@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,170 +0,0 @@
|
|
|
1
|
-
import { FakeImplementationError } from "../../core/errors";
|
|
2
|
-
import { hashKey } from "../../utils";
|
|
3
|
-
|
|
4
|
-
/** Extracts method names from a type as string literal union */
|
|
5
|
-
type MethodKeys<T> = { [K in keyof T]: T[K] extends (...args: never[]) => unknown ? K : never }[keyof T] & string;
|
|
6
|
-
|
|
7
|
-
/** Extracts the argument types of a method */
|
|
8
|
-
type MethodArgs<T, K extends keyof T> = T[K] extends (...args: infer P) => unknown ? P : never;
|
|
9
|
-
|
|
10
|
-
/** Extracts the awaited return value of a method (unwraps Promise) */
|
|
11
|
-
type MethodReturn<T, K extends keyof T> = T[K] extends (...args: never[]) => infer R ? Awaited<R> : never;
|
|
12
|
-
|
|
13
|
-
/** Extracts the raw return type of a method (preserves Promise) */
|
|
14
|
-
type MethodReturnType<T, K extends keyof T> = T[K] extends (...args: never[]) => infer R ? R : never;
|
|
15
|
-
|
|
16
|
-
type StubEntry<TResult> = { type: "result"; value: TResult } | { type: "error"; error: Error };
|
|
17
|
-
type StubStore<TSelf> = Map<string, StubEntry<MethodReturn<TSelf, MethodKeys<TSelf>>>>;
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Factory for generating stub keys.
|
|
21
|
-
* Centralizes the logic for global (method-level) and specific (args-level) keys.
|
|
22
|
-
*/
|
|
23
|
-
class StubKeyFactory<TSelf, K extends MethodKeys<TSelf>> {
|
|
24
|
-
constructor(
|
|
25
|
-
private readonly methodName: K,
|
|
26
|
-
private readonly args?: MethodArgs<TSelf, K>,
|
|
27
|
-
) {}
|
|
28
|
-
|
|
29
|
-
/** Global key for method-level stubs (applies to any args) */
|
|
30
|
-
global(): string {
|
|
31
|
-
return this.methodName;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/** Specific key for arg-specific stubs */
|
|
35
|
-
specific(): string {
|
|
36
|
-
return hashKey({ methodName: this.methodName, params: this.args });
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Builder for specifying method arguments or global method behavior.
|
|
42
|
-
* Part of the fluent API: `stub.onMethod("name").withArgs(...)` or `stub.onMethod("name").throwError(...)`
|
|
43
|
-
*/
|
|
44
|
-
class StubArgsBuilder<TSelf, K extends MethodKeys<TSelf>> {
|
|
45
|
-
private readonly keyFactory: StubKeyFactory<TSelf, K>;
|
|
46
|
-
|
|
47
|
-
constructor(
|
|
48
|
-
private readonly store: StubStore<TSelf>,
|
|
49
|
-
private readonly methodName: K,
|
|
50
|
-
private readonly className: string,
|
|
51
|
-
) {
|
|
52
|
-
this.keyFactory = new StubKeyFactory(methodName);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Specifies the arguments for the stubbed method call.
|
|
57
|
-
* @param args - The arguments to match when the method is called
|
|
58
|
-
*/
|
|
59
|
-
withArgs(...args: MethodArgs<TSelf, K>): StubResultBuilder<TSelf, K> {
|
|
60
|
-
return new StubResultBuilder(this.store, this.methodName, args, this.className);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* Stubs the method to return a value for any arguments.
|
|
65
|
-
* @param result - The value to return regardless of arguments
|
|
66
|
-
*/
|
|
67
|
-
returnValue(result: MethodReturn<TSelf, K>): void {
|
|
68
|
-
this.store.set(this.keyFactory.global(), { type: "result", value: result });
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Stubs the method to throw an error for any arguments.
|
|
73
|
-
* @param error - The error to throw regardless of arguments
|
|
74
|
-
*/
|
|
75
|
-
throwError(error: Error): void {
|
|
76
|
-
this.store.set(this.keyFactory.global(), { type: "error", error });
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* Builder for defining stub behavior or executing the stub.
|
|
82
|
-
* Part of the fluent API: `stub.onMethod("name").withArgs(...).returnValue(...)`
|
|
83
|
-
*/
|
|
84
|
-
class StubResultBuilder<TSelf, K extends MethodKeys<TSelf>> {
|
|
85
|
-
private readonly keyFactory: StubKeyFactory<TSelf, K>;
|
|
86
|
-
|
|
87
|
-
constructor(
|
|
88
|
-
private readonly store: StubStore<TSelf>,
|
|
89
|
-
methodName: K,
|
|
90
|
-
args: MethodArgs<TSelf, K>,
|
|
91
|
-
private readonly className: string,
|
|
92
|
-
) {
|
|
93
|
-
this.keyFactory = new StubKeyFactory(methodName, args);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
/**
|
|
97
|
-
* Stubs the method to return a value when called with the specified arguments.
|
|
98
|
-
* @param result - The value to return
|
|
99
|
-
*/
|
|
100
|
-
returnValue(result: MethodReturn<TSelf, K>): void {
|
|
101
|
-
this.store.set(this.keyFactory.specific(), { type: "result", value: result });
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
/**
|
|
105
|
-
* Stubs the method to throw an error when called with the specified arguments.
|
|
106
|
-
* @param error - The error to throw
|
|
107
|
-
*/
|
|
108
|
-
throwError(error: Error): void {
|
|
109
|
-
this.store.set(this.keyFactory.specific(), { type: "error", error });
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
/**
|
|
113
|
-
* Executes the stub and returns the configured result or throws the configured error.
|
|
114
|
-
* @throws {FakeImplementationError} If no stub is configured for the given method and arguments
|
|
115
|
-
* @throws The configured error if `throwError` was used (with or without args)
|
|
116
|
-
*/
|
|
117
|
-
execute(): MethodReturnType<TSelf, K> {
|
|
118
|
-
const entry = this.store.get(this.keyFactory.specific()) ?? this.store.get(this.keyFactory.global());
|
|
119
|
-
|
|
120
|
-
if (!entry) {
|
|
121
|
-
throw new FakeImplementationError(this.className, this.keyFactory.global());
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
if (entry.type === "error") {
|
|
125
|
-
throw entry.error;
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
return entry.value as MethodReturnType<TSelf, K>;
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
/**
|
|
133
|
-
* Abstract base class for creating type-safe method stubs.
|
|
134
|
-
*
|
|
135
|
-
* @example
|
|
136
|
-
* ```typescript
|
|
137
|
-
* class FakeUserService extends Stub<FakeUserService> implements UserService {
|
|
138
|
-
* async fetchUser(id: string): Promise<User> {
|
|
139
|
-
* return this.onMethod("fetchUser").withArgs(id).execute();
|
|
140
|
-
* }
|
|
141
|
-
* }
|
|
142
|
-
*
|
|
143
|
-
* // In tests:
|
|
144
|
-
* const fake = new FakeUserService();
|
|
145
|
-
*
|
|
146
|
-
* // Stub specific args
|
|
147
|
-
* fake.onMethod("fetchUser").withArgs("123").returnValue({ id: "123", name: "John" });
|
|
148
|
-
* fake.onMethod("fetchUser").withArgs("invalid").throwError(new NotFoundError());
|
|
149
|
-
*
|
|
150
|
-
* // Stub for any args (global fallback)
|
|
151
|
-
* fake.onMethod("fetchUser").returnValue({ id: "default", name: "Default" });
|
|
152
|
-
* fake.onMethod("fetchUser").throwError(new ServiceUnavailableError());
|
|
153
|
-
* ```
|
|
154
|
-
*/
|
|
155
|
-
export abstract class Stub<TSelf = unknown> {
|
|
156
|
-
protected store: StubStore<TSelf> = new Map();
|
|
157
|
-
|
|
158
|
-
/**
|
|
159
|
-
* Starts the stub configuration for a method.
|
|
160
|
-
* @param methodName - The name of the method to stub
|
|
161
|
-
*/
|
|
162
|
-
onMethod<K extends MethodKeys<TSelf>>(methodName: K): StubArgsBuilder<TSelf, K> {
|
|
163
|
-
return new StubArgsBuilder(this.store, methodName, this.constructor.name);
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
/** Clears all stubbed configurations. */
|
|
167
|
-
clear(): void {
|
|
168
|
-
this.store.clear();
|
|
169
|
-
}
|
|
170
|
-
}
|
package/src/utils/array.spec.ts
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { chunk } from "./array";
|
|
2
|
-
|
|
3
|
-
const generateArray = (length: number): number[] => new Array<number>(length).fill(0);
|
|
4
|
-
|
|
5
|
-
describe("chunk", () => {
|
|
6
|
-
it("should split 1 array 100 items into 10 array 10 items", () => {
|
|
7
|
-
const ARRAY = generateArray(100);
|
|
8
|
-
|
|
9
|
-
const chunks = chunk(ARRAY, 10);
|
|
10
|
-
|
|
11
|
-
expect(chunks.length).toEqual(10);
|
|
12
|
-
chunks.forEach((chunk) => expect(chunk.length).toEqual(10));
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it("should split 1 array 95 items into 9 array 10 items and 1 array 5 items", () => {
|
|
16
|
-
const ARRAY = generateArray(95);
|
|
17
|
-
|
|
18
|
-
const chunks = chunk(ARRAY, 10);
|
|
19
|
-
|
|
20
|
-
expect(chunks.length).toEqual(10);
|
|
21
|
-
chunks.forEach((chunk, index) => {
|
|
22
|
-
if (index !== 9) {
|
|
23
|
-
expect(chunk.length).toEqual(10);
|
|
24
|
-
} else {
|
|
25
|
-
expect(chunk.length).toEqual(5);
|
|
26
|
-
}
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
});
|
package/src/utils/array.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/unbound-method */
|
|
2
|
-
import _ from "lodash";
|
|
3
|
-
|
|
4
|
-
export const uniqBy = _.uniqBy;
|
|
5
|
-
export const maxBy = _.maxBy;
|
|
6
|
-
export const minBy = _.minBy;
|
|
7
|
-
export const chunk = _.chunk;
|
|
8
|
-
export const shuffle = _.shuffle;
|
|
9
|
-
export const sum = _.sum;
|
|
10
|
-
export const sortBy = _.sortBy;
|
package/src/utils/base64.spec.ts
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { base64ToString, stringToBase64 } from "./base64";
|
|
2
|
-
|
|
3
|
-
const UNICODE_STRING = "foo © bar 𝌆 baz";
|
|
4
|
-
const ENCODED_BASE64 = "Zm9vIMKpIGJhciDwnYyGIGJheg==";
|
|
5
|
-
|
|
6
|
-
describe("base64", () => {
|
|
7
|
-
describe("base64ToString", () => {
|
|
8
|
-
it("should decoded base64 to string", () => {
|
|
9
|
-
expect(base64ToString(ENCODED_BASE64)).toEqual(UNICODE_STRING);
|
|
10
|
-
});
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
describe("stringToBase64", () => {
|
|
14
|
-
it("should encoded string to base64", () => {
|
|
15
|
-
expect(stringToBase64(UNICODE_STRING)).toEqual(ENCODED_BASE64);
|
|
16
|
-
});
|
|
17
|
-
});
|
|
18
|
-
});
|
package/src/utils/base64.ts
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { decode as decodeBase64, encode as encodeBase64 } from "base-64";
|
|
2
|
-
import { decode as decodeUtf8, encode as encodeUtf8 } from "utf8";
|
|
3
|
-
|
|
4
|
-
export const stringToBase64 = (str: string) => encodeBase64(encodeUtf8(str));
|
|
5
|
-
|
|
6
|
-
export const base64ToString = (base64: string) => decodeUtf8(decodeBase64(base64));
|
package/src/utils/collection.ts
DELETED
package/src/utils/common.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export type RecursiveKeyOf<TObj extends object> = {
|
|
2
|
-
[TKey in keyof TObj & (string | number)]: RecursiveKeyOfHandleValue<TObj[TKey], `${TKey}`>;
|
|
3
|
-
}[keyof TObj & (string | number)];
|
|
4
|
-
|
|
5
|
-
type RecursiveKeyOfInner<TObj extends object> = {
|
|
6
|
-
[TKey in keyof TObj & (string | number)]: RecursiveKeyOfHandleValue<TObj[TKey], `['${TKey}']` | `.${TKey}`>;
|
|
7
|
-
}[keyof TObj & (string | number)];
|
|
8
|
-
|
|
9
|
-
type RecursiveKeyOfHandleValue<TValue, Text extends string> = TValue extends unknown[]
|
|
10
|
-
? Text
|
|
11
|
-
: TValue extends object
|
|
12
|
-
? Text | `${Text}${RecursiveKeyOfInner<TValue>}`
|
|
13
|
-
: Text;
|
package/src/utils/csv.ts
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
|
2
|
-
import "reflect-metadata";
|
|
3
|
-
import { Transform } from "stream";
|
|
4
|
-
|
|
5
|
-
const META_KEY = Symbol("csv:columns");
|
|
6
|
-
|
|
7
|
-
type ColumnMeta = { propertyKey: string; displayName: string };
|
|
8
|
-
|
|
9
|
-
export function CSVFileRecord(): ClassDecorator {
|
|
10
|
-
return function (target: object) {
|
|
11
|
-
Reflect.defineMetadata(META_KEY, [], target);
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export function Column(displayName: string): PropertyDecorator {
|
|
16
|
-
return function (target: object, propertyKey: string | symbol) {
|
|
17
|
-
const columns: ColumnMeta[] = Reflect.getMetadata(META_KEY, target) ?? [];
|
|
18
|
-
columns.push({ propertyKey: propertyKey as string, displayName });
|
|
19
|
-
Reflect.defineMetadata(META_KEY, columns, target);
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
export class CSVStream extends Transform {
|
|
24
|
-
private headerWritten = false;
|
|
25
|
-
|
|
26
|
-
constructor() {
|
|
27
|
-
super({ objectMode: true });
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
_transform(data: Record<string, string>, _enc: string, done: () => void) {
|
|
31
|
-
const columns = Reflect.getMetadata(META_KEY, data) as ColumnMeta[] | undefined;
|
|
32
|
-
if (!columns) {throw new Error("data is not a valid record");}
|
|
33
|
-
|
|
34
|
-
if (!this.headerWritten) {
|
|
35
|
-
this.push(columns.map((c) => c.displayName).join(",") + "\r\n");
|
|
36
|
-
this.headerWritten = true;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const row = columns.map((c) => (data[c.propertyKey] ?? "").toString().replace(/"/g, '""'));
|
|
40
|
-
this.push(`"${row.join('","')}"\r\n`);
|
|
41
|
-
|
|
42
|
-
done();
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
_flush(done: () => void) {
|
|
46
|
-
this.headerWritten = false;
|
|
47
|
-
done();
|
|
48
|
-
}
|
|
49
|
-
}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import { arrayContainsDate, compareDates, composeDate, daysBetweenDates, isValidDate, makeDateRange } from "./date";
|
|
2
|
-
|
|
3
|
-
describe("makeDateRange", () => {
|
|
4
|
-
it("should include from and to", () => {
|
|
5
|
-
const from = new Date("2021-07-13");
|
|
6
|
-
const to = new Date("2021-07-15");
|
|
7
|
-
|
|
8
|
-
expect(makeDateRange(from, to)).toEqual([new Date("2021-07-13"), new Date("2021-07-14"), new Date("2021-07-15")]);
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
it("should not make a range if to is before from", () => {
|
|
12
|
-
const from = new Date("2021-07-29");
|
|
13
|
-
const to = new Date("2021-07-28");
|
|
14
|
-
|
|
15
|
-
expect(makeDateRange(from, to)).toEqual([]);
|
|
16
|
-
});
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
describe("compareDates", () => {
|
|
20
|
-
it("should make correct comparisons", () => {
|
|
21
|
-
expect(compareDates(new Date("2021-06-15"), new Date("2021-06-17"))).toBeLessThan(0);
|
|
22
|
-
expect(compareDates(new Date("2021-06-15"), new Date("2021-06-13"))).toBeGreaterThan(0);
|
|
23
|
-
expect(compareDates(new Date("2021-06-15"), new Date("2021-06-15"))).toBe(0);
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
it("should order an array of dates ASC", () => {
|
|
27
|
-
const array = [new Date("2021-06-17"), new Date("2021-06-13"), new Date("2021-06-19"), new Date("2021-06-15")];
|
|
28
|
-
|
|
29
|
-
expect(array.sort(compareDates)).toEqual([
|
|
30
|
-
new Date("2021-06-13"),
|
|
31
|
-
new Date("2021-06-15"),
|
|
32
|
-
new Date("2021-06-17"),
|
|
33
|
-
new Date("2021-06-19"),
|
|
34
|
-
]);
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
describe("arrayContainsDate", () => {
|
|
39
|
-
it("should find a date in an array of dates", () => {
|
|
40
|
-
const date = new Date("2021-06-15");
|
|
41
|
-
const array = [new Date("2021-06-13"), new Date("2021-06-15"), new Date("2021-06-17")];
|
|
42
|
-
|
|
43
|
-
expect(arrayContainsDate(array, date)).toBe(true);
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
it("should not find a date if no date is the same", () => {
|
|
47
|
-
const date = new Date("2021-06-15");
|
|
48
|
-
const array = [new Date("2021-06-13"), new Date("2021-06-15T22:00:00"), new Date("2021-06-17")];
|
|
49
|
-
|
|
50
|
-
expect(arrayContainsDate(array, date)).toBe(false);
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
describe("daysBetween dates", () => {
|
|
55
|
-
it("sould compute the number of days between dates", () => {
|
|
56
|
-
const date1 = new Date("2021-06-15");
|
|
57
|
-
const date2 = new Date("2021-06-11");
|
|
58
|
-
|
|
59
|
-
expect(daysBetweenDates(date1, date2)).toBe(4);
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it("should floor the result of the computation", () => {
|
|
63
|
-
const date1 = new Date("2021-06-15T12:00:00.000Z");
|
|
64
|
-
const date2 = new Date("2021-06-11");
|
|
65
|
-
|
|
66
|
-
expect(daysBetweenDates(date1, date2)).toBe(4);
|
|
67
|
-
});
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
describe("composeDate", () => {
|
|
71
|
-
describe("should compose a date from a string and a timezone", () => {
|
|
72
|
-
it("Asia/Ho_Chi_Minh", () => {
|
|
73
|
-
const dateStr = "2021-06-15 12:00:00";
|
|
74
|
-
const format = "YYYY-MM-DD HH:mm:ss";
|
|
75
|
-
const timezone = "Asia/Ho_Chi_Minh"; // UTC+7
|
|
76
|
-
|
|
77
|
-
expect(composeDate(dateStr, format, timezone)).toEqual(new Date("2021-06-15T05:00:00.000Z"));
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it("UTC", () => {
|
|
81
|
-
const dateStr = "15/06/2021 12:00";
|
|
82
|
-
const format = "DD/MM/YYYY HH:mm";
|
|
83
|
-
const timezone = "UTC";
|
|
84
|
-
|
|
85
|
-
expect(composeDate(dateStr, format, timezone)).toEqual(new Date("2021-06-15T12:00:00.000Z"));
|
|
86
|
-
});
|
|
87
|
-
});
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
describe("isValidDate", () => {
|
|
91
|
-
it("should return true if the date is valid", () => {
|
|
92
|
-
const date = new Date("2021-06-15");
|
|
93
|
-
expect(isValidDate(date)).toBe(true);
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
it("should return false if the date is invalid", () => {
|
|
97
|
-
const date = new Date("invalid");
|
|
98
|
-
expect(isValidDate(date)).toBe(false);
|
|
99
|
-
});
|
|
100
|
-
});
|
package/src/utils/date/date.ts
DELETED
|
@@ -1,177 +0,0 @@
|
|
|
1
|
-
import dayjs, { extend } from "dayjs";
|
|
2
|
-
import customParseFormat from "dayjs/plugin/customParseFormat";
|
|
3
|
-
import quarterPlugin from "dayjs/plugin/quarterOfYear";
|
|
4
|
-
import relativeTime from "dayjs/plugin/relativeTime";
|
|
5
|
-
import timezone from "dayjs/plugin/timezone";
|
|
6
|
-
import utc from "dayjs/plugin/utc";
|
|
7
|
-
|
|
8
|
-
import { maxBy, minBy } from "../array";
|
|
9
|
-
import { RecursiveKeyOf } from "../common";
|
|
10
|
-
import { get } from "../object";
|
|
11
|
-
import { DateRange } from "./date-range";
|
|
12
|
-
|
|
13
|
-
extend(quarterPlugin);
|
|
14
|
-
extend(timezone);
|
|
15
|
-
extend(utc);
|
|
16
|
-
extend(relativeTime);
|
|
17
|
-
extend(customParseFormat);
|
|
18
|
-
|
|
19
|
-
export const makeDateRange = (from: Date, to: Date) => {
|
|
20
|
-
const range: Date[] = [];
|
|
21
|
-
|
|
22
|
-
for (let current = new Date(from); current <= to; current.setDate(current.getDate() + 1)) {
|
|
23
|
-
range.push(new Date(current));
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
return range;
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
const MS_IN_DAY = 86_400_000;
|
|
30
|
-
|
|
31
|
-
export const daysBetweenDates = (date1: Date, date2: Date): number =>
|
|
32
|
-
Math.floor(Math.abs(date2.getTime() - date1.getTime()) / MS_IN_DAY);
|
|
33
|
-
|
|
34
|
-
export const compareDates = (date1: Date, date2: Date): number => date1.getTime() - date2.getTime();
|
|
35
|
-
|
|
36
|
-
export const arrayContainsDate = (dateArray: Date[], date: Date): boolean =>
|
|
37
|
-
dateArray.some((d) => compareDates(date, d) === 0);
|
|
38
|
-
|
|
39
|
-
export const isSame = (date: Date, compareDate: Date, type?: dayjs.QUnitType): boolean =>
|
|
40
|
-
dayjs(date).isSame(compareDate, type);
|
|
41
|
-
|
|
42
|
-
export const isSameOrBefore = (date: Date, compareDate: Date): boolean =>
|
|
43
|
-
date.getTime() <= compareDate.getTime();
|
|
44
|
-
|
|
45
|
-
export const isBefore = (date: Date, compareDate: Date): boolean =>
|
|
46
|
-
date.getTime() < compareDate.getTime();
|
|
47
|
-
|
|
48
|
-
export const isSameOrAfter = (date: Date, compareDate: Date): boolean =>
|
|
49
|
-
date.getTime() >= compareDate.getTime();
|
|
50
|
-
|
|
51
|
-
export const isAfter = (date: Date, compareDate: Date): boolean =>
|
|
52
|
-
date.getTime() > compareDate.getTime();
|
|
53
|
-
|
|
54
|
-
export const diffDay = (date: Date, compareDate: Date): number =>
|
|
55
|
-
Math.ceil((compareDate.getTime() - date.getTime()) / MS_IN_DAY);
|
|
56
|
-
|
|
57
|
-
export const diffYear = (date1: Date, date2: Date) =>
|
|
58
|
-
dayjs(date1).diff(date2, "year", true);
|
|
59
|
-
|
|
60
|
-
export const diff = (date: Date, compareDate: Date, unit?: dayjs.QUnitType | dayjs.OpUnitType, float?: boolean) =>
|
|
61
|
-
dayjs(date).diff(compareDate, unit, float);
|
|
62
|
-
|
|
63
|
-
export type GroupUnit = "day" | "month" | "quarter" | "year";
|
|
64
|
-
|
|
65
|
-
export type GroupDate<T> = {
|
|
66
|
-
beginOfUnit: Date;
|
|
67
|
-
endOfUnit: Date;
|
|
68
|
-
values: T[];
|
|
69
|
-
unit: GroupUnit;
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
const makeGroupKey = (date: Date, unit: GroupUnit): string => {
|
|
73
|
-
const y = date.getFullYear();
|
|
74
|
-
const m = date.getMonth();
|
|
75
|
-
switch (unit) {
|
|
76
|
-
case "day": return `${y}-${m}-${date.getDate()}`;
|
|
77
|
-
case "month": return `${y}-${m}-m`;
|
|
78
|
-
case "quarter": return `${y}-${Math.floor(m / 3)}-q`;
|
|
79
|
-
case "year": return `${y}`;
|
|
80
|
-
}
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
export function groupBy<T extends object>(array: T[], key: RecursiveKeyOf<T>, unit: GroupUnit): GroupDate<T>[] {
|
|
84
|
-
const groups: Map<string, GroupDate<T>> = new Map();
|
|
85
|
-
|
|
86
|
-
array.forEach((item) => {
|
|
87
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
88
|
-
const date = get(item, key);
|
|
89
|
-
if (!(date instanceof Date)) {
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
const groupKey = makeGroupKey(date, unit);
|
|
94
|
-
|
|
95
|
-
const group = groups.get(groupKey) || {
|
|
96
|
-
beginOfUnit: dayjs(date).startOf(unit).toDate(),
|
|
97
|
-
endOfUnit: dayjs(date).endOf(unit).toDate(),
|
|
98
|
-
values: [],
|
|
99
|
-
unit,
|
|
100
|
-
};
|
|
101
|
-
|
|
102
|
-
group.values.push(item);
|
|
103
|
-
groups.set(groupKey, group);
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
return Array.from(groups.values());
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
export function fillMissingRangeValues<T extends object>(
|
|
110
|
-
array: GroupDate<T>[],
|
|
111
|
-
unit: GroupUnit,
|
|
112
|
-
dateRange?: DateRange,
|
|
113
|
-
): GroupDate<T>[] {
|
|
114
|
-
const groups: Map<string, GroupDate<T>> = new Map(
|
|
115
|
-
array.map((item) => {
|
|
116
|
-
return [makeGroupKey(item.beginOfUnit, unit), item];
|
|
117
|
-
}),
|
|
118
|
-
);
|
|
119
|
-
|
|
120
|
-
const minDate = dateRange?.from
|
|
121
|
-
? dayjs(dateRange.from).startOf(unit).toDate()
|
|
122
|
-
: dayjs(minBy(array, "beginOfUnit")?.beginOfUnit).startOf(unit).toDate();
|
|
123
|
-
|
|
124
|
-
const maxDate = dateRange?.to
|
|
125
|
-
? dayjs(dateRange.to).endOf(unit).toDate()
|
|
126
|
-
: dayjs(maxBy(array, "beginOfUnit")?.beginOfUnit).endOf(unit).toDate();
|
|
127
|
-
|
|
128
|
-
for (let date = new Date(minDate); isSameOrBefore(date, maxDate); date = add(date, 1, unit)) {
|
|
129
|
-
const groupKey = makeGroupKey(date, unit);
|
|
130
|
-
const group = groups.get(groupKey) || {
|
|
131
|
-
beginOfUnit: dayjs(date).startOf(unit).toDate(),
|
|
132
|
-
endOfUnit: dayjs(date).endOf(unit).toDate(),
|
|
133
|
-
values: [],
|
|
134
|
-
unit,
|
|
135
|
-
};
|
|
136
|
-
groups.set(groupKey, group);
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
return Array.from(groups.values());
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
type DateUnit = "quarter" | "year" | "month" | "day";
|
|
143
|
-
type TimeUnit = DateUnit | "hour" | "minute" | "second" | "millisecond";
|
|
144
|
-
|
|
145
|
-
export const startOf = (date: Date, unit: DateUnit) => dayjs(date).startOf(unit).toDate();
|
|
146
|
-
|
|
147
|
-
export const endOf = (date: Date, unit: DateUnit) => dayjs(date).endOf(unit).toDate();
|
|
148
|
-
|
|
149
|
-
export const subtract = (date: Date, n: number, unit: TimeUnit) => dayjs(date).subtract(n, unit).toDate();
|
|
150
|
-
|
|
151
|
-
export const add = (date: Date, n: number, unit: TimeUnit) => dayjs(date).add(n, unit).toDate();
|
|
152
|
-
|
|
153
|
-
export const getQuarter = (date: Date) => dayjs(date).quarter();
|
|
154
|
-
|
|
155
|
-
export const randomDate = (start: Date, end: Date) =>
|
|
156
|
-
new Date(start.getTime() + Math.random() * (end.getTime() - start.getTime()));
|
|
157
|
-
|
|
158
|
-
export const format = (date: Date, fmt: string, timezone?: string) => {
|
|
159
|
-
const d = dayjs(date);
|
|
160
|
-
if (!d.isValid()) {return "";}
|
|
161
|
-
|
|
162
|
-
if (timezone) {
|
|
163
|
-
try { return d.tz(timezone).format(fmt); } catch { /* fall through */ }
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
return d.format(fmt);
|
|
167
|
-
};
|
|
168
|
-
|
|
169
|
-
export const toNow = (date: Date) => dayjs(date).toNow();
|
|
170
|
-
|
|
171
|
-
export const fromNow = (date: Date) => dayjs(date).fromNow();
|
|
172
|
-
|
|
173
|
-
export const composeDate = (dateStr: string, fmt: string, timezone: string) => {
|
|
174
|
-
try { return dayjs.tz(dateStr, fmt, timezone).toDate(); } catch { return new Date(dateStr); }
|
|
175
|
-
};
|
|
176
|
-
|
|
177
|
-
export const isValidDate = (date: Date) => dayjs(date).isValid();
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import { add, diff } from "./date";
|
|
2
|
-
|
|
3
|
-
const NOW = Date.now();
|
|
4
|
-
|
|
5
|
-
const ONE_MS = 1;
|
|
6
|
-
const ONE_SECOND = ONE_MS * 1000;
|
|
7
|
-
const ONE_MINUTE = ONE_SECOND * 60;
|
|
8
|
-
const ONE_HOUR = ONE_MINUTE * 60;
|
|
9
|
-
|
|
10
|
-
describe("diff", () => {
|
|
11
|
-
describe("millisecond", () => {
|
|
12
|
-
it("should return diff millisecond", () => {
|
|
13
|
-
const result = diff(new Date(NOW + ONE_MS), new Date(NOW), "millisecond");
|
|
14
|
-
|
|
15
|
-
expect(result).toEqual(1);
|
|
16
|
-
});
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
describe("second", () => {
|
|
20
|
-
it("should return diff second", () => {
|
|
21
|
-
const result = diff(new Date(NOW + ONE_SECOND), new Date(NOW), "second");
|
|
22
|
-
|
|
23
|
-
expect(result).toEqual(1);
|
|
24
|
-
});
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
describe("minute", () => {
|
|
28
|
-
it("should return diff minute", () => {
|
|
29
|
-
const result = diff(new Date(NOW + ONE_MINUTE), new Date(NOW), "minute");
|
|
30
|
-
|
|
31
|
-
expect(result).toEqual(1);
|
|
32
|
-
});
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
describe("hour", () => {
|
|
36
|
-
it("should return diff hour", () => {
|
|
37
|
-
const result = diff(new Date(NOW + ONE_HOUR), new Date(NOW), "hour");
|
|
38
|
-
|
|
39
|
-
expect(result).toEqual(1);
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
describe("day", () => {
|
|
44
|
-
it("should return diff day", () => {
|
|
45
|
-
const result = diff(add(new Date(NOW), 1, "day"), new Date(NOW), "day");
|
|
46
|
-
|
|
47
|
-
expect(result).toEqual(1);
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
describe("month", () => {
|
|
52
|
-
it("should return diff month", () => {
|
|
53
|
-
const result = diff(add(new Date(NOW), 1, "month"), new Date(NOW), "month");
|
|
54
|
-
|
|
55
|
-
expect(result).toEqual(1);
|
|
56
|
-
});
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
describe("year", () => {
|
|
60
|
-
it("should return diff year", () => {
|
|
61
|
-
const result = diff(add(new Date(NOW), 1, "year"), new Date(NOW), "year");
|
|
62
|
-
|
|
63
|
-
expect(result).toEqual(1);
|
|
64
|
-
});
|
|
65
|
-
});
|
|
66
|
-
});
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { diffYear } from "./date";
|
|
2
|
-
|
|
3
|
-
describe("diffYear", () => {
|
|
4
|
-
it("should return correct value if firstDate is of normal year", () => {
|
|
5
|
-
const firstDate = new Date(2022, 1, 1); // 2022 is normal year
|
|
6
|
-
const expectedResult = 1.25;
|
|
7
|
-
const secondDate = new Date(firstDate.getTime() + expectedResult * 365 * 24 * 60 * 60 * 1000);
|
|
8
|
-
|
|
9
|
-
const duration = diffYear(secondDate, firstDate);
|
|
10
|
-
|
|
11
|
-
expect(duration).toBeCloseTo(expectedResult, 1);
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
it("should return correct value if firstDate is of leap year", () => {
|
|
15
|
-
const firstDate = new Date(2016, 1, 1); // 2020 is leap year
|
|
16
|
-
const expectedResult = 1.25;
|
|
17
|
-
const secondDate = new Date(firstDate.getTime() + expectedResult * 366 * 24 * 60 * 60 * 1000);
|
|
18
|
-
|
|
19
|
-
const duration = diffYear(secondDate, firstDate);
|
|
20
|
-
|
|
21
|
-
expect(duration).toBeCloseTo(expectedResult, 1);
|
|
22
|
-
});
|
|
23
|
-
});
|