@invariant--labs/foundation 1.1.2 → 1.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/core/application/index.d.ts +2 -0
- package/dist/core/application/index.d.ts.map +1 -0
- package/dist/core/application/index.js +5 -0
- package/dist/core/application/index.js.map +1 -0
- package/{src/core/application/persistence/index.ts → dist/core/application/persistence/index.d.ts} +1 -0
- package/dist/core/application/persistence/index.d.ts.map +1 -0
- package/dist/core/application/persistence/index.js +7 -0
- package/dist/core/application/persistence/index.js.map +1 -0
- package/dist/core/application/persistence/query-builder.d.ts +3 -0
- package/dist/core/application/persistence/query-builder.d.ts.map +1 -0
- package/dist/core/application/persistence/query-builder.js +3 -0
- package/dist/core/application/persistence/query-builder.js.map +1 -0
- package/dist/core/application/persistence/read-projection.d.ts +3 -0
- package/dist/core/application/persistence/read-projection.d.ts.map +1 -0
- package/dist/core/application/persistence/read-projection.js +3 -0
- package/dist/core/application/persistence/read-projection.js.map +1 -0
- package/dist/core/application/persistence/repository.d.ts +24 -0
- package/dist/core/application/persistence/repository.d.ts.map +1 -0
- package/dist/core/application/persistence/repository.js +7 -0
- package/dist/core/application/persistence/repository.js.map +1 -0
- package/dist/core/domain/entities/aggregate-root.d.ts +16 -0
- package/dist/core/domain/entities/aggregate-root.d.ts.map +1 -0
- package/dist/core/domain/entities/aggregate-root.js +38 -0
- package/dist/core/domain/entities/aggregate-root.js.map +1 -0
- package/dist/core/domain/entities/entity.d.ts +15 -0
- package/dist/core/domain/entities/entity.d.ts.map +1 -0
- package/dist/core/domain/entities/entity.js +33 -0
- package/dist/core/domain/entities/entity.js.map +1 -0
- package/dist/core/domain/entities/identifier.d.ts +8 -0
- package/dist/core/domain/entities/identifier.d.ts.map +1 -0
- package/dist/core/domain/entities/identifier.js +23 -0
- package/dist/core/domain/entities/identifier.js.map +1 -0
- package/{src/core/domain/entities/index.ts → dist/core/domain/entities/index.d.ts} +1 -0
- package/dist/core/domain/entities/index.d.ts.map +1 -0
- package/dist/core/domain/entities/index.js +9 -0
- package/dist/core/domain/entities/index.js.map +1 -0
- package/{src/core/domain/entities/projection.ts → dist/core/domain/entities/projection.d.ts} +2 -3
- package/dist/core/domain/entities/projection.d.ts.map +1 -0
- package/dist/core/domain/entities/projection.js +3 -0
- package/dist/core/domain/entities/projection.js.map +1 -0
- package/dist/core/domain/entities/unique-entity-id.d.ts +5 -0
- package/dist/core/domain/entities/unique-entity-id.d.ts.map +1 -0
- package/dist/core/domain/entities/unique-entity-id.js +12 -0
- package/dist/core/domain/entities/unique-entity-id.js.map +1 -0
- package/dist/core/domain/events/domain-event.d.ts +7 -0
- package/dist/core/domain/events/domain-event.d.ts.map +1 -0
- package/dist/core/domain/events/domain-event.js +12 -0
- package/dist/core/domain/events/domain-event.js.map +1 -0
- package/dist/core/domain/events/index.d.ts +2 -0
- package/dist/core/domain/events/index.d.ts.map +1 -0
- package/dist/core/domain/events/index.js +5 -0
- package/dist/core/domain/events/index.js.map +1 -0
- package/{src/core/domain/index.ts → dist/core/domain/index.d.ts} +1 -0
- package/dist/core/domain/index.d.ts.map +1 -0
- package/dist/core/domain/index.js +7 -0
- package/dist/core/domain/index.js.map +1 -0
- package/{src/core/domain/value-objects/index.ts → dist/core/domain/value-objects/index.d.ts} +1 -0
- package/dist/core/domain/value-objects/index.d.ts.map +1 -0
- package/dist/core/domain/value-objects/index.js +6 -0
- package/dist/core/domain/value-objects/index.js.map +1 -0
- package/dist/core/domain/value-objects/range.d.ts +5 -0
- package/dist/core/domain/value-objects/range.d.ts.map +1 -0
- package/dist/core/domain/value-objects/range.js +3 -0
- package/dist/core/domain/value-objects/range.js.map +1 -0
- package/dist/core/domain/value-objects/value-object.d.ts +8 -0
- package/dist/core/domain/value-objects/value-object.d.ts.map +1 -0
- package/dist/core/domain/value-objects/value-object.js +19 -0
- package/dist/core/domain/value-objects/value-object.js.map +1 -0
- package/dist/core/errors/application/application.error.d.ts +6 -0
- package/dist/core/errors/application/application.error.d.ts.map +1 -0
- package/dist/core/errors/application/application.error.js +13 -0
- package/dist/core/errors/application/application.error.js.map +1 -0
- package/dist/core/errors/application/command-failure.error.d.ts +5 -0
- package/dist/core/errors/application/command-failure.error.d.ts.map +1 -0
- package/dist/core/errors/application/command-failure.error.js +11 -0
- package/dist/core/errors/application/command-failure.error.js.map +1 -0
- package/dist/core/errors/application/command-filter.error.d.ts +4 -0
- package/dist/core/errors/application/command-filter.error.d.ts.map +1 -0
- package/dist/core/errors/application/command-filter.error.js +8 -0
- package/dist/core/errors/application/command-filter.error.js.map +1 -0
- package/{src/core/errors/index.ts → dist/core/errors/application/index.d.ts} +2 -4
- package/dist/core/errors/application/index.d.ts.map +1 -0
- package/dist/core/errors/application/index.js +9 -0
- package/dist/core/errors/application/index.js.map +1 -0
- package/dist/core/errors/application/query-failure.error.d.ts +5 -0
- package/dist/core/errors/application/query-failure.error.d.ts.map +1 -0
- package/dist/core/errors/application/query-failure.error.js +11 -0
- package/dist/core/errors/application/query-failure.error.js.map +1 -0
- package/dist/core/errors/application/too-many-results.error.d.ts +5 -0
- package/dist/core/errors/application/too-many-results.error.d.ts.map +1 -0
- package/dist/core/errors/application/too-many-results.error.js +11 -0
- package/dist/core/errors/application/too-many-results.error.js.map +1 -0
- package/dist/core/errors/detailed.error.d.ts +11 -0
- package/dist/core/errors/detailed.error.d.ts.map +1 -0
- package/dist/core/errors/detailed.error.js +23 -0
- package/dist/core/errors/detailed.error.js.map +1 -0
- package/dist/core/errors/domain/domain.error.d.ts +6 -0
- package/dist/core/errors/domain/domain.error.d.ts.map +1 -0
- package/dist/core/errors/domain/domain.error.js +13 -0
- package/dist/core/errors/domain/domain.error.js.map +1 -0
- package/dist/core/errors/domain/index.d.ts +2 -0
- package/dist/core/errors/domain/index.d.ts.map +1 -0
- package/dist/core/errors/domain/index.js +5 -0
- package/dist/core/errors/domain/index.js.map +1 -0
- package/dist/core/errors/index.d.ts +5 -0
- package/dist/core/errors/index.d.ts.map +1 -0
- package/dist/core/errors/index.js +8 -0
- package/dist/core/errors/index.js.map +1 -0
- package/dist/core/errors/infrastructure/entity-not-found.error.d.ts +6 -0
- package/dist/core/errors/infrastructure/entity-not-found.error.d.ts.map +1 -0
- package/dist/core/errors/infrastructure/entity-not-found.error.js +11 -0
- package/dist/core/errors/infrastructure/entity-not-found.error.js.map +1 -0
- package/dist/core/errors/infrastructure/fake-implementation.error.d.ts +5 -0
- package/dist/core/errors/infrastructure/fake-implementation.error.d.ts.map +1 -0
- package/dist/core/errors/infrastructure/fake-implementation.error.js +11 -0
- package/dist/core/errors/infrastructure/fake-implementation.error.js.map +1 -0
- package/dist/core/errors/infrastructure/index.d.ts +4 -0
- package/dist/core/errors/infrastructure/index.d.ts.map +1 -0
- package/dist/core/errors/infrastructure/index.js +7 -0
- package/dist/core/errors/infrastructure/index.js.map +1 -0
- package/dist/core/errors/infrastructure/infrastructure.error.d.ts +6 -0
- package/dist/core/errors/infrastructure/infrastructure.error.d.ts.map +1 -0
- package/dist/core/errors/infrastructure/infrastructure.error.js +13 -0
- package/dist/core/errors/infrastructure/infrastructure.error.js.map +1 -0
- package/{src/core/index.ts → dist/core/index.d.ts} +1 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +8 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/infrastructure/config/config.provider.d.ts +21 -0
- package/dist/core/infrastructure/config/config.provider.d.ts.map +1 -0
- package/dist/core/infrastructure/config/config.provider.js +93 -0
- package/dist/core/infrastructure/config/config.provider.js.map +1 -0
- package/dist/core/infrastructure/config/config.service.d.ts +15 -0
- package/dist/core/infrastructure/config/config.service.d.ts.map +1 -0
- package/dist/core/infrastructure/config/config.service.js +7 -0
- package/dist/core/infrastructure/config/config.service.js.map +1 -0
- package/{src/core/infrastructure/config/index.ts → dist/core/infrastructure/config/index.d.ts} +1 -0
- package/dist/core/infrastructure/config/index.d.ts.map +1 -0
- package/dist/core/infrastructure/config/index.js +6 -0
- package/dist/core/infrastructure/config/index.js.map +1 -0
- package/dist/core/infrastructure/messaging/fake/fake-messaging.service.d.ts +8 -0
- package/dist/core/infrastructure/messaging/fake/fake-messaging.service.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/fake/fake-messaging.service.js +17 -0
- package/dist/core/infrastructure/messaging/fake/fake-messaging.service.js.map +1 -0
- package/dist/core/infrastructure/messaging/fake/fake-queue-manager.service.d.ts +6 -0
- package/dist/core/infrastructure/messaging/fake/fake-queue-manager.service.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/fake/fake-queue-manager.service.js +11 -0
- package/dist/core/infrastructure/messaging/fake/fake-queue-manager.service.js.map +1 -0
- package/dist/core/infrastructure/messaging/fake/fake-queue-messaging.service.d.ts +6 -0
- package/dist/core/infrastructure/messaging/fake/fake-queue-messaging.service.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/fake/fake-queue-messaging.service.js +11 -0
- package/dist/core/infrastructure/messaging/fake/fake-queue-messaging.service.js.map +1 -0
- package/{src/core/infrastructure/messaging/fake/index.ts → dist/core/infrastructure/messaging/fake/index.d.ts} +1 -0
- package/dist/core/infrastructure/messaging/fake/index.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/fake/index.js +7 -0
- package/dist/core/infrastructure/messaging/fake/index.js.map +1 -0
- package/{src/core/infrastructure/messaging/index.ts → dist/core/infrastructure/messaging/index.d.ts} +1 -0
- package/dist/core/infrastructure/messaging/index.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/index.js +10 -0
- package/dist/core/infrastructure/messaging/index.js.map +1 -0
- package/dist/core/infrastructure/messaging/messaging.service.d.ts +4 -0
- package/dist/core/infrastructure/messaging/messaging.service.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/messaging.service.js +7 -0
- package/dist/core/infrastructure/messaging/messaging.service.js.map +1 -0
- package/dist/core/infrastructure/messaging/queue-manager.service.d.ts +6 -0
- package/dist/core/infrastructure/messaging/queue-manager.service.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/queue-manager.service.js +7 -0
- package/dist/core/infrastructure/messaging/queue-manager.service.js.map +1 -0
- package/dist/core/infrastructure/messaging/queue-messaging.service.d.ts +4 -0
- package/dist/core/infrastructure/messaging/queue-messaging.service.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/queue-messaging.service.js +7 -0
- package/dist/core/infrastructure/messaging/queue-messaging.service.js.map +1 -0
- package/{src/core/infrastructure/messaging/rabbitmq/index.ts → dist/core/infrastructure/messaging/rabbitmq/index.d.ts} +1 -0
- package/dist/core/infrastructure/messaging/rabbitmq/index.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/rabbitmq/index.js +6 -0
- package/dist/core/infrastructure/messaging/rabbitmq/index.js.map +1 -0
- package/dist/core/infrastructure/messaging/rabbitmq/rabbit-messaging.service.d.ts +8 -0
- package/dist/core/infrastructure/messaging/rabbitmq/rabbit-messaging.service.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/rabbitmq/rabbit-messaging.service.js +14 -0
- package/dist/core/infrastructure/messaging/rabbitmq/rabbit-messaging.service.js.map +1 -0
- package/dist/core/infrastructure/messaging/rabbitmq/rabbit-queue-messaging.service.d.ts +8 -0
- package/dist/core/infrastructure/messaging/rabbitmq/rabbit-queue-messaging.service.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/rabbitmq/rabbit-queue-messaging.service.js +14 -0
- package/dist/core/infrastructure/messaging/rabbitmq/rabbit-queue-messaging.service.js.map +1 -0
- package/dist/core/infrastructure/messaging/types.d.ts +22 -0
- package/dist/core/infrastructure/messaging/types.d.ts.map +1 -0
- package/dist/core/infrastructure/messaging/types.js +12 -0
- package/dist/core/infrastructure/messaging/types.js.map +1 -0
- package/{src/core/infrastructure/persistence/errors/index.ts → dist/core/infrastructure/persistence/errors/index.d.ts} +1 -0
- package/dist/core/infrastructure/persistence/errors/index.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/errors/index.js +6 -0
- package/dist/core/infrastructure/persistence/errors/index.js.map +1 -0
- package/dist/core/infrastructure/persistence/errors/model-to-entity-conversion.error.d.ts +5 -0
- package/dist/core/infrastructure/persistence/errors/model-to-entity-conversion.error.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/errors/model-to-entity-conversion.error.js +13 -0
- package/dist/core/infrastructure/persistence/errors/model-to-entity-conversion.error.js.map +1 -0
- package/dist/core/infrastructure/persistence/errors/persistence.error.d.ts +6 -0
- package/dist/core/infrastructure/persistence/errors/persistence.error.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/errors/persistence.error.js +11 -0
- package/dist/core/infrastructure/persistence/errors/persistence.error.js.map +1 -0
- package/dist/core/infrastructure/persistence/in-memory/fake.repository.d.ts +20 -0
- package/dist/core/infrastructure/persistence/in-memory/fake.repository.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/in-memory/fake.repository.js +69 -0
- package/dist/core/infrastructure/persistence/in-memory/fake.repository.js.map +1 -0
- package/dist/core/infrastructure/persistence/in-memory/in-memory.query-builder.d.ts +5 -0
- package/dist/core/infrastructure/persistence/in-memory/in-memory.query-builder.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/in-memory/in-memory.query-builder.js +8 -0
- package/dist/core/infrastructure/persistence/in-memory/in-memory.query-builder.js.map +1 -0
- package/dist/core/infrastructure/persistence/in-memory/in-memory.repository.d.ts +20 -0
- package/dist/core/infrastructure/persistence/in-memory/in-memory.repository.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/in-memory/in-memory.repository.js +69 -0
- package/dist/core/infrastructure/persistence/in-memory/in-memory.repository.js.map +1 -0
- package/{src/core/infrastructure/persistence/in-memory/index.ts → dist/core/infrastructure/persistence/in-memory/index.d.ts} +1 -0
- package/dist/core/infrastructure/persistence/in-memory/index.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/in-memory/index.js +7 -0
- package/dist/core/infrastructure/persistence/in-memory/index.js.map +1 -0
- package/{src/core/infrastructure/persistence/index.ts → dist/core/infrastructure/persistence/index.d.ts} +1 -0
- package/dist/core/infrastructure/persistence/index.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/index.js +8 -0
- package/dist/core/infrastructure/persistence/index.js.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/in-memory.query-builder.d.ts +5 -0
- package/dist/core/infrastructure/persistence/read-side/in-memory.query-builder.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/in-memory.query-builder.js +8 -0
- package/dist/core/infrastructure/persistence/read-side/in-memory.query-builder.js.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/index.d.ts +2 -0
- package/dist/core/infrastructure/persistence/read-side/index.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/index.js +5 -0
- package/dist/core/infrastructure/persistence/read-side/index.js.map +1 -0
- package/{src/core/infrastructure/persistence/read-side/knex/index.ts → dist/core/infrastructure/persistence/read-side/knex/index.d.ts} +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex/index.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex/index.js +6 -0
- package/dist/core/infrastructure/persistence/read-side/knex/index.js.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex/knex-types.definition.d.ts +9 -0
- package/dist/core/infrastructure/persistence/read-side/knex/knex-types.definition.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex/knex-types.definition.js +3 -0
- package/dist/core/infrastructure/persistence/read-side/knex/knex-types.definition.js.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex/knex.query-builder.d.ts +24 -0
- package/dist/core/infrastructure/persistence/read-side/knex/knex.query-builder.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex/knex.query-builder.js +57 -0
- package/dist/core/infrastructure/persistence/read-side/knex/knex.query-builder.js.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex-query-builder.d.ts +24 -0
- package/dist/core/infrastructure/persistence/read-side/knex-query-builder.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex-query-builder.js +57 -0
- package/dist/core/infrastructure/persistence/read-side/knex-query-builder.js.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex-types.definition.d.ts +9 -0
- package/dist/core/infrastructure/persistence/read-side/knex-types.definition.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/read-side/knex-types.definition.js +3 -0
- package/dist/core/infrastructure/persistence/read-side/knex-types.definition.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/aggregate-typeorm-repository.d.ts +19 -0
- package/dist/core/infrastructure/persistence/write-side/aggregate-typeorm-repository.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/aggregate-typeorm-repository.js +68 -0
- package/dist/core/infrastructure/persistence/write-side/aggregate-typeorm-repository.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/entity-typeorm-repository.d.ts +19 -0
- package/dist/core/infrastructure/persistence/write-side/entity-typeorm-repository.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/entity-typeorm-repository.js +44 -0
- package/dist/core/infrastructure/persistence/write-side/entity-typeorm-repository.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/in-memory.repository.d.ts +21 -0
- package/dist/core/infrastructure/persistence/write-side/in-memory.repository.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/in-memory.repository.js +69 -0
- package/dist/core/infrastructure/persistence/write-side/in-memory.repository.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/index.d.ts +2 -0
- package/dist/core/infrastructure/persistence/write-side/index.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/index.js +5 -0
- package/dist/core/infrastructure/persistence/write-side/index.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/model-attributes.d.ts +2 -0
- package/dist/core/infrastructure/persistence/write-side/model-attributes.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/model-attributes.js +3 -0
- package/dist/core/infrastructure/persistence/write-side/model-attributes.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/orm-embedded-mapper.d.ts +6 -0
- package/dist/core/infrastructure/persistence/write-side/orm-embedded-mapper.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/orm-embedded-mapper.js +3 -0
- package/dist/core/infrastructure/persistence/write-side/orm-embedded-mapper.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/orm-mapper.d.ts +6 -0
- package/dist/core/infrastructure/persistence/write-side/orm-mapper.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/orm-mapper.js +3 -0
- package/dist/core/infrastructure/persistence/write-side/orm-mapper.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/aggregate-typeorm.repository.d.ts +19 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/aggregate-typeorm.repository.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/aggregate-typeorm.repository.js +68 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/aggregate-typeorm.repository.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/entity-typeorm.repository.d.ts +19 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/entity-typeorm.repository.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/entity-typeorm.repository.js +44 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/entity-typeorm.repository.js.map +1 -0
- package/{src/core/infrastructure/persistence/write-side/typeorm/index.ts → dist/core/infrastructure/persistence/write-side/typeorm/index.d.ts} +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/index.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/index.js +9 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/index.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/model-attributes.d.ts +2 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/model-attributes.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/model-attributes.js +3 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/model-attributes.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/orm-embedded.mapper.d.ts +6 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/orm-embedded.mapper.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/orm-embedded.mapper.js +3 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/orm-embedded.mapper.js.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/orm.mapper.d.ts +6 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/orm.mapper.d.ts.map +1 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/orm.mapper.js +3 -0
- package/dist/core/infrastructure/persistence/write-side/typeorm/orm.mapper.js.map +1 -0
- package/dist/core/types/architecture-layer.d.ts +35 -0
- package/dist/core/types/architecture-layer.d.ts.map +1 -0
- package/dist/core/types/architecture-layer.js +11 -0
- package/dist/core/types/architecture-layer.js.map +1 -0
- package/{src/core/types/array-element.ts → dist/core/types/array-element.d.ts} +1 -2
- package/dist/core/types/array-element.d.ts.map +1 -0
- package/dist/core/types/array-element.js +3 -0
- package/dist/core/types/array-element.js.map +1 -0
- package/{src/core/types/index.ts → dist/core/types/index.d.ts} +1 -0
- package/dist/core/types/index.d.ts.map +1 -0
- package/dist/core/types/index.js +6 -0
- package/dist/core/types/index.js.map +1 -0
- package/{src/index.ts → dist/index.d.ts} +1 -11
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +23 -0
- package/dist/index.js.map +1 -0
- package/dist/modules/config/config.module.d.ts +3 -0
- package/dist/modules/config/config.module.d.ts.map +1 -0
- package/dist/modules/config/config.module.js +16 -0
- package/dist/modules/config/config.module.js.map +1 -0
- package/{src/modules/config/index.ts → dist/modules/config/index.d.ts} +1 -0
- package/dist/modules/config/index.d.ts.map +1 -0
- package/dist/modules/config/index.js +6 -0
- package/dist/modules/config/index.js.map +1 -0
- package/{src/modules/graphql/index.ts → dist/modules/graphql/index.d.ts} +1 -0
- package/dist/modules/graphql/index.d.ts.map +1 -0
- package/dist/modules/graphql/index.js +5 -0
- package/dist/modules/graphql/index.js.map +1 -0
- package/dist/modules/graphql/paginated-response.object-type.d.ts +8 -0
- package/dist/modules/graphql/paginated-response.object-type.d.ts.map +1 -0
- package/dist/modules/graphql/paginated-response.object-type.js +29 -0
- package/dist/modules/graphql/paginated-response.object-type.js.map +1 -0
- package/dist/modules/healthcheck/healthcheck-out.dto.d.ts +15 -0
- package/dist/modules/healthcheck/healthcheck-out.dto.d.ts.map +1 -0
- package/dist/modules/healthcheck/healthcheck-out.dto.js +67 -0
- package/dist/modules/healthcheck/healthcheck-out.dto.js.map +1 -0
- package/{src/modules/healthcheck/index.ts → dist/modules/healthcheck/index.d.ts} +1 -0
- package/dist/modules/healthcheck/index.d.ts.map +1 -0
- package/dist/modules/healthcheck/index.js +5 -0
- package/dist/modules/healthcheck/index.js.map +1 -0
- package/{src/modules/knex/index.ts → dist/modules/knex/index.d.ts} +1 -0
- package/dist/modules/knex/index.d.ts.map +1 -0
- package/dist/modules/knex/index.js +7 -0
- package/dist/modules/knex/index.js.map +1 -0
- package/dist/modules/knex/knex-core.module.d.ts +6 -0
- package/dist/modules/knex/knex-core.module.d.ts.map +1 -0
- package/dist/modules/knex/knex-core.module.js +34 -0
- package/dist/modules/knex/knex-core.module.js.map +1 -0
- package/dist/modules/knex/knex.decorator.d.ts +2 -0
- package/dist/modules/knex/knex.decorator.d.ts.map +1 -0
- package/dist/modules/knex/knex.decorator.js +8 -0
- package/dist/modules/knex/knex.decorator.js.map +1 -0
- package/dist/modules/knex/knex.interface.d.ts +9 -0
- package/dist/modules/knex/knex.interface.d.ts.map +1 -0
- package/dist/modules/knex/knex.interface.js +3 -0
- package/dist/modules/knex/knex.interface.js.map +1 -0
- package/dist/modules/knex/knex.module.d.ts +6 -0
- package/dist/modules/knex/knex.module.d.ts.map +1 -0
- package/dist/modules/knex/knex.module.js +15 -0
- package/dist/modules/knex/knex.module.js.map +1 -0
- package/dist/modules/knex/knex.token.d.ts +3 -0
- package/dist/modules/knex/knex.token.d.ts.map +1 -0
- package/dist/modules/knex/knex.token.js +6 -0
- package/dist/modules/knex/knex.token.js.map +1 -0
- package/dist/modules/logger/app-logger.d.ts +13 -0
- package/dist/modules/logger/app-logger.d.ts.map +1 -0
- package/dist/modules/logger/app-logger.js +29 -0
- package/dist/modules/logger/app-logger.js.map +1 -0
- package/{src/modules/logger/index.ts → dist/modules/logger/index.d.ts} +1 -0
- package/dist/modules/logger/index.d.ts.map +1 -0
- package/dist/modules/logger/index.js +9 -0
- package/dist/modules/logger/index.js.map +1 -0
- package/dist/modules/logger/log.d.ts +26 -0
- package/dist/modules/logger/log.d.ts.map +1 -0
- package/dist/modules/logger/log.js +14 -0
- package/dist/modules/logger/log.js.map +1 -0
- package/dist/modules/logger/logger.module.d.ts +5 -0
- package/dist/modules/logger/logger.module.d.ts.map +1 -0
- package/dist/modules/logger/logger.module.js +52 -0
- package/dist/modules/logger/logger.module.js.map +1 -0
- package/dist/modules/logger/logger.service.d.ts +28 -0
- package/dist/modules/logger/logger.service.d.ts.map +1 -0
- package/dist/modules/logger/logger.service.js +128 -0
- package/dist/modules/logger/logger.service.js.map +1 -0
- package/dist/modules/logger/transports/console-color.transport.d.ts +7 -0
- package/dist/modules/logger/transports/console-color.transport.d.ts.map +1 -0
- package/dist/modules/logger/transports/console-color.transport.js +40 -0
- package/dist/modules/logger/transports/console-color.transport.js.map +1 -0
- package/dist/modules/logger/transports/console-json.transport.d.ts +7 -0
- package/dist/modules/logger/transports/console-json.transport.d.ts.map +1 -0
- package/dist/modules/logger/transports/console-json.transport.js +24 -0
- package/dist/modules/logger/transports/console-json.transport.js.map +1 -0
- package/dist/modules/logger/transports/console.transport.d.ts +6 -0
- package/dist/modules/logger/transports/console.transport.d.ts.map +1 -0
- package/dist/modules/logger/transports/console.transport.js +12 -0
- package/dist/modules/logger/transports/console.transport.js.map +1 -0
- package/dist/modules/logger/transports/fake.transport.d.ts +9 -0
- package/dist/modules/logger/transports/fake.transport.d.ts.map +1 -0
- package/dist/modules/logger/transports/fake.transport.js +18 -0
- package/dist/modules/logger/transports/fake.transport.js.map +1 -0
- package/{src/modules/logger/transports/index.ts → dist/modules/logger/transports/index.d.ts} +1 -0
- package/dist/modules/logger/transports/index.d.ts.map +1 -0
- package/dist/modules/logger/transports/index.js +9 -0
- package/dist/modules/logger/transports/index.js.map +1 -0
- package/dist/modules/logger/transports/logger-transport.d.ts +12 -0
- package/dist/modules/logger/transports/logger-transport.d.ts.map +1 -0
- package/dist/modules/logger/transports/logger-transport.js +20 -0
- package/dist/modules/logger/transports/logger-transport.js.map +1 -0
- package/{src/modules/messaging/index.ts → dist/modules/messaging/index.d.ts} +1 -0
- package/dist/modules/messaging/index.d.ts.map +1 -0
- package/dist/modules/messaging/index.js +6 -0
- package/dist/modules/messaging/index.js.map +1 -0
- package/dist/modules/messaging/messaging.module.d.ts +6 -0
- package/dist/modules/messaging/messaging.module.d.ts.map +1 -0
- package/dist/modules/messaging/messaging.module.js +98 -0
- package/dist/modules/messaging/messaging.module.js.map +1 -0
- package/dist/modules/queue/default-queue-name.resolver.d.ts +4 -0
- package/dist/modules/queue/default-queue-name.resolver.d.ts.map +1 -0
- package/dist/modules/queue/default-queue-name.resolver.js +6 -0
- package/dist/modules/queue/default-queue-name.resolver.js.map +1 -0
- package/{src/modules/queue/index.ts → dist/modules/queue/index.d.ts} +1 -0
- package/dist/modules/queue/index.d.ts.map +1 -0
- package/dist/modules/queue/index.js +7 -0
- package/dist/modules/queue/index.js.map +1 -0
- package/dist/modules/queue/queue.module.d.ts +6 -0
- package/dist/modules/queue/queue.module.d.ts.map +1 -0
- package/dist/modules/queue/queue.module.js +64 -0
- package/dist/modules/queue/queue.module.js.map +1 -0
- package/dist/modules/queue/rabbit-queue-manager.service.d.ts +14 -0
- package/dist/modules/queue/rabbit-queue-manager.service.d.ts.map +1 -0
- package/dist/modules/queue/rabbit-queue-manager.service.js +68 -0
- package/dist/modules/queue/rabbit-queue-manager.service.js.map +1 -0
- package/dist/nestjs/errors/handlers/error-handler.d.ts +10 -0
- package/dist/nestjs/errors/handlers/error-handler.d.ts.map +1 -0
- package/dist/nestjs/errors/handlers/error-handler.js +33 -0
- package/dist/nestjs/errors/handlers/error-handler.js.map +1 -0
- package/{src/nestjs/errors/handlers/error-handler.type.ts → dist/nestjs/errors/handlers/error-handler.type.d.ts} +7 -15
- package/dist/nestjs/errors/handlers/error-handler.type.d.ts.map +1 -0
- package/dist/nestjs/errors/handlers/error-handler.type.js +3 -0
- package/dist/nestjs/errors/handlers/error-handler.type.js.map +1 -0
- package/dist/nestjs/errors/handlers/generic-error-handler.d.ts +6 -0
- package/dist/nestjs/errors/handlers/generic-error-handler.d.ts.map +1 -0
- package/dist/nestjs/errors/handlers/generic-error-handler.js +49 -0
- package/dist/nestjs/errors/handlers/generic-error-handler.js.map +1 -0
- package/dist/nestjs/errors/handlers/handle-errors.decorator.d.ts +3 -0
- package/dist/nestjs/errors/handlers/handle-errors.decorator.d.ts.map +1 -0
- package/dist/nestjs/errors/handlers/handle-errors.decorator.js +36 -0
- package/dist/nestjs/errors/handlers/handle-errors.decorator.js.map +1 -0
- package/{src/nestjs/errors/handlers/index.ts → dist/nestjs/errors/handlers/index.d.ts} +1 -0
- package/dist/nestjs/errors/handlers/index.d.ts.map +1 -0
- package/dist/nestjs/errors/handlers/index.js +9 -0
- package/dist/nestjs/errors/handlers/index.js.map +1 -0
- package/dist/nestjs/errors/handlers/validation-error-handler.d.ts +7 -0
- package/dist/nestjs/errors/handlers/validation-error-handler.d.ts.map +1 -0
- package/dist/nestjs/errors/handlers/validation-error-handler.js +43 -0
- package/dist/nestjs/errors/handlers/validation-error-handler.js.map +1 -0
- package/{src/nestjs/errors/index.ts → dist/nestjs/errors/index.d.ts} +1 -0
- package/dist/nestjs/errors/index.d.ts.map +1 -0
- package/dist/nestjs/errors/index.js +6 -0
- package/dist/nestjs/errors/index.js.map +1 -0
- package/dist/nestjs/errors/parsers/axios-metadata.parser.d.ts +3 -0
- package/dist/nestjs/errors/parsers/axios-metadata.parser.d.ts.map +1 -0
- package/dist/nestjs/errors/parsers/axios-metadata.parser.js +20 -0
- package/dist/nestjs/errors/parsers/axios-metadata.parser.js.map +1 -0
- package/dist/nestjs/errors/parsers/error-metadata.definition.d.ts +2 -0
- package/dist/nestjs/errors/parsers/error-metadata.definition.d.ts.map +1 -0
- package/dist/nestjs/errors/parsers/error-metadata.definition.js +3 -0
- package/dist/nestjs/errors/parsers/error-metadata.definition.js.map +1 -0
- package/{src/nestjs/errors/parsers/index.ts → dist/nestjs/errors/parsers/index.d.ts} +1 -0
- package/dist/nestjs/errors/parsers/index.d.ts.map +1 -0
- package/dist/nestjs/errors/parsers/index.js +9 -0
- package/dist/nestjs/errors/parsers/index.js.map +1 -0
- package/dist/nestjs/errors/parsers/knex-metadata.parser.d.ts +3 -0
- package/dist/nestjs/errors/parsers/knex-metadata.parser.d.ts.map +1 -0
- package/dist/nestjs/errors/parsers/knex-metadata.parser.js +18 -0
- package/dist/nestjs/errors/parsers/knex-metadata.parser.js.map +1 -0
- package/dist/nestjs/errors/parsers/typeorm-metadata.parser.d.ts +3 -0
- package/dist/nestjs/errors/parsers/typeorm-metadata.parser.d.ts.map +1 -0
- package/dist/nestjs/errors/parsers/typeorm-metadata.parser.js +20 -0
- package/dist/nestjs/errors/parsers/typeorm-metadata.parser.js.map +1 -0
- package/dist/nestjs/errors/parsers/workos-metadata.parser.d.ts +3 -0
- package/dist/nestjs/errors/parsers/workos-metadata.parser.d.ts.map +1 -0
- package/dist/nestjs/errors/parsers/workos-metadata.parser.js +17 -0
- package/dist/nestjs/errors/parsers/workos-metadata.parser.js.map +1 -0
- package/{src/nestjs/http/decorators/index.ts → dist/nestjs/http/decorators/index.d.ts} +1 -0
- package/dist/nestjs/http/decorators/index.d.ts.map +1 -0
- package/dist/nestjs/http/decorators/index.js +5 -0
- package/dist/nestjs/http/decorators/index.js.map +1 -0
- package/dist/nestjs/http/decorators/log-app-ctx.decorator.d.ts +2 -0
- package/dist/nestjs/http/decorators/log-app-ctx.decorator.d.ts.map +1 -0
- package/dist/nestjs/http/decorators/log-app-ctx.decorator.js +28 -0
- package/dist/nestjs/http/decorators/log-app-ctx.decorator.js.map +1 -0
- package/dist/nestjs/http/dtos/date-range.dto.d.ts +5 -0
- package/dist/nestjs/http/dtos/date-range.dto.d.ts.map +1 -0
- package/dist/nestjs/http/dtos/date-range.dto.js +24 -0
- package/dist/nestjs/http/dtos/date-range.dto.js.map +1 -0
- package/dist/nestjs/http/dtos/index.d.ts +2 -0
- package/dist/nestjs/http/dtos/index.d.ts.map +1 -0
- package/dist/nestjs/http/dtos/index.js +5 -0
- package/dist/nestjs/http/dtos/index.js.map +1 -0
- package/dist/nestjs/http/filters/all-exceptions.filter.d.ts +15 -0
- package/dist/nestjs/http/filters/all-exceptions.filter.d.ts.map +1 -0
- package/dist/nestjs/http/filters/all-exceptions.filter.js +82 -0
- package/dist/nestjs/http/filters/all-exceptions.filter.js.map +1 -0
- package/dist/nestjs/http/filters/command-failure.filter.d.ts +7 -0
- package/dist/nestjs/http/filters/command-failure.filter.d.ts.map +1 -0
- package/dist/nestjs/http/filters/command-failure.filter.js +20 -0
- package/dist/nestjs/http/filters/command-failure.filter.js.map +1 -0
- package/{src/nestjs/http/filters/index.ts → dist/nestjs/http/filters/index.d.ts} +1 -0
- package/dist/nestjs/http/filters/index.d.ts.map +1 -0
- package/dist/nestjs/http/filters/index.js +8 -0
- package/dist/nestjs/http/filters/index.js.map +1 -0
- package/dist/nestjs/http/filters/rpc-exceptions.filter.d.ts +7 -0
- package/dist/nestjs/http/filters/rpc-exceptions.filter.d.ts.map +1 -0
- package/dist/nestjs/http/filters/rpc-exceptions.filter.js +17 -0
- package/dist/nestjs/http/filters/rpc-exceptions.filter.js.map +1 -0
- package/dist/nestjs/http/filters/too-many-results.filter.d.ts +7 -0
- package/dist/nestjs/http/filters/too-many-results.filter.d.ts.map +1 -0
- package/dist/nestjs/http/filters/too-many-results.filter.js +20 -0
- package/dist/nestjs/http/filters/too-many-results.filter.js.map +1 -0
- package/{src/nestjs/http/index.ts → dist/nestjs/http/index.d.ts} +1 -0
- package/dist/nestjs/http/index.d.ts.map +1 -0
- package/dist/nestjs/http/index.js +10 -0
- package/dist/nestjs/http/index.js.map +1 -0
- package/{src/nestjs/http/interceptors/index.ts → dist/nestjs/http/interceptors/index.d.ts} +1 -0
- package/dist/nestjs/http/interceptors/index.d.ts.map +1 -0
- package/dist/nestjs/http/interceptors/index.js +6 -0
- package/dist/nestjs/http/interceptors/index.js.map +1 -0
- package/dist/nestjs/http/interceptors/log-app-ctx.interceptor.d.ts +12 -0
- package/dist/nestjs/http/interceptors/log-app-ctx.interceptor.d.ts.map +1 -0
- package/dist/nestjs/http/interceptors/log-app-ctx.interceptor.js +107 -0
- package/dist/nestjs/http/interceptors/log-app-ctx.interceptor.js.map +1 -0
- package/dist/nestjs/http/interceptors/serialize-output.interceptor.d.ts +3 -0
- package/dist/nestjs/http/interceptors/serialize-output.interceptor.d.ts.map +1 -0
- package/dist/nestjs/http/interceptors/serialize-output.interceptor.js +18 -0
- package/dist/nestjs/http/interceptors/serialize-output.interceptor.js.map +1 -0
- package/dist/nestjs/http/middleware/http-logger.middleware.d.ts +9 -0
- package/dist/nestjs/http/middleware/http-logger.middleware.d.ts.map +1 -0
- package/dist/nestjs/http/middleware/http-logger.middleware.js +39 -0
- package/dist/nestjs/http/middleware/http-logger.middleware.js.map +1 -0
- package/{src/nestjs/http/middleware/index.ts → dist/nestjs/http/middleware/index.d.ts} +1 -0
- package/dist/nestjs/http/middleware/index.d.ts.map +1 -0
- package/dist/nestjs/http/middleware/index.js +6 -0
- package/dist/nestjs/http/middleware/index.js.map +1 -0
- package/dist/nestjs/http/middleware/logger.middleware.d.ts +9 -0
- package/dist/nestjs/http/middleware/logger.middleware.d.ts.map +1 -0
- package/dist/nestjs/http/middleware/logger.middleware.js +28 -0
- package/dist/nestjs/http/middleware/logger.middleware.js.map +1 -0
- package/dist/nestjs/http/swagger/index.d.ts +2 -0
- package/dist/nestjs/http/swagger/index.d.ts.map +1 -0
- package/dist/nestjs/http/swagger/index.js +5 -0
- package/dist/nestjs/http/swagger/index.js.map +1 -0
- package/dist/nestjs/http/swagger/swagger.d.ts +3 -0
- package/dist/nestjs/http/swagger/swagger.d.ts.map +1 -0
- package/dist/nestjs/http/swagger/swagger.js +38 -0
- package/dist/nestjs/http/swagger/swagger.js.map +1 -0
- package/{src/nestjs/index.ts → dist/nestjs/index.d.ts} +1 -0
- package/dist/nestjs/index.d.ts.map +1 -0
- package/dist/nestjs/index.js +6 -0
- package/dist/nestjs/index.js.map +1 -0
- package/dist/testing/command-bus.stub.d.ts +14 -0
- package/dist/testing/command-bus.stub.d.ts.map +1 -0
- package/dist/testing/command-bus.stub.js +32 -0
- package/dist/testing/command-bus.stub.js.map +1 -0
- package/dist/testing/event-bus.stub.d.ts +19 -0
- package/dist/testing/event-bus.stub.d.ts.map +1 -0
- package/dist/testing/event-bus.stub.js +48 -0
- package/dist/testing/event-bus.stub.js.map +1 -0
- package/dist/testing/event-publisher.stub.d.ts +7 -0
- package/dist/testing/event-publisher.stub.d.ts.map +1 -0
- package/dist/testing/event-publisher.stub.js +22 -0
- package/dist/testing/event-publisher.stub.js.map +1 -0
- package/dist/testing/fake-logger.d.ts +8 -0
- package/dist/testing/fake-logger.d.ts.map +1 -0
- package/dist/testing/fake-logger.js +21 -0
- package/dist/testing/fake-logger.js.map +1 -0
- package/{src/testing/index.ts → dist/testing/index.d.ts} +1 -0
- package/dist/testing/index.d.ts.map +1 -0
- package/dist/testing/index.js +6 -0
- package/dist/testing/index.js.map +1 -0
- package/dist/testing/query-bus.stub.d.ts +10 -0
- package/dist/testing/query-bus.stub.d.ts.map +1 -0
- package/dist/testing/query-bus.stub.js +25 -0
- package/dist/testing/query-bus.stub.js.map +1 -0
- package/dist/testing/stub.d.ts +40 -0
- package/dist/testing/stub.d.ts.map +1 -0
- package/dist/testing/stub.js +77 -0
- package/dist/testing/stub.js.map +1 -0
- package/dist/testing/stubs/command-bus.stub.d.ts +14 -0
- package/dist/testing/stubs/command-bus.stub.d.ts.map +1 -0
- package/dist/testing/stubs/command-bus.stub.js +32 -0
- package/dist/testing/stubs/command-bus.stub.js.map +1 -0
- package/dist/testing/stubs/event-bus.stub.d.ts +19 -0
- package/dist/testing/stubs/event-bus.stub.d.ts.map +1 -0
- package/dist/testing/stubs/event-bus.stub.js +48 -0
- package/dist/testing/stubs/event-bus.stub.js.map +1 -0
- package/dist/testing/stubs/event-publisher.stub.d.ts +7 -0
- package/dist/testing/stubs/event-publisher.stub.d.ts.map +1 -0
- package/dist/testing/stubs/event-publisher.stub.js +22 -0
- package/dist/testing/stubs/event-publisher.stub.js.map +1 -0
- package/{src/testing/stubs/index.ts → dist/testing/stubs/index.d.ts} +1 -0
- package/dist/testing/stubs/index.d.ts.map +1 -0
- package/dist/testing/stubs/index.js +9 -0
- package/dist/testing/stubs/index.js.map +1 -0
- package/dist/testing/stubs/query-bus.stub.d.ts +10 -0
- package/dist/testing/stubs/query-bus.stub.d.ts.map +1 -0
- package/dist/testing/stubs/query-bus.stub.js +25 -0
- package/dist/testing/stubs/query-bus.stub.js.map +1 -0
- package/dist/testing/stubs/stub.d.ts +40 -0
- package/dist/testing/stubs/stub.d.ts.map +1 -0
- package/dist/testing/stubs/stub.js +77 -0
- package/dist/testing/stubs/stub.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/utils/array.d.ts +15 -0
- package/dist/utils/array.d.ts.map +1 -0
- package/dist/utils/array.js +13 -0
- package/dist/utils/array.js.map +1 -0
- package/dist/utils/base64.d.ts +3 -0
- package/dist/utils/base64.d.ts.map +1 -0
- package/dist/utils/base64.js +10 -0
- package/dist/utils/base64.js.map +1 -0
- package/dist/utils/collection.d.ts +4 -0
- package/dist/utils/collection.d.ts.map +1 -0
- package/dist/utils/collection.js +10 -0
- package/dist/utils/collection.js.map +1 -0
- package/dist/utils/common.d.ts +9 -0
- package/dist/utils/common.d.ts.map +1 -0
- package/dist/utils/common.js +3 -0
- package/dist/utils/common.js.map +1 -0
- package/dist/utils/csv.d.ts +11 -0
- package/dist/utils/csv.d.ts.map +1 -0
- package/dist/utils/csv.js +45 -0
- package/dist/utils/csv.js.map +1 -0
- package/dist/utils/date/date-range.d.ts +5 -0
- package/dist/utils/date/date-range.d.ts.map +1 -0
- package/dist/utils/date/date-range.js +3 -0
- package/dist/utils/date/date-range.js.map +1 -0
- package/dist/utils/date/date.d.ts +39 -0
- package/dist/utils/date/date.d.ts.map +1 -0
- package/dist/utils/date/date.js +143 -0
- package/dist/utils/date/date.js.map +1 -0
- package/{src/utils/date/index.ts → dist/utils/date/index.d.ts} +1 -0
- package/dist/utils/date/index.d.ts.map +1 -0
- package/dist/utils/date/index.js +6 -0
- package/dist/utils/date/index.js.map +1 -0
- package/dist/utils/file.d.ts +2 -0
- package/dist/utils/file.d.ts.map +1 -0
- package/dist/utils/file.js +10 -0
- package/dist/utils/file.js.map +1 -0
- package/dist/utils/hash-key.d.ts +2 -0
- package/dist/utils/hash-key.d.ts.map +1 -0
- package/dist/utils/hash-key.js +25 -0
- package/dist/utils/hash-key.js.map +1 -0
- package/{src/utils/index.ts → dist/utils/index.d.ts} +1 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +19 -0
- package/dist/utils/index.js.map +1 -0
- package/{src/utils/invariant.ts → dist/utils/invariant.d.ts} +1 -1
- package/dist/utils/invariant.d.ts.map +1 -0
- package/dist/utils/invariant.js +7 -0
- package/dist/utils/invariant.js.map +1 -0
- package/dist/utils/iso-date.d.ts +4 -0
- package/dist/utils/iso-date.d.ts.map +1 -0
- package/dist/utils/iso-date.js +13 -0
- package/dist/utils/iso-date.js.map +1 -0
- package/dist/utils/object.d.ts +4 -0
- package/dist/utils/object.d.ts.map +1 -0
- package/dist/utils/object.js +12 -0
- package/dist/utils/object.js.map +1 -0
- package/dist/utils/paginated.d.ts +31 -0
- package/dist/utils/paginated.d.ts.map +1 -0
- package/dist/utils/paginated.js +9 -0
- package/dist/utils/paginated.js.map +1 -0
- package/dist/utils/string.d.ts +12 -0
- package/dist/utils/string.d.ts.map +1 -0
- package/dist/utils/string.js +15 -0
- package/dist/utils/string.js.map +1 -0
- package/{src/utils/type.ts → dist/utils/type.d.ts} +3 -4
- package/dist/utils/type.d.ts.map +1 -0
- package/dist/utils/type.js +3 -0
- package/dist/utils/type.js.map +1 -0
- package/dist/utils/xml.d.ts +2 -0
- package/dist/utils/xml.d.ts.map +1 -0
- package/dist/utils/xml.js +10 -0
- package/dist/utils/xml.js.map +1 -0
- package/dist/validation/ensure-array.decorator.d.ts +2 -0
- package/dist/validation/ensure-array.decorator.d.ts.map +1 -0
- package/dist/validation/ensure-array.decorator.js +8 -0
- package/dist/validation/ensure-array.decorator.js.map +1 -0
- package/{src/validation/index.ts → dist/validation/index.d.ts} +1 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +11 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/is-iso-date.decorator.d.ts +3 -0
- package/dist/validation/is-iso-date.decorator.d.ts.map +1 -0
- package/dist/validation/is-iso-date.decorator.js +28 -0
- package/dist/validation/is-iso-date.decorator.js.map +1 -0
- package/dist/validation/is-less-than-or-equal.decorator.d.ts +3 -0
- package/dist/validation/is-less-than-or-equal.decorator.d.ts.map +1 -0
- package/dist/validation/is-less-than-or-equal.decorator.js +44 -0
- package/dist/validation/is-less-than-or-equal.decorator.js.map +1 -0
- package/dist/validation/is-less-than.decorator.d.ts +3 -0
- package/dist/validation/is-less-than.decorator.d.ts.map +1 -0
- package/dist/validation/is-less-than.decorator.js +44 -0
- package/dist/validation/is-less-than.decorator.js.map +1 -0
- package/dist/validation/is-more-than-or-equal.decorator.d.ts +3 -0
- package/dist/validation/is-more-than-or-equal.decorator.d.ts.map +1 -0
- package/dist/validation/is-more-than-or-equal.decorator.js +44 -0
- package/dist/validation/is-more-than-or-equal.decorator.js.map +1 -0
- package/dist/validation/is-more-than.decorator.d.ts +3 -0
- package/dist/validation/is-more-than.decorator.d.ts.map +1 -0
- package/dist/validation/is-more-than.decorator.js +44 -0
- package/dist/validation/is-more-than.decorator.js.map +1 -0
- package/dist/validation/is-time-string.decorator.d.ts +3 -0
- package/dist/validation/is-time-string.decorator.d.ts.map +1 -0
- package/dist/validation/is-time-string.decorator.js +27 -0
- package/dist/validation/is-time-string.decorator.js.map +1 -0
- package/package.json +109 -46
- package/.pnp.cjs +0 -22192
- package/.pnp.loader.mjs +0 -2126
- package/.yarnrc.yml +0 -1
- package/CHANGELOG.md +0 -527
- package/eslint.config.mjs +0 -52
- package/invariant.json +0 -22
- package/jest/jest.config.base.ts +0 -30
- package/jest/jest.spec.base.ts +0 -7
- package/jest.config.js +0 -49
- package/src/core/application/index.ts +0 -1
- package/src/core/application/persistence/query-builder.ts +0 -2
- package/src/core/application/persistence/read-projection.ts +0 -2
- package/src/core/application/persistence/repository.ts +0 -23
- package/src/core/domain/entities/aggregate-root.ts +0 -34
- package/src/core/domain/entities/entity.spec.ts +0 -43
- package/src/core/domain/entities/entity.ts +0 -29
- package/src/core/domain/entities/identifier.spec.ts +0 -34
- package/src/core/domain/entities/identifier.ts +0 -16
- package/src/core/domain/entities/unique-entity-id.ts +0 -9
- package/src/core/domain/events/domain-event.ts +0 -7
- package/src/core/domain/events/index.ts +0 -1
- package/src/core/domain/value-objects/range.ts +0 -4
- package/src/core/domain/value-objects/value-object.spec.ts +0 -45
- package/src/core/domain/value-objects/value-object.ts +0 -17
- package/src/core/errors/command-failure.error.spec.ts +0 -30
- package/src/core/errors/command-failure.error.ts +0 -9
- package/src/core/errors/command-filter.error.ts +0 -3
- package/src/core/errors/detailed.error.ts +0 -25
- package/src/core/errors/domain.error.spec.ts +0 -27
- package/src/core/errors/domain.error.ts +0 -9
- package/src/core/errors/entity-not-found.error.spec.ts +0 -32
- package/src/core/errors/entity-not-found.error.ts +0 -9
- package/src/core/errors/fake-implementation.error.spec.ts +0 -27
- package/src/core/errors/fake-implementation.error.ts +0 -15
- package/src/core/errors/query-failure.error.ts +0 -8
- package/src/core/errors/too-many-results.error.ts +0 -3
- package/src/core/infrastructure/config/config.provider.ts +0 -78
- package/src/core/infrastructure/config/config.service.ts +0 -25
- package/src/core/infrastructure/messaging/fake/fake-messaging.service.ts +0 -17
- package/src/core/infrastructure/messaging/fake/fake-queue-manager.service.ts +0 -9
- package/src/core/infrastructure/messaging/fake/fake-queue-messaging.service.ts +0 -9
- package/src/core/infrastructure/messaging/messaging.service.ts +0 -3
- package/src/core/infrastructure/messaging/queue-manager.service.ts +0 -6
- package/src/core/infrastructure/messaging/queue-messaging.service.ts +0 -3
- package/src/core/infrastructure/messaging/rabbitmq/rabbit-messaging.service.ts +0 -11
- package/src/core/infrastructure/messaging/rabbitmq/rabbit-queue-messaging.service.ts +0 -11
- package/src/core/infrastructure/messaging/types.ts +0 -28
- package/src/core/infrastructure/persistence/errors/model-to-entity-conversion.error.ts +0 -9
- package/src/core/infrastructure/persistence/errors/persistence.error.ts +0 -8
- package/src/core/infrastructure/persistence/in-memory/fake.repository.ts +0 -79
- package/src/core/infrastructure/persistence/in-memory/in-memory.query-builder.ts +0 -4
- package/src/core/infrastructure/persistence/in-memory/in-memory.repository.spec.ts +0 -50
- package/src/core/infrastructure/persistence/in-memory/in-memory.repository.ts +0 -81
- package/src/core/infrastructure/persistence/read-side/in-memory.query-builder.ts +0 -4
- package/src/core/infrastructure/persistence/read-side/index.ts +0 -1
- package/src/core/infrastructure/persistence/read-side/knex/knex-types.definition.ts +0 -13
- package/src/core/infrastructure/persistence/read-side/knex/knex.query-builder.ts +0 -70
- package/src/core/infrastructure/persistence/read-side/knex-query-builder.ts +0 -70
- package/src/core/infrastructure/persistence/read-side/knex-types.definition.ts +0 -13
- package/src/core/infrastructure/persistence/write-side/aggregate-typeorm-repository.ts +0 -87
- package/src/core/infrastructure/persistence/write-side/entity-typeorm-repository.ts +0 -64
- package/src/core/infrastructure/persistence/write-side/in-memory.repository.ts +0 -82
- package/src/core/infrastructure/persistence/write-side/index.ts +0 -1
- package/src/core/infrastructure/persistence/write-side/model-attributes.ts +0 -4
- package/src/core/infrastructure/persistence/write-side/orm-embedded-mapper.ts +0 -11
- package/src/core/infrastructure/persistence/write-side/orm-mapper.ts +0 -11
- package/src/core/infrastructure/persistence/write-side/typeorm/aggregate-typeorm.repository.ts +0 -87
- package/src/core/infrastructure/persistence/write-side/typeorm/entity-typeorm.repository.ts +0 -64
- package/src/core/infrastructure/persistence/write-side/typeorm/model-attributes.ts +0 -4
- package/src/core/infrastructure/persistence/write-side/typeorm/orm-embedded.mapper.ts +0 -11
- package/src/core/infrastructure/persistence/write-side/typeorm/orm.mapper.ts +0 -11
- package/src/core/types/architecture-layer.ts +0 -52
- package/src/modules/config/config.module.ts +0 -9
- package/src/modules/graphql/paginated-response.object-type.ts +0 -23
- package/src/modules/healthcheck/healthcheck-out.dto.ts +0 -43
- package/src/modules/knex/knex-core.module.ts +0 -30
- package/src/modules/knex/knex.decorator.ts +0 -5
- package/src/modules/knex/knex.interface.ts +0 -12
- package/src/modules/knex/knex.module.ts +0 -14
- package/src/modules/knex/knex.token.ts +0 -2
- package/src/modules/logger/app-logger.ts +0 -28
- package/src/modules/logger/log.ts +0 -26
- package/src/modules/logger/logger.module.ts +0 -47
- package/src/modules/logger/logger.service.ts +0 -131
- package/src/modules/logger/transports/console-color.transport.ts +0 -41
- package/src/modules/logger/transports/console-json.transport.ts +0 -23
- package/src/modules/logger/transports/console.transport.ts +0 -10
- package/src/modules/logger/transports/fake.transport.ts +0 -18
- package/src/modules/logger/transports/logger-transport.ts +0 -22
- package/src/modules/messaging/messaging.module.ts +0 -92
- package/src/modules/queue/default-queue-name.resolver.ts +0 -5
- package/src/modules/queue/queue.module.ts +0 -73
- package/src/modules/queue/rabbit-queue-manager.service.ts +0 -67
- package/src/nestjs/errors/handlers/error-handler.ts +0 -38
- package/src/nestjs/errors/handlers/generic-error-handler.ts +0 -59
- package/src/nestjs/errors/handlers/handle-errors.decorator.ts +0 -43
- package/src/nestjs/errors/handlers/validation-error-handler.ts +0 -46
- package/src/nestjs/errors/parsers/axios-metadata.parser.ts +0 -21
- package/src/nestjs/errors/parsers/error-metadata.definition.ts +0 -1
- package/src/nestjs/errors/parsers/knex-metadata.parser.ts +0 -18
- package/src/nestjs/errors/parsers/typeorm-metadata.parser.ts +0 -19
- package/src/nestjs/errors/parsers/workos-metadata.parser.ts +0 -17
- package/src/nestjs/http/decorators/log-app-ctx.decorator.ts +0 -32
- package/src/nestjs/http/dtos/date-range.dto.ts +0 -15
- package/src/nestjs/http/dtos/index.ts +0 -1
- package/src/nestjs/http/filters/all-exceptions.filter.ts +0 -92
- package/src/nestjs/http/filters/command-failure.filter.ts +0 -12
- package/src/nestjs/http/filters/rpc-exceptions.filter.ts +0 -10
- package/src/nestjs/http/filters/too-many-results.filter.ts +0 -12
- package/src/nestjs/http/interceptors/log-app-ctx.interceptor.ts +0 -109
- package/src/nestjs/http/interceptors/serialize-output.interceptor.ts +0 -19
- package/src/nestjs/http/middleware/http-logger.middleware.ts +0 -31
- package/src/nestjs/http/middleware/logger.middleware.ts +0 -21
- package/src/nestjs/http/swagger/index.ts +0 -1
- package/src/nestjs/http/swagger/swagger.ts +0 -44
- package/src/testing/command-bus.stub.ts +0 -33
- package/src/testing/event-bus.stub.ts +0 -56
- package/src/testing/event-publisher.stub.ts +0 -24
- package/src/testing/fake-logger.ts +0 -20
- package/src/testing/query-bus.stub.ts +0 -27
- package/src/testing/stub.spec.ts +0 -250
- package/src/testing/stub.ts +0 -170
- package/src/testing/stubs/command-bus.stub.ts +0 -33
- package/src/testing/stubs/event-bus.stub.ts +0 -56
- package/src/testing/stubs/event-publisher.stub.ts +0 -24
- package/src/testing/stubs/query-bus.stub.ts +0 -27
- package/src/testing/stubs/stub.ts +0 -170
- package/src/utils/array.spec.ts +0 -29
- package/src/utils/array.ts +0 -10
- package/src/utils/base64.spec.ts +0 -18
- package/src/utils/base64.ts +0 -6
- package/src/utils/collection.ts +0 -4
- package/src/utils/common.ts +0 -13
- package/src/utils/csv.ts +0 -49
- package/src/utils/date/date-range.ts +0 -4
- package/src/utils/date/date.spec.ts +0 -100
- package/src/utils/date/date.ts +0 -177
- package/src/utils/date/diff.spec.ts +0 -66
- package/src/utils/date/diffYear.spec.ts +0 -23
- package/src/utils/date/fillMissingRangeValues.spec.ts +0 -523
- package/src/utils/date/groubBy.spec.ts +0 -183
- package/src/utils/date/isSame.spec.ts +0 -111
- package/src/utils/file.spec.ts +0 -66
- package/src/utils/file.ts +0 -5
- package/src/utils/hash-key.ts +0 -23
- package/src/utils/iso-date.ts +0 -11
- package/src/utils/object.spec.ts +0 -18
- package/src/utils/object.ts +0 -6
- package/src/utils/paginated.ts +0 -36
- package/src/utils/string.spec.ts +0 -10
- package/src/utils/string.ts +0 -19
- package/src/utils/xml.ts +0 -6
- package/src/validation/ensure-array.decorator.ts +0 -5
- package/src/validation/is-iso-date.decorator.spec.ts +0 -29
- package/src/validation/is-iso-date.decorator.ts +0 -30
- package/src/validation/is-less-than-or-equal.decorator.spec.ts +0 -30
- package/src/validation/is-less-than-or-equal.decorator.ts +0 -52
- package/src/validation/is-less-than.decorator.spec.ts +0 -36
- package/src/validation/is-less-than.decorator.ts +0 -52
- package/src/validation/is-more-than-or-equal.decorator.spec.ts +0 -30
- package/src/validation/is-more-than-or-equal.decorator.ts +0 -52
- package/src/validation/is-more-than.decorator.spec.ts +0 -36
- package/src/validation/is-more-than.decorator.ts +0 -52
- package/src/validation/is-time-string.decorator.spec.ts +0 -35
- package/src/validation/is-time-string.decorator.ts +0 -29
- package/tsconfig.build.json +0 -6
- package/tsconfig.json +0 -34
- package/tsconfig.spec.json +0 -14
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-unsafe-return, @typescript-eslint/no-unsafe-call, @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access */
|
|
2
|
-
import * as cls from "cls-hooked";
|
|
3
|
-
import { merge } from "lodash";
|
|
4
|
-
|
|
5
|
-
import { ArchitectureLayer, ArchitectureLevel } from "../../core/types";
|
|
6
|
-
import { LoggerTransport } from "./transports/logger-transport";
|
|
7
|
-
import { CtxLog, DataLog, LogLevel } from "./log";
|
|
8
|
-
|
|
9
|
-
const NSID = "fb8b817a-4824-4abc-a1b1-e7cbb7f420eb";
|
|
10
|
-
|
|
11
|
-
export const SECRET_KEYS = [
|
|
12
|
-
"pass", "password", "token", "pendingToken",
|
|
13
|
-
"authToken", "accessToken", "refreshToken", "secret",
|
|
14
|
-
] as const;
|
|
15
|
-
|
|
16
|
-
const IGNORED_MESSAGES = ["Successfully connected to RMQ broker"] as const;
|
|
17
|
-
|
|
18
|
-
export class LoggerService {
|
|
19
|
-
private readonly transports: LoggerTransport[];
|
|
20
|
-
private readonly service: string;
|
|
21
|
-
|
|
22
|
-
constructor({ transports, service }: { transports: LoggerTransport[]; service: string }) {
|
|
23
|
-
this.transports = transports;
|
|
24
|
-
this.service = service;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
log(level: LogLevel, arg1: string | DataLog, arg2?: string | DataLog) {
|
|
28
|
-
const message = typeof arg1 === "string" ? arg1 : "";
|
|
29
|
-
if (IGNORED_MESSAGES.includes(message as any)) {return;}
|
|
30
|
-
|
|
31
|
-
const obj = typeof arg1 === "string" ? arg2 : arg1;
|
|
32
|
-
const { data, stack } = this.extractLogData(obj, message);
|
|
33
|
-
const ctx = this.getCtx();
|
|
34
|
-
|
|
35
|
-
for (const transport of this.transports) {
|
|
36
|
-
transport.add({
|
|
37
|
-
level,
|
|
38
|
-
message,
|
|
39
|
-
service: this.service,
|
|
40
|
-
stack,
|
|
41
|
-
data: { ...data, ...ctx },
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
error(arg1: string | DataLog, arg2?: string | DataLog) { this.log("error", arg1, arg2); }
|
|
47
|
-
warn(arg1: string | DataLog, arg2?: string | DataLog) { this.log("warn", arg1, arg2); }
|
|
48
|
-
info(arg1: string | DataLog, arg2?: string | DataLog) { this.log("info", arg1, arg2); }
|
|
49
|
-
http(arg1: string | DataLog, arg2?: string | DataLog) { this.log("http", arg1, arg2); }
|
|
50
|
-
verbose(arg1: string | DataLog, arg2?: string | DataLog) { this.log("verbose", arg1, arg2); }
|
|
51
|
-
debug(arg1: string | DataLog, arg2?: string | DataLog) { this.log("debug", arg1, arg2); }
|
|
52
|
-
silly(arg1: string | DataLog, arg2?: string | DataLog) { this.log("silly", arg1, arg2); }
|
|
53
|
-
|
|
54
|
-
init(req: any, res: any, next: any) {
|
|
55
|
-
const ns = cls.getNamespace(NSID) ?? cls.createNamespace(NSID);
|
|
56
|
-
ns.bind(req);
|
|
57
|
-
ns.bind(res);
|
|
58
|
-
ns.run(() => next());
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
clearCtx() {
|
|
62
|
-
const ns = cls.getNamespace(NSID);
|
|
63
|
-
if (ns?.active) {ns.set("ctx", {});}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
ctx(layer: ArchitectureLayer, log?: CtxLog) {
|
|
67
|
-
const ns = cls.getNamespace(NSID);
|
|
68
|
-
const levelKeys = Object.keys(layer) as ArchitectureLevel[];
|
|
69
|
-
|
|
70
|
-
if (levelKeys.length <= 0) {
|
|
71
|
-
this.warn("[Logger] Error: layer has no architecture level, cannot set any logger context");
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
try {
|
|
76
|
-
const anyLayer = layer as any;
|
|
77
|
-
const level = levelKeys[0] as string;
|
|
78
|
-
const trace = Object.keys(anyLayer[level])[0];
|
|
79
|
-
anyLayer[level][trace].meta = { ...anyLayer[level][trace].meta, ...log };
|
|
80
|
-
} catch {
|
|
81
|
-
this.warn("[Logger] Error: unable to define logger context, logging will be uncoherent", { error: "ctx parse failed" });
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
if (ns?.active) {
|
|
85
|
-
return ns.set("ctx", { ...merge(this.getCtx(), layer) });
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
private getCtx(): CtxLog {
|
|
90
|
-
return cls.getNamespace(NSID)?.active ? cls.getNamespace(NSID)!.get("ctx") : {};
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
private extractLogData(obj: string | DataLog | undefined, message: string) {
|
|
94
|
-
let stack: string | undefined;
|
|
95
|
-
const data: DataLog = {};
|
|
96
|
-
|
|
97
|
-
if (Array.isArray(obj)) {
|
|
98
|
-
data["list"] = this.stringifyValue(obj);
|
|
99
|
-
} else if (obj instanceof Error) {
|
|
100
|
-
stack = obj.stack;
|
|
101
|
-
if (!message) {data["text"] = obj.message;}
|
|
102
|
-
} else if (typeof obj === "object" && obj !== null) {
|
|
103
|
-
for (const [key, value] of Object.entries(obj)) {
|
|
104
|
-
if (key === "metrics") {data.metrics = { ...obj.metrics };}
|
|
105
|
-
else if (key === "stack" && typeof value === "string") {stack = this.stringifyValue(value);}
|
|
106
|
-
else {data[key] = this.sanitizeLog(key, value);}
|
|
107
|
-
}
|
|
108
|
-
} else if (typeof obj === "string") {
|
|
109
|
-
data["text"] = obj;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
return { data, stack };
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
private stringifyValue(value: any): string {
|
|
116
|
-
try {
|
|
117
|
-
const content = value === undefined ? "" : typeof value === "string" ? value : JSON.stringify(value);
|
|
118
|
-
const secretPattern = new RegExp(`"(${SECRET_KEYS.join("|")})":"([^"]*)"`, "gm");
|
|
119
|
-
return content
|
|
120
|
-
.replace(/Bearer [^ "'\\]*/gm, "Bearer ***")
|
|
121
|
-
.replace(secretPattern, '"$1": "***"')
|
|
122
|
-
.replace(/(\.eyJ[^\s"]+\.[^\s"]+\.[^\s"]+)/, (_: string, match: string) => match.substring(0, 5) + "***");
|
|
123
|
-
} catch {
|
|
124
|
-
return "JSON.stringify did not work";
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
private sanitizeLog(key: string, value: any) {
|
|
129
|
-
return SECRET_KEYS.includes(key as any) ? "***" : this.stringifyValue(value);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { Log } from "../log";
|
|
2
|
-
import { LoggerTransport } from "./logger-transport";
|
|
3
|
-
|
|
4
|
-
const COLORS = {
|
|
5
|
-
Reset: "\x1b[0m",
|
|
6
|
-
Bright: "\x1b[1m",
|
|
7
|
-
Dim: "\x1b[2m",
|
|
8
|
-
FgRed: "\x1b[31m",
|
|
9
|
-
FgGreen: "\x1b[32m",
|
|
10
|
-
FgYellow: "\x1b[33m",
|
|
11
|
-
FgBlue: "\x1b[34m",
|
|
12
|
-
FgCyan: "\x1b[36m",
|
|
13
|
-
FgWhite: "\x1b[37m",
|
|
14
|
-
} as const;
|
|
15
|
-
|
|
16
|
-
const LEVEL_COLOR: Record<string, string> = {
|
|
17
|
-
warn: COLORS.FgYellow,
|
|
18
|
-
info: COLORS.FgCyan,
|
|
19
|
-
error: COLORS.FgRed,
|
|
20
|
-
http: COLORS.FgGreen,
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
export class ConsoleColorTransport extends LoggerTransport {
|
|
24
|
-
send(log: Log): void {
|
|
25
|
-
const level = this.bracket(log.level.toUpperCase(), LEVEL_COLOR[log.level] ?? COLORS.FgBlue);
|
|
26
|
-
const date = `${COLORS.Dim}${new Date().toISOString().substring(11, 19)}${COLORS.Reset}`;
|
|
27
|
-
const message = `${COLORS.Bright}${log.message}`;
|
|
28
|
-
const data = log.data && Object.keys(log.data).length > 0
|
|
29
|
-
? `\n${COLORS.Dim}${JSON.stringify(log.data, null, 2)}${COLORS.Reset}`
|
|
30
|
-
: "";
|
|
31
|
-
const stack = log.stack
|
|
32
|
-
? `\n-----\n${COLORS.Reset}${COLORS.Dim}${log.stack}${COLORS.Reset}\n-----\n`
|
|
33
|
-
: "";
|
|
34
|
-
// eslint-disable-next-line no-console
|
|
35
|
-
console.log(`${level} ${date} ${message}${data}${stack}`);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
private bracket(message: string, color: string) {
|
|
39
|
-
return `${COLORS.FgWhite}[${color}${message}${COLORS.FgWhite}]${COLORS.Reset}`;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { Log } from "../log";
|
|
2
|
-
import { LoggerTransport } from "./logger-transport";
|
|
3
|
-
|
|
4
|
-
export class ConsoleJSONTransport extends LoggerTransport {
|
|
5
|
-
format(log: Log): string {
|
|
6
|
-
const { data = {}, message, service, stack, level } = log;
|
|
7
|
-
const { metrics, ...otherData } = data;
|
|
8
|
-
return JSON.stringify({
|
|
9
|
-
timestamp: new Date().toISOString(),
|
|
10
|
-
level,
|
|
11
|
-
service,
|
|
12
|
-
message,
|
|
13
|
-
data: otherData,
|
|
14
|
-
metrics,
|
|
15
|
-
stack,
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
send(log: Log): void {
|
|
20
|
-
// eslint-disable-next-line no-console
|
|
21
|
-
console.log(this.format(log));
|
|
22
|
-
}
|
|
23
|
-
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
/* eslint-disable no-console */
|
|
2
|
-
import { Log } from "../log";
|
|
3
|
-
import { LoggerTransport } from "./logger-transport";
|
|
4
|
-
|
|
5
|
-
export class ConsoleTransport extends LoggerTransport {
|
|
6
|
-
send(log: Log): void {
|
|
7
|
-
console.log(`[${log.level}] ${log.message}`);
|
|
8
|
-
console.log(JSON.stringify(log.data, null, 2));
|
|
9
|
-
}
|
|
10
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { Log } from "../log";
|
|
2
|
-
import { LoggerTransport } from "./logger-transport";
|
|
3
|
-
|
|
4
|
-
export class FakeTransport extends LoggerTransport {
|
|
5
|
-
public logs: Log[] = [];
|
|
6
|
-
|
|
7
|
-
send(log: Log) {
|
|
8
|
-
this.logs.push(log);
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
clear(): void {
|
|
12
|
-
this.logs = [];
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
getLastLog(): Log | undefined {
|
|
16
|
-
return this.logs.at(-1);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { Log, LogLevel, LOG_LEVEL_PRIORITY } from "../log";
|
|
2
|
-
|
|
3
|
-
export type LoggerTransportOptions = {
|
|
4
|
-
level: LogLevel;
|
|
5
|
-
};
|
|
6
|
-
|
|
7
|
-
export abstract class LoggerTransport {
|
|
8
|
-
readonly levelPriority: number;
|
|
9
|
-
|
|
10
|
-
constructor(public readonly options: LoggerTransportOptions = { level: "silly" }) {
|
|
11
|
-
this.levelPriority = LOG_LEVEL_PRIORITY[options.level];
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
add(log: Log): void {
|
|
15
|
-
if (this.levelPriority < LOG_LEVEL_PRIORITY[log.level]) {
|
|
16
|
-
return;
|
|
17
|
-
}
|
|
18
|
-
this.send(log);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
abstract send(log: Log): void;
|
|
22
|
-
}
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import { DynamicModule, Module } from "@nestjs/common";
|
|
2
|
-
import { ClientProxy, ClientProxyFactory, Transport } from "@nestjs/microservices";
|
|
3
|
-
|
|
4
|
-
import { MessagingService, FakeMessagingService, RabbitMessagingService } from "../../core/infrastructure/messaging";
|
|
5
|
-
import { ConfigModule, ConfigService } from "../config";
|
|
6
|
-
import { LoggerModule, LoggerService } from "../logger";
|
|
7
|
-
|
|
8
|
-
const clientProxyCache = new Map<string, ClientProxy>();
|
|
9
|
-
|
|
10
|
-
function buildRmqUrl(config: ConfigService): string {
|
|
11
|
-
const protocol = config.get("RMQ_PROTOCOL");
|
|
12
|
-
const user = config.get("RMQ_USER");
|
|
13
|
-
const password = config.get("RMQ_PASSWORD");
|
|
14
|
-
const host = config.get("RMQ_HOST");
|
|
15
|
-
const port = config.get("RMQ_PORT");
|
|
16
|
-
return `${protocol}://${user}:${password}@${host}:${port}`;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
async function closeAllCachedProxies(logger?: { info: (msg: string) => void; error: (msg: string, data?: object) => void }) {
|
|
20
|
-
for (const [queue, proxy] of clientProxyCache) {
|
|
21
|
-
try {
|
|
22
|
-
await proxy.close();
|
|
23
|
-
logger?.info(`Closed cached client proxy for queue: ${queue}`);
|
|
24
|
-
} catch (error) {
|
|
25
|
-
logger?.error(`Error closing cached client proxy for queue ${queue}:`, { error });
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
clientProxyCache.clear();
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
@Module({})
|
|
32
|
-
export class MessagingModule {
|
|
33
|
-
static register(queueName: string): DynamicModule {
|
|
34
|
-
return {
|
|
35
|
-
module: MessagingModule,
|
|
36
|
-
imports: [ConfigModule, LoggerModule],
|
|
37
|
-
providers: [
|
|
38
|
-
{
|
|
39
|
-
provide: MessagingService,
|
|
40
|
-
useFactory: (configService: ConfigService, optionalProvider: ClientProxy) => {
|
|
41
|
-
return configService.isTest() ? new FakeMessagingService() : new RabbitMessagingService(optionalProvider);
|
|
42
|
-
},
|
|
43
|
-
inject: [ConfigService, { token: queueName, optional: false }],
|
|
44
|
-
},
|
|
45
|
-
{
|
|
46
|
-
provide: queueName,
|
|
47
|
-
useFactory: async (configService: ConfigService) => {
|
|
48
|
-
if (configService.isTest()) {return {};}
|
|
49
|
-
|
|
50
|
-
const cached = clientProxyCache.get(queueName);
|
|
51
|
-
if (cached) {return cached;}
|
|
52
|
-
|
|
53
|
-
const clientProxy = ClientProxyFactory.create({
|
|
54
|
-
transport: Transport.RMQ,
|
|
55
|
-
options: {
|
|
56
|
-
urls: [buildRmqUrl(configService)],
|
|
57
|
-
queue: queueName,
|
|
58
|
-
queueOptions: {
|
|
59
|
-
durable: configService.getBoolean("RMQ_IS_DURABLE"),
|
|
60
|
-
exclusive: false,
|
|
61
|
-
autoDelete: false,
|
|
62
|
-
},
|
|
63
|
-
prefetchCount: 1,
|
|
64
|
-
socketOptions: {
|
|
65
|
-
heartbeatIntervalInSeconds: 30,
|
|
66
|
-
reconnectTimeInSeconds: 5,
|
|
67
|
-
},
|
|
68
|
-
},
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
await clientProxy.connect();
|
|
72
|
-
clientProxyCache.set(queueName, clientProxy);
|
|
73
|
-
return clientProxy;
|
|
74
|
-
},
|
|
75
|
-
inject: [ConfigService],
|
|
76
|
-
},
|
|
77
|
-
{
|
|
78
|
-
provide: "MESSAGING_MODULE_CLEANUP",
|
|
79
|
-
useFactory: (logger: LoggerService) => ({
|
|
80
|
-
async onModuleDestroy() { await closeAllCachedProxies(logger); },
|
|
81
|
-
}),
|
|
82
|
-
inject: [LoggerService],
|
|
83
|
-
},
|
|
84
|
-
],
|
|
85
|
-
exports: [MessagingService],
|
|
86
|
-
};
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
export async function cleanupMessagingConnections() {
|
|
91
|
-
await closeAllCachedProxies();
|
|
92
|
-
}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import { ConfigService } from "../../core/infrastructure/config";
|
|
2
|
-
import { QueueName, QueueNameResolver } from "../../core/infrastructure/messaging/types";
|
|
3
|
-
|
|
4
|
-
export const defaultQueueNameResolverFactory = (configService: ConfigService): QueueNameResolver =>
|
|
5
|
-
(queueName: QueueName) => configService.get(`${queueName}_QUEUE_RMQ`) ?? "default";
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
import { DynamicModule, Global, Module } from "@nestjs/common";
|
|
2
|
-
|
|
3
|
-
import {
|
|
4
|
-
QueueManagerService,
|
|
5
|
-
FakeQueueManagerService,
|
|
6
|
-
CLIENT_PROXY_OPTIONS,
|
|
7
|
-
ClientProxyOptions,
|
|
8
|
-
QUEUE_CORE_OPTIONS_TOKEN,
|
|
9
|
-
QUEUE_NAME_RESOLVER,
|
|
10
|
-
QueueModuleAsyncOptions,
|
|
11
|
-
QueueModuleOptions,
|
|
12
|
-
QueueNameResolver,
|
|
13
|
-
} from "../../core/infrastructure/messaging";
|
|
14
|
-
import { ConfigModule, ConfigService } from "../config";
|
|
15
|
-
import { LoggerModule, LoggerService } from "../logger";
|
|
16
|
-
import { defaultQueueNameResolverFactory } from "./default-queue-name.resolver";
|
|
17
|
-
import { RabbitQueueManagerService } from "./rabbit-queue-manager.service";
|
|
18
|
-
|
|
19
|
-
@Module({})
|
|
20
|
-
@Global()
|
|
21
|
-
export class QueueModule {
|
|
22
|
-
static forRootAsync(options?: QueueModuleAsyncOptions): DynamicModule {
|
|
23
|
-
return {
|
|
24
|
-
module: QueueModule,
|
|
25
|
-
imports: [QueueCoreModule.forRootAsync(options)],
|
|
26
|
-
exports: [QueueCoreModule],
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
@Module({})
|
|
32
|
-
class QueueCoreModule {
|
|
33
|
-
static forRootAsync(options?: QueueModuleAsyncOptions): DynamicModule {
|
|
34
|
-
return {
|
|
35
|
-
module: QueueCoreModule,
|
|
36
|
-
imports: [...(options?.imports ?? []), ConfigModule, LoggerModule],
|
|
37
|
-
providers: [
|
|
38
|
-
{
|
|
39
|
-
provide: QUEUE_NAME_RESOLVER,
|
|
40
|
-
useFactory: (configService: ConfigService, option?: QueueModuleOptions) =>
|
|
41
|
-
option?.queueNameResolver ?? defaultQueueNameResolverFactory(configService),
|
|
42
|
-
inject: [ConfigService, { token: QUEUE_CORE_OPTIONS_TOKEN, optional: true }],
|
|
43
|
-
},
|
|
44
|
-
{
|
|
45
|
-
provide: CLIENT_PROXY_OPTIONS,
|
|
46
|
-
useFactory: (option?: QueueModuleOptions) => option?.clientProxyOptions,
|
|
47
|
-
inject: [QUEUE_CORE_OPTIONS_TOKEN],
|
|
48
|
-
},
|
|
49
|
-
...(options
|
|
50
|
-
? [{
|
|
51
|
-
provide: QUEUE_CORE_OPTIONS_TOKEN,
|
|
52
|
-
useFactory: options.useFactory,
|
|
53
|
-
inject: options.inject ?? [],
|
|
54
|
-
}]
|
|
55
|
-
: []),
|
|
56
|
-
{
|
|
57
|
-
provide: QueueManagerService,
|
|
58
|
-
useFactory: (
|
|
59
|
-
queueNameResolver: QueueNameResolver,
|
|
60
|
-
clientProxyOptions: ClientProxyOptions,
|
|
61
|
-
configService: ConfigService,
|
|
62
|
-
logger: LoggerService,
|
|
63
|
-
) =>
|
|
64
|
-
configService.isTest()
|
|
65
|
-
? new FakeQueueManagerService()
|
|
66
|
-
: new RabbitQueueManagerService(queueNameResolver, clientProxyOptions, logger),
|
|
67
|
-
inject: [QUEUE_NAME_RESOLVER, CLIENT_PROXY_OPTIONS, ConfigService, LoggerService],
|
|
68
|
-
},
|
|
69
|
-
],
|
|
70
|
-
exports: [QueueManagerService],
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
import { Inject, Injectable, OnModuleDestroy } from "@nestjs/common";
|
|
2
|
-
import { ClientProxy, ClientProxyFactory, Transport } from "@nestjs/microservices";
|
|
3
|
-
|
|
4
|
-
import {
|
|
5
|
-
QueueMessagingService,
|
|
6
|
-
QueueManagerService,
|
|
7
|
-
CLIENT_PROXY_OPTIONS,
|
|
8
|
-
ClientProxyOptions,
|
|
9
|
-
QUEUE_NAME_RESOLVER,
|
|
10
|
-
QueueName,
|
|
11
|
-
QueueNameResolver,
|
|
12
|
-
} from "../../core/infrastructure/messaging";
|
|
13
|
-
import { RabbitQueueMessagingService } from "../../core/infrastructure/messaging/rabbitmq/rabbit-queue-messaging.service";
|
|
14
|
-
import { LoggerService } from "../logger";
|
|
15
|
-
|
|
16
|
-
@Injectable()
|
|
17
|
-
export class RabbitQueueManagerService implements QueueManagerService, OnModuleDestroy {
|
|
18
|
-
private readonly queueMessagingServiceMap = new Map<QueueName, QueueMessagingService>();
|
|
19
|
-
private readonly clientProxyMap = new Map<QueueName, ClientProxy>();
|
|
20
|
-
|
|
21
|
-
constructor(
|
|
22
|
-
@Inject(QUEUE_NAME_RESOLVER) private readonly queueNameResolver: QueueNameResolver,
|
|
23
|
-
@Inject(CLIENT_PROXY_OPTIONS) private readonly clientProxyOptions: ClientProxyOptions,
|
|
24
|
-
private readonly logger: LoggerService,
|
|
25
|
-
) {}
|
|
26
|
-
|
|
27
|
-
async onModuleDestroy() {
|
|
28
|
-
for (const [queueName, clientProxy] of this.clientProxyMap) {
|
|
29
|
-
try {
|
|
30
|
-
await clientProxy.close();
|
|
31
|
-
this.logger.info(`Closed client proxy for queue: ${queueName}`);
|
|
32
|
-
} catch (error) {
|
|
33
|
-
this.logger.error(`Error closing client proxy for queue ${queueName}:`, { error });
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
this.clientProxyMap.clear();
|
|
37
|
-
this.queueMessagingServiceMap.clear();
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
getMessagingService(queueName: QueueName): QueueMessagingService {
|
|
41
|
-
const existing = this.queueMessagingServiceMap.get(queueName);
|
|
42
|
-
if (existing) {return existing;}
|
|
43
|
-
|
|
44
|
-
const clientProxy = ClientProxyFactory.create({
|
|
45
|
-
transport: Transport.RMQ,
|
|
46
|
-
options: {
|
|
47
|
-
...this.clientProxyOptions,
|
|
48
|
-
queue: this.queueNameResolver(queueName),
|
|
49
|
-
queueOptions: {
|
|
50
|
-
...this.clientProxyOptions.queueOptions,
|
|
51
|
-
exclusive: false,
|
|
52
|
-
autoDelete: false,
|
|
53
|
-
},
|
|
54
|
-
socketOptions: {
|
|
55
|
-
heartbeatIntervalInSeconds: 30,
|
|
56
|
-
reconnectTimeInSeconds: 5,
|
|
57
|
-
},
|
|
58
|
-
},
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
this.clientProxyMap.set(queueName, clientProxy);
|
|
62
|
-
|
|
63
|
-
const messagingService = new RabbitQueueMessagingService(clientProxy);
|
|
64
|
-
this.queueMessagingServiceMap.set(queueName, messagingService);
|
|
65
|
-
return messagingService;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { HttpException } from "@nestjs/common";
|
|
2
|
-
|
|
3
|
-
import { DetailedError } from "../../../core/errors";
|
|
4
|
-
import { ErrorHandlerEntry, HttpExceptionClass, HttpExceptionReturn } from "./error-handler.type";
|
|
5
|
-
|
|
6
|
-
export class ErrorHandler {
|
|
7
|
-
constructor(private readonly entries: ErrorHandlerEntry[]) {}
|
|
8
|
-
|
|
9
|
-
toHttpException(error: unknown): HttpException | undefined {
|
|
10
|
-
if (!(error instanceof DetailedError)) {
|
|
11
|
-
return undefined;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const entry = this.entries.find((entry) => error instanceof entry.on);
|
|
15
|
-
|
|
16
|
-
if (!entry) {
|
|
17
|
-
return undefined;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
return ErrorHandler.buildHttpException(error, entry.use, entry.return?.(error));
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
static buildHttpException<TError extends DetailedError, TException extends HttpException>(
|
|
24
|
-
error: TError,
|
|
25
|
-
exception: HttpExceptionClass<TException>,
|
|
26
|
-
exceptionReturn: HttpExceptionReturn = {},
|
|
27
|
-
): TException {
|
|
28
|
-
return new exception(exceptionReturn.message, {
|
|
29
|
-
cause: {
|
|
30
|
-
layer: error.layer(),
|
|
31
|
-
details: error.details(),
|
|
32
|
-
stack: error.stack,
|
|
33
|
-
message: error.message,
|
|
34
|
-
response: exceptionReturn.response,
|
|
35
|
-
},
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
}
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
BadGatewayException,
|
|
3
|
-
BadRequestException,
|
|
4
|
-
ConflictException,
|
|
5
|
-
ForbiddenException,
|
|
6
|
-
HttpException,
|
|
7
|
-
InternalServerErrorException,
|
|
8
|
-
ServiceUnavailableException,
|
|
9
|
-
UnauthorizedException,
|
|
10
|
-
UnprocessableEntityException,
|
|
11
|
-
} from "@nestjs/common";
|
|
12
|
-
|
|
13
|
-
import { ArchitectureLayerType, ArchitectureLevel } from "../../../core/types";
|
|
14
|
-
import { DetailedError } from "../../../core/errors";
|
|
15
|
-
import { ErrorHandler } from "./error-handler";
|
|
16
|
-
import { HttpExceptionClass } from "./error-handler.type";
|
|
17
|
-
|
|
18
|
-
const LAYER_TO_EXCEPTION: Record<ArchitectureLayerType, HttpExceptionClass<HttpException>> = {
|
|
19
|
-
"aggregate-root": UnprocessableEntityException,
|
|
20
|
-
"entity": UnprocessableEntityException,
|
|
21
|
-
"value-object": UnprocessableEntityException,
|
|
22
|
-
"command": UnprocessableEntityException,
|
|
23
|
-
"query": BadGatewayException,
|
|
24
|
-
"event-handler": ConflictException,
|
|
25
|
-
"event-saga": ConflictException,
|
|
26
|
-
"service": InternalServerErrorException,
|
|
27
|
-
"authorization": ForbiddenException,
|
|
28
|
-
"authentication": UnauthorizedException,
|
|
29
|
-
"web-dto": BadRequestException,
|
|
30
|
-
"web-rest": InternalServerErrorException,
|
|
31
|
-
"web-graphql": InternalServerErrorException,
|
|
32
|
-
"web-socket": InternalServerErrorException,
|
|
33
|
-
"web-rpc": InternalServerErrorException,
|
|
34
|
-
"persistence-sql": InternalServerErrorException,
|
|
35
|
-
"persistence-disk": InternalServerErrorException,
|
|
36
|
-
"persistence-fake": InternalServerErrorException,
|
|
37
|
-
"persistence-saas": ServiceUnavailableException,
|
|
38
|
-
"persistence-s3": ServiceUnavailableException,
|
|
39
|
-
"persistence-other": ServiceUnavailableException,
|
|
40
|
-
"messaging-inmem": InternalServerErrorException,
|
|
41
|
-
"messaging-pubsub": ServiceUnavailableException,
|
|
42
|
-
"unknown": InternalServerErrorException,
|
|
43
|
-
};
|
|
44
|
-
|
|
45
|
-
export class GenericErrorHandler {
|
|
46
|
-
toHttpException(error: unknown): HttpException | undefined {
|
|
47
|
-
if (!(error instanceof DetailedError)) {return undefined;}
|
|
48
|
-
|
|
49
|
-
const layerType = this.extractArchitectureLayerType(error);
|
|
50
|
-
const ExceptionClass = LAYER_TO_EXCEPTION[layerType] ?? InternalServerErrorException;
|
|
51
|
-
return ErrorHandler.buildHttpException(error, ExceptionClass);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
private extractArchitectureLayerType(error: DetailedError): ArchitectureLayerType {
|
|
55
|
-
const layer = error.layer();
|
|
56
|
-
const level = Object.keys(layer)[0] as ArchitectureLevel;
|
|
57
|
-
return Object.keys(layer[level as never])[0] as ArchitectureLayerType;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import { isObservable, throwError } from "rxjs";
|
|
2
|
-
import { catchError } from "rxjs/operators";
|
|
3
|
-
|
|
4
|
-
import { DetailedError } from "../../../core/errors";
|
|
5
|
-
import { ErrorHandler } from "./error-handler";
|
|
6
|
-
import { ErrorHandlerEntry } from "./error-handler.type";
|
|
7
|
-
|
|
8
|
-
export function HandleErrors(entries?: ErrorHandlerEntry[]) {
|
|
9
|
-
return function (_target: object, _propertyKey: string, descriptor: PropertyDescriptor) {
|
|
10
|
-
const originalMethod = descriptor.value as (...args: unknown[]) => unknown;
|
|
11
|
-
const errorHandler = new ErrorHandler(entries ?? []);
|
|
12
|
-
|
|
13
|
-
const convertError = (rawError: unknown): unknown =>
|
|
14
|
-
rawError instanceof DetailedError ? (errorHandler.toHttpException(rawError) ?? rawError) : rawError;
|
|
15
|
-
|
|
16
|
-
descriptor.value = function (...args: unknown[]) {
|
|
17
|
-
try {
|
|
18
|
-
const result = originalMethod.apply(this, args) as unknown;
|
|
19
|
-
|
|
20
|
-
if (result && typeof (result as Promise<unknown>).then === "function") {
|
|
21
|
-
return (result as Promise<unknown>).catch((err: unknown) => {
|
|
22
|
-
throw convertError(err);
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
if (isObservable(result)) {
|
|
27
|
-
return result.pipe(
|
|
28
|
-
catchError((err: unknown) => {
|
|
29
|
-
const converted = convertError(err);
|
|
30
|
-
return throwError(() => (converted instanceof Error ? converted : new Error(String(converted))));
|
|
31
|
-
}),
|
|
32
|
-
);
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
return result;
|
|
36
|
-
} catch (rawError) {
|
|
37
|
-
throw convertError(rawError);
|
|
38
|
-
}
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
return descriptor;
|
|
42
|
-
};
|
|
43
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { BadRequestException } from "@nestjs/common";
|
|
2
|
-
import { ValidationError } from "class-validator";
|
|
3
|
-
|
|
4
|
-
import { ArchitectureLayer, ArchitectureLevel } from "../../../core/types";
|
|
5
|
-
|
|
6
|
-
export class ValidationErrorHandler {
|
|
7
|
-
toHttpException(validationErrors: ValidationError[]): BadRequestException {
|
|
8
|
-
const firstError = validationErrors[0];
|
|
9
|
-
const constraints = firstError?.constraints;
|
|
10
|
-
const firstMessage = constraints?.[Object.keys(constraints ?? {})[0]];
|
|
11
|
-
const details = this.formatValidationErrorsNested(validationErrors);
|
|
12
|
-
|
|
13
|
-
return new BadRequestException(firstMessage, {
|
|
14
|
-
cause: {
|
|
15
|
-
layer: {
|
|
16
|
-
[ArchitectureLevel.INFRASTRUCTURE]: {
|
|
17
|
-
"web-dto": {
|
|
18
|
-
className: firstError?.target?.constructor.name ?? ValidationErrorHandler.name,
|
|
19
|
-
},
|
|
20
|
-
},
|
|
21
|
-
} satisfies ArchitectureLayer,
|
|
22
|
-
details,
|
|
23
|
-
response: details,
|
|
24
|
-
},
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
private formatValidationErrorsNested(errors: ValidationError[]): Record<string, unknown> {
|
|
29
|
-
const formatted: Record<string, unknown> = {};
|
|
30
|
-
|
|
31
|
-
for (const err of errors) {
|
|
32
|
-
if (err.constraints) {
|
|
33
|
-
formatted[err.property] = Object.values(err.constraints)[0];
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
if (err.children?.length) {
|
|
37
|
-
const nested = this.formatValidationErrorsNested(err.children);
|
|
38
|
-
formatted[err.property] = formatted[err.property]
|
|
39
|
-
? { errors: formatted[err.property], children: nested }
|
|
40
|
-
: nested;
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
return formatted;
|
|
45
|
-
}
|
|
46
|
-
}
|