@woltz/rich-domain 1.3.2 → 1.4.0
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/README.md +21 -0
- package/dist/{aggregate-changes.d.ts → cjs/aggregate-changes.d.ts} +2 -2
- package/dist/cjs/aggregate-changes.d.ts.map +1 -0
- package/dist/cjs/aggregate-changes.js +365 -0
- package/dist/cjs/aggregate-changes.js.map +1 -0
- package/dist/{base-entity.d.ts → cjs/base-entity.d.ts} +5 -5
- package/dist/cjs/base-entity.d.ts.map +1 -0
- package/dist/cjs/base-entity.js +328 -0
- package/dist/cjs/base-entity.js.map +1 -0
- package/dist/{change-tracker.d.ts → cjs/change-tracker.d.ts} +2 -2
- package/dist/cjs/change-tracker.d.ts.map +1 -0
- package/dist/cjs/change-tracker.js +789 -0
- package/dist/cjs/change-tracker.js.map +1 -0
- package/dist/cjs/constants.d.ts.map +1 -0
- package/dist/cjs/constants.js +74 -0
- package/dist/cjs/constants.js.map +1 -0
- package/dist/{criteria.d.ts → cjs/criteria.d.ts} +1 -1
- package/dist/cjs/criteria.d.ts.map +1 -0
- package/dist/cjs/criteria.js +335 -0
- package/dist/{criteria.js.map → cjs/criteria.js.map} +1 -1
- package/dist/cjs/crypto.d.ts.map +1 -0
- package/dist/cjs/crypto.js +32 -0
- package/dist/cjs/crypto.js.map +1 -0
- package/dist/cjs/domain-event-bus.d.ts.map +1 -0
- package/dist/cjs/domain-event-bus.js +108 -0
- package/dist/cjs/domain-event-bus.js.map +1 -0
- package/dist/{domain-event.d.ts → cjs/domain-event.d.ts} +1 -1
- package/dist/cjs/domain-event.d.ts.map +1 -0
- package/dist/cjs/domain-event.js +47 -0
- package/dist/cjs/domain-event.js.map +1 -0
- package/dist/{entity-changes.d.ts → cjs/entity-changes.d.ts} +1 -1
- package/dist/cjs/entity-changes.d.ts.map +1 -0
- package/dist/cjs/entity-changes.js +136 -0
- package/dist/cjs/entity-changes.js.map +1 -0
- package/dist/{entity-schema-registry.d.ts → cjs/entity-schema-registry.d.ts} +2 -2
- package/dist/cjs/entity-schema-registry.d.ts.map +1 -0
- package/dist/cjs/entity-schema-registry.js +370 -0
- package/dist/cjs/entity-schema-registry.js.map +1 -0
- package/dist/{entity.d.ts → cjs/entity.d.ts} +2 -2
- package/dist/cjs/entity.d.ts.map +1 -0
- package/dist/cjs/entity.js +11 -0
- package/dist/cjs/entity.js.map +1 -0
- package/dist/cjs/exceptions.d.ts.map +1 -0
- package/dist/cjs/exceptions.js +365 -0
- package/dist/cjs/exceptions.js.map +1 -0
- package/dist/cjs/id.d.ts.map +1 -0
- package/dist/cjs/id.js +80 -0
- package/dist/cjs/id.js.map +1 -0
- package/dist/{index.d.ts → cjs/index.d.ts} +16 -16
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +47 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/mapper.d.ts.map +1 -0
- package/dist/cjs/mapper.js +7 -0
- package/dist/cjs/mapper.js.map +1 -0
- package/dist/{paginated-result.d.ts → cjs/paginated-result.d.ts} +2 -2
- package/dist/cjs/paginated-result.d.ts.map +1 -0
- package/dist/cjs/paginated-result.js +194 -0
- package/dist/cjs/paginated-result.js.map +1 -0
- package/dist/{repository → cjs/repository}/base-repository.d.ts +4 -4
- package/dist/cjs/repository/base-repository.d.ts.map +1 -0
- package/dist/cjs/repository/base-repository.js +16 -0
- package/dist/cjs/repository/base-repository.js.map +1 -0
- package/dist/cjs/repository/index.d.ts +4 -0
- package/dist/cjs/repository/index.d.ts.map +1 -0
- package/dist/cjs/repository/index.js +24 -0
- package/dist/cjs/repository/index.js.map +1 -0
- package/dist/{repository → cjs/repository}/unit-of-work.d.ts +1 -1
- package/dist/cjs/repository/unit-of-work.d.ts.map +1 -0
- package/dist/cjs/repository/unit-of-work.js +60 -0
- package/dist/cjs/repository/unit-of-work.js.map +1 -0
- package/dist/cjs/types/change-tracker.d.ts +226 -0
- package/dist/cjs/types/change-tracker.d.ts.map +1 -0
- package/dist/cjs/types/change-tracker.js +3 -0
- package/dist/cjs/types/change-tracker.js.map +1 -0
- package/dist/cjs/types/criteria.d.ts +60 -0
- package/dist/cjs/types/criteria.d.ts.map +1 -0
- package/dist/cjs/types/criteria.js +20 -0
- package/dist/cjs/types/criteria.js.map +1 -0
- package/dist/cjs/types/domain-event.d.ts +32 -0
- package/dist/cjs/types/domain-event.d.ts.map +1 -0
- package/dist/cjs/types/domain-event.js +3 -0
- package/dist/{types → cjs/types}/domain-event.js.map +1 -1
- package/dist/{types → cjs/types}/domain.d.ts +2 -2
- package/dist/cjs/types/domain.d.ts.map +1 -0
- package/dist/cjs/types/domain.js +3 -0
- package/dist/{types → cjs/types}/domain.js.map +1 -1
- package/dist/cjs/types/index.d.ts +8 -0
- package/dist/cjs/types/index.d.ts.map +1 -0
- package/dist/cjs/types/index.js +24 -0
- package/dist/cjs/types/index.js.map +1 -0
- package/dist/cjs/types/standard-schema.d.ts.map +1 -0
- package/dist/cjs/types/standard-schema.js +3 -0
- package/dist/cjs/types/standard-schema.js.map +1 -0
- package/dist/{types → cjs/types}/unit-of-work.d.ts +2 -2
- package/dist/cjs/types/unit-of-work.d.ts.map +1 -0
- package/dist/cjs/types/unit-of-work.js +3 -0
- package/dist/{types → cjs/types}/unit-of-work.js.map +1 -1
- package/dist/{types → cjs/types}/utils.d.ts +1 -1
- package/dist/cjs/types/utils.d.ts.map +1 -0
- package/dist/cjs/types/utils.js +3 -0
- package/dist/{types → cjs/types}/utils.js.map +1 -1
- package/dist/{utils → cjs/utils}/criteria-operator-validation.d.ts +1 -1
- package/dist/cjs/utils/criteria-operator-validation.d.ts.map +1 -0
- package/dist/cjs/utils/criteria-operator-validation.js +171 -0
- package/dist/cjs/utils/criteria-operator-validation.js.map +1 -0
- package/dist/cjs/utils/helpers.d.ts.map +1 -0
- package/dist/cjs/utils/helpers.js +37 -0
- package/dist/cjs/utils/helpers.js.map +1 -0
- package/dist/cjs/validation-error.d.ts.map +1 -0
- package/dist/cjs/validation-error.js +117 -0
- package/dist/cjs/validation-error.js.map +1 -0
- package/dist/{value-object.d.ts → cjs/value-object.d.ts} +2 -2
- package/dist/cjs/value-object.d.ts.map +1 -0
- package/dist/cjs/value-object.js +192 -0
- package/dist/cjs/value-object.js.map +1 -0
- package/dist/esm/aggregate-changes.d.ts +206 -0
- package/dist/esm/aggregate-changes.d.ts.map +1 -0
- package/dist/{aggregate-changes.js → esm/aggregate-changes.js} +1 -1
- package/dist/esm/aggregate-changes.js.map +1 -0
- package/dist/esm/base-entity.d.ts +91 -0
- package/dist/esm/base-entity.d.ts.map +1 -0
- package/dist/{base-entity.js → esm/base-entity.js} +5 -5
- package/dist/esm/base-entity.js.map +1 -0
- package/dist/esm/change-tracker.d.ts +98 -0
- package/dist/esm/change-tracker.d.ts.map +1 -0
- package/dist/{change-tracker.js → esm/change-tracker.js} +4 -4
- package/dist/esm/change-tracker.js.map +1 -0
- package/dist/esm/constants.d.ts +9 -0
- package/dist/esm/constants.d.ts.map +1 -0
- package/dist/esm/constants.js.map +1 -0
- package/dist/esm/criteria.d.ts +62 -0
- package/dist/esm/criteria.d.ts.map +1 -0
- package/dist/{criteria.js → esm/criteria.js} +3 -3
- package/dist/esm/criteria.js.map +1 -0
- package/dist/esm/crypto.d.ts +3 -0
- package/dist/esm/crypto.d.ts.map +1 -0
- package/dist/esm/crypto.js.map +1 -0
- package/dist/esm/domain-event-bus.d.ts +56 -0
- package/dist/esm/domain-event-bus.d.ts.map +1 -0
- package/dist/esm/domain-event-bus.js.map +1 -0
- package/dist/esm/domain-event.d.ts +25 -0
- package/dist/esm/domain-event.d.ts.map +1 -0
- package/dist/{domain-event.js → esm/domain-event.js} +1 -1
- package/dist/esm/domain-event.js.map +1 -0
- package/dist/esm/entity-changes.d.ts +84 -0
- package/dist/esm/entity-changes.d.ts.map +1 -0
- package/dist/esm/entity-changes.js.map +1 -0
- package/dist/esm/entity-schema-registry.d.ts +282 -0
- package/dist/esm/entity-schema-registry.d.ts.map +1 -0
- package/dist/{entity-schema-registry.js → esm/entity-schema-registry.js} +5 -5
- package/dist/esm/entity-schema-registry.js.map +1 -0
- package/dist/esm/entity.d.ts +7 -0
- package/dist/esm/entity.d.ts.map +1 -0
- package/dist/{entity.js → esm/entity.js} +1 -1
- package/dist/esm/entity.js.map +1 -0
- package/dist/esm/exceptions.d.ts +251 -0
- package/dist/esm/exceptions.d.ts.map +1 -0
- package/dist/esm/exceptions.js.map +1 -0
- package/dist/esm/id.d.ts +52 -0
- package/dist/esm/id.d.ts.map +1 -0
- package/dist/{id.js → esm/id.js} +1 -1
- package/dist/esm/id.js.map +1 -0
- package/dist/esm/index.d.ts +17 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +16 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/mapper.d.ts +4 -0
- package/dist/esm/mapper.d.ts.map +1 -0
- package/dist/esm/mapper.js.map +1 -0
- package/dist/esm/package.json +3 -0
- package/dist/esm/paginated-result.d.ts +62 -0
- package/dist/esm/paginated-result.d.ts.map +1 -0
- package/dist/{paginated-result.js → esm/paginated-result.js} +1 -1
- package/dist/esm/paginated-result.js.map +1 -0
- package/dist/esm/repository/base-repository.d.ts +28 -0
- package/dist/esm/repository/base-repository.d.ts.map +1 -0
- package/dist/esm/repository/base-repository.js.map +1 -0
- package/dist/esm/repository/index.d.ts +4 -0
- package/dist/esm/repository/index.d.ts.map +1 -0
- package/dist/esm/repository/index.js +4 -0
- package/dist/esm/repository/index.js.map +1 -0
- package/dist/esm/repository/unit-of-work.d.ts +34 -0
- package/dist/esm/repository/unit-of-work.d.ts.map +1 -0
- package/dist/esm/repository/unit-of-work.js.map +1 -0
- package/dist/esm/types/change-tracker.d.ts +226 -0
- package/dist/esm/types/change-tracker.d.ts.map +1 -0
- package/dist/esm/types/change-tracker.js.map +1 -0
- package/dist/esm/types/criteria.d.ts +60 -0
- package/dist/esm/types/criteria.d.ts.map +1 -0
- package/dist/esm/types/criteria.js.map +1 -0
- package/dist/esm/types/domain-event.d.ts +32 -0
- package/dist/esm/types/domain-event.d.ts.map +1 -0
- package/dist/esm/types/domain-event.js.map +1 -0
- package/dist/esm/types/domain.d.ts +29 -0
- package/dist/esm/types/domain.d.ts.map +1 -0
- package/dist/esm/types/domain.js.map +1 -0
- package/dist/esm/types/index.d.ts +8 -0
- package/dist/esm/types/index.d.ts.map +1 -0
- package/dist/esm/types/index.js +8 -0
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/types/standard-schema.d.ts +15 -0
- package/dist/esm/types/standard-schema.d.ts.map +1 -0
- package/dist/esm/types/standard-schema.js.map +1 -0
- package/dist/esm/types/unit-of-work.d.ts +39 -0
- package/dist/esm/types/unit-of-work.d.ts.map +1 -0
- package/dist/esm/types/unit-of-work.js.map +1 -0
- package/dist/esm/types/utils.d.ts +13 -0
- package/dist/esm/types/utils.d.ts.map +1 -0
- package/dist/esm/types/utils.js.map +1 -0
- package/dist/esm/utils/criteria-operator-validation.d.ts +6 -0
- package/dist/esm/utils/criteria-operator-validation.d.ts.map +1 -0
- package/dist/{utils → esm/utils}/criteria-operator-validation.js +1 -1
- package/dist/esm/utils/criteria-operator-validation.js.map +1 -0
- package/dist/esm/utils/helpers.d.ts +3 -0
- package/dist/esm/utils/helpers.d.ts.map +1 -0
- package/dist/esm/utils/helpers.js.map +1 -0
- package/dist/esm/validation-error.d.ts +56 -0
- package/dist/esm/validation-error.d.ts.map +1 -0
- package/dist/esm/validation-error.js.map +1 -0
- package/dist/esm/value-object.d.ts +96 -0
- package/dist/esm/value-object.d.ts.map +1 -0
- package/dist/{value-object.js → esm/value-object.js} +3 -3
- package/dist/esm/value-object.js.map +1 -0
- package/dist/tsconfig.cjs.tsbuildinfo +1 -0
- package/dist/tsconfig.esm.tsbuildinfo +1 -0
- package/dist/tsconfig.types.tsbuildinfo +1 -0
- package/dist/types/aggregate-changes.d.ts +206 -0
- package/dist/types/aggregate-changes.d.ts.map +1 -0
- package/dist/types/base-entity.d.ts +91 -0
- package/dist/types/base-entity.d.ts.map +1 -0
- package/dist/types/change-tracker.d.ts +90 -218
- package/dist/types/change-tracker.d.ts.map +1 -1
- package/dist/types/constants.d.ts +9 -0
- package/dist/types/constants.d.ts.map +1 -0
- package/dist/types/criteria.d.ts +59 -57
- package/dist/types/criteria.d.ts.map +1 -1
- package/dist/types/crypto.d.ts +3 -0
- package/dist/types/crypto.d.ts.map +1 -0
- package/dist/types/domain-event-bus.d.ts +56 -0
- package/dist/types/domain-event-bus.d.ts.map +1 -0
- package/dist/types/domain-event.d.ts +14 -21
- package/dist/types/domain-event.d.ts.map +1 -1
- package/dist/types/entity-changes.d.ts +84 -0
- package/dist/types/entity-changes.d.ts.map +1 -0
- package/dist/types/entity-schema-registry.d.ts +282 -0
- package/dist/types/entity-schema-registry.d.ts.map +1 -0
- package/dist/types/entity.d.ts +7 -0
- package/dist/types/entity.d.ts.map +1 -0
- package/dist/types/exceptions.d.ts +251 -0
- package/dist/types/exceptions.d.ts.map +1 -0
- package/dist/types/id.d.ts +52 -0
- package/dist/types/id.d.ts.map +1 -0
- package/dist/types/index.d.ts +16 -7
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/mapper.d.ts +4 -0
- package/dist/types/mapper.d.ts.map +1 -0
- package/dist/types/paginated-result.d.ts +62 -0
- package/dist/types/paginated-result.d.ts.map +1 -0
- package/dist/types/repository/base-repository.d.ts +28 -0
- package/dist/types/repository/base-repository.d.ts.map +1 -0
- package/dist/types/repository/index.d.ts +4 -0
- package/dist/types/repository/index.d.ts.map +1 -0
- package/dist/types/repository/unit-of-work.d.ts +34 -0
- package/dist/types/repository/unit-of-work.d.ts.map +1 -0
- package/dist/types/types/change-tracker.d.ts +226 -0
- package/dist/types/types/change-tracker.d.ts.map +1 -0
- package/dist/types/types/criteria.d.ts +60 -0
- package/dist/types/types/criteria.d.ts.map +1 -0
- package/dist/types/types/domain-event.d.ts +32 -0
- package/dist/types/types/domain-event.d.ts.map +1 -0
- package/dist/types/types/domain.d.ts +29 -0
- package/dist/types/types/domain.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +8 -0
- package/dist/types/types/index.d.ts.map +1 -0
- package/dist/types/types/standard-schema.d.ts +15 -0
- package/dist/types/types/standard-schema.d.ts.map +1 -0
- package/dist/types/types/unit-of-work.d.ts +39 -0
- package/dist/types/types/unit-of-work.d.ts.map +1 -0
- package/dist/types/types/utils.d.ts +13 -0
- package/dist/types/types/utils.d.ts.map +1 -0
- package/dist/types/utils/criteria-operator-validation.d.ts +6 -0
- package/dist/types/utils/criteria-operator-validation.d.ts.map +1 -0
- package/dist/types/utils/helpers.d.ts +3 -0
- package/dist/types/utils/helpers.d.ts.map +1 -0
- package/dist/types/validation-error.d.ts +56 -0
- package/dist/types/validation-error.d.ts.map +1 -0
- package/dist/types/value-object.d.ts +96 -0
- package/dist/types/value-object.d.ts.map +1 -0
- package/package.json +13 -8
- package/dist/aggregate-changes.d.ts.map +0 -1
- package/dist/aggregate-changes.js.map +0 -1
- package/dist/base-entity.d.ts.map +0 -1
- package/dist/base-entity.js.map +0 -1
- package/dist/change-tracker.d.ts.map +0 -1
- package/dist/change-tracker.js.map +0 -1
- package/dist/constants.d.ts.map +0 -1
- package/dist/constants.js.map +0 -1
- package/dist/criteria.d.ts.map +0 -1
- package/dist/crypto.d.ts.map +0 -1
- package/dist/crypto.js.map +0 -1
- package/dist/domain-event-bus.d.ts.map +0 -1
- package/dist/domain-event-bus.js.map +0 -1
- package/dist/domain-event.d.ts.map +0 -1
- package/dist/domain-event.js.map +0 -1
- package/dist/entity-changes.d.ts.map +0 -1
- package/dist/entity-changes.js.map +0 -1
- package/dist/entity-schema-registry.d.ts.map +0 -1
- package/dist/entity-schema-registry.js.map +0 -1
- package/dist/entity.d.ts.map +0 -1
- package/dist/entity.js.map +0 -1
- package/dist/exceptions.d.ts.map +0 -1
- package/dist/exceptions.js.map +0 -1
- package/dist/id.d.ts.map +0 -1
- package/dist/id.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -16
- package/dist/index.js.map +0 -1
- package/dist/mapper.d.ts.map +0 -1
- package/dist/mapper.js.map +0 -1
- package/dist/paginated-result.d.ts.map +0 -1
- package/dist/paginated-result.js.map +0 -1
- package/dist/repository/base-repository.d.ts.map +0 -1
- package/dist/repository/base-repository.js.map +0 -1
- package/dist/repository/index.d.ts +0 -4
- package/dist/repository/index.d.ts.map +0 -1
- package/dist/repository/index.js +0 -4
- package/dist/repository/index.js.map +0 -1
- package/dist/repository/unit-of-work.d.ts.map +0 -1
- package/dist/repository/unit-of-work.js.map +0 -1
- package/dist/types/change-tracker.js.map +0 -1
- package/dist/types/criteria.js.map +0 -1
- package/dist/types/domain.d.ts.map +0 -1
- package/dist/types/index.js +0 -8
- package/dist/types/index.js.map +0 -1
- package/dist/types/standard-schema.d.ts.map +0 -1
- package/dist/types/standard-schema.js.map +0 -1
- package/dist/types/unit-of-work.d.ts.map +0 -1
- package/dist/types/utils.d.ts.map +0 -1
- package/dist/utils/criteria-operator-validation.d.ts.map +0 -1
- package/dist/utils/criteria-operator-validation.js.map +0 -1
- package/dist/utils/helpers.d.ts.map +0 -1
- package/dist/utils/helpers.js.map +0 -1
- package/dist/validation-error.d.ts.map +0 -1
- package/dist/validation-error.js.map +0 -1
- package/dist/value-object.d.ts.map +0 -1
- package/dist/value-object.js.map +0 -1
- /package/dist/{constants.d.ts → cjs/constants.d.ts} +0 -0
- /package/dist/{crypto.d.ts → cjs/crypto.d.ts} +0 -0
- /package/dist/{domain-event-bus.d.ts → cjs/domain-event-bus.d.ts} +0 -0
- /package/dist/{exceptions.d.ts → cjs/exceptions.d.ts} +0 -0
- /package/dist/{id.d.ts → cjs/id.d.ts} +0 -0
- /package/dist/{mapper.d.ts → cjs/mapper.d.ts} +0 -0
- /package/dist/{types → cjs/types}/standard-schema.d.ts +0 -0
- /package/dist/{utils → cjs/utils}/helpers.d.ts +0 -0
- /package/dist/{validation-error.d.ts → cjs/validation-error.d.ts} +0 -0
- /package/dist/{constants.js → esm/constants.js} +0 -0
- /package/dist/{crypto.js → esm/crypto.js} +0 -0
- /package/dist/{domain-event-bus.js → esm/domain-event-bus.js} +0 -0
- /package/dist/{entity-changes.js → esm/entity-changes.js} +0 -0
- /package/dist/{exceptions.js → esm/exceptions.js} +0 -0
- /package/dist/{mapper.js → esm/mapper.js} +0 -0
- /package/dist/{repository → esm/repository}/base-repository.js +0 -0
- /package/dist/{repository → esm/repository}/unit-of-work.js +0 -0
- /package/dist/{types → esm/types}/change-tracker.js +0 -0
- /package/dist/{types → esm/types}/criteria.js +0 -0
- /package/dist/{types → esm/types}/domain-event.js +0 -0
- /package/dist/{types → esm/types}/domain.js +0 -0
- /package/dist/{types → esm/types}/standard-schema.js +0 -0
- /package/dist/{types → esm/types}/unit-of-work.js +0 -0
- /package/dist/{types → esm/types}/utils.js +0 -0
- /package/dist/{utils → esm/utils}/helpers.js +0 -0
- /package/dist/{validation-error.js → esm/validation-error.js} +0 -0
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { IDomainEvent, DomainEventHandler, IDomainEventHandler } from ".";
|
|
2
|
+
type EventConstructor<T extends IDomainEvent = IDomainEvent> = new (...args: any[]) => T;
|
|
3
|
+
/**
|
|
4
|
+
* Domain Event Bus - Singleton pattern for event pub/sub
|
|
5
|
+
*/
|
|
6
|
+
export declare class DomainEventBus {
|
|
7
|
+
private static instance;
|
|
8
|
+
private handlers;
|
|
9
|
+
private wildcardHandlers;
|
|
10
|
+
private constructor();
|
|
11
|
+
/**
|
|
12
|
+
* Get the singleton instance
|
|
13
|
+
*/
|
|
14
|
+
static getInstance(): DomainEventBus;
|
|
15
|
+
/**
|
|
16
|
+
* Subscribe to a specific event type
|
|
17
|
+
*/
|
|
18
|
+
subscribe<T extends IDomainEvent>(props: {
|
|
19
|
+
event: EventConstructor<T> | string;
|
|
20
|
+
handler: DomainEventHandler<T> | IDomainEventHandler<T>;
|
|
21
|
+
}): void;
|
|
22
|
+
/**
|
|
23
|
+
* Subscribe to all events (wildcard)
|
|
24
|
+
*/
|
|
25
|
+
subscribeAll(handler: DomainEventHandler<IDomainEvent> | IDomainEventHandler<IDomainEvent>): void;
|
|
26
|
+
/**
|
|
27
|
+
* Unsubscribe from a specific event type
|
|
28
|
+
*/
|
|
29
|
+
unsubscribe<T extends IDomainEvent>(eventType: EventConstructor<T> | string, handler: DomainEventHandler<T> | IDomainEventHandler<T>): void;
|
|
30
|
+
/**
|
|
31
|
+
* Unsubscribe from all events
|
|
32
|
+
*/
|
|
33
|
+
unsubscribeAll(handler: DomainEventHandler<IDomainEvent> | IDomainEventHandler<IDomainEvent>): void;
|
|
34
|
+
/**
|
|
35
|
+
* Publish a single event
|
|
36
|
+
*/
|
|
37
|
+
publish<T extends IDomainEvent>(event: T): Promise<void>;
|
|
38
|
+
/**
|
|
39
|
+
* Publish multiple events
|
|
40
|
+
*/
|
|
41
|
+
publishAll(events: IDomainEvent[]): Promise<void>;
|
|
42
|
+
/**
|
|
43
|
+
* Clear all handlers (useful for testing)
|
|
44
|
+
*/
|
|
45
|
+
clearAllHandlers(): void;
|
|
46
|
+
/**
|
|
47
|
+
* Get count of handlers for an event type
|
|
48
|
+
*/
|
|
49
|
+
getHandlerCount(eventType: EventConstructor | string): number;
|
|
50
|
+
/**
|
|
51
|
+
* Execute a handler (function or class)
|
|
52
|
+
*/
|
|
53
|
+
private executeHandler;
|
|
54
|
+
}
|
|
55
|
+
export {};
|
|
56
|
+
//# sourceMappingURL=domain-event-bus.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"domain-event-bus.d.ts","sourceRoot":"","sources":["../../src/domain-event-bus.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,GAAG,CAAC;AAE1E,KAAK,gBAAgB,CAAC,CAAC,SAAS,YAAY,GAAG,YAAY,IAAI,KAC7D,GAAG,IAAI,EAAE,GAAG,EAAE,KACX,CAAC,CAAC;AAEP;;GAEG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAiB;IACxC,OAAO,CAAC,QAAQ,CAGF;IACd,OAAO,CAAC,gBAAgB,CAEV;IAEd,OAAO;IAEP;;OAEG;IACH,MAAM,CAAC,WAAW,IAAI,cAAc;IAOpC;;OAEG;IACH,SAAS,CAAC,CAAC,SAAS,YAAY,EAAE,KAAK,EAAE;QACvC,KAAK,EAAE,gBAAgB,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QACpC,OAAO,EAAE,kBAAkB,CAAC,CAAC,CAAC,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;KACzD,GAAG,IAAI;IAWR;;OAEG;IACH,YAAY,CACV,OAAO,EACH,kBAAkB,CAAC,YAAY,CAAC,GAChC,mBAAmB,CAAC,YAAY,CAAC,GACpC,IAAI;IAIP;;OAEG;IACH,WAAW,CAAC,CAAC,SAAS,YAAY,EAChC,SAAS,EAAE,gBAAgB,CAAC,CAAC,CAAC,GAAG,MAAM,EACvC,OAAO,EAAE,kBAAkB,CAAC,CAAC,CAAC,GAAG,mBAAmB,CAAC,CAAC,CAAC,GACtD,IAAI;IAaP;;OAEG;IACH,cAAc,CACZ,OAAO,EACH,kBAAkB,CAAC,YAAY,CAAC,GAChC,mBAAmB,CAAC,YAAY,CAAC,GACpC,IAAI;IAIP;;OAEG;IACG,OAAO,CAAC,CAAC,SAAS,YAAY,EAAE,KAAK,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAiB9D;;OAEG;IACG,UAAU,CAAC,MAAM,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAIvD;;OAEG;IACH,gBAAgB,IAAI,IAAI;IAKxB;;OAEG;IACH,eAAe,CAAC,SAAS,EAAE,gBAAgB,GAAG,MAAM,GAAG,MAAM;IAM7D;;OAEG;YACW,cAAc;CAe7B"}
|
|
@@ -1,32 +1,25 @@
|
|
|
1
|
+
import { IDomainEvent } from ".";
|
|
2
|
+
import { Id } from "./id.js";
|
|
1
3
|
/**
|
|
2
|
-
*
|
|
4
|
+
* Base class for domain events
|
|
3
5
|
*/
|
|
4
|
-
export
|
|
5
|
-
/**
|
|
6
|
-
* Unique identifier for this event occurrence
|
|
7
|
-
*/
|
|
6
|
+
export declare abstract class DomainEvent implements IDomainEvent {
|
|
8
7
|
readonly eventId: string;
|
|
8
|
+
readonly occurredOn: Date;
|
|
9
|
+
readonly aggregateId: string;
|
|
10
|
+
constructor(aggregateId: Id | string);
|
|
9
11
|
/**
|
|
10
|
-
*
|
|
12
|
+
* Get the event name (defaults to class name)
|
|
11
13
|
*/
|
|
12
|
-
|
|
14
|
+
get eventName(): string;
|
|
15
|
+
private generateEventId;
|
|
13
16
|
/**
|
|
14
|
-
*
|
|
17
|
+
* Convert event to JSON
|
|
15
18
|
*/
|
|
16
|
-
|
|
19
|
+
toJSON(): Record<string, any>;
|
|
17
20
|
/**
|
|
18
|
-
*
|
|
21
|
+
* Override this to provide event-specific data
|
|
19
22
|
*/
|
|
20
|
-
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Event handler function type
|
|
24
|
-
*/
|
|
25
|
-
export type DomainEventHandler<T extends IDomainEvent = IDomainEvent> = (event: T) => void | Promise<void>;
|
|
26
|
-
/**
|
|
27
|
-
* Event handler class type
|
|
28
|
-
*/
|
|
29
|
-
export interface IDomainEventHandler<T extends IDomainEvent = IDomainEvent> {
|
|
30
|
-
handle(event: T): void | Promise<void>;
|
|
23
|
+
protected getPayload(): Record<string, any>;
|
|
31
24
|
}
|
|
32
25
|
//# sourceMappingURL=domain-event.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"domain-event.d.ts","sourceRoot":"","sources":["../../src/
|
|
1
|
+
{"version":3,"file":"domain-event.d.ts","sourceRoot":"","sources":["../../src/domain-event.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,GAAG,CAAC;AACjC,OAAO,EAAE,EAAE,EAAE,MAAM,SAAS,CAAC;AAE7B;;GAEG;AACH,8BAAsB,WAAY,YAAW,YAAY;IACvD,SAAgB,OAAO,EAAE,MAAM,CAAC;IAChC,SAAgB,UAAU,EAAE,IAAI,CAAC;IACjC,SAAgB,WAAW,EAAE,MAAM,CAAC;gBAExB,WAAW,EAAE,EAAE,GAAG,MAAM;IAOpC;;OAEG;IACH,IAAI,SAAS,IAAI,MAAM,CAEtB;IAED,OAAO,CAAC,eAAe;IAIvB;;OAEG;IACH,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAU7B;;OAEG;IACH,SAAS,CAAC,UAAU,IAAI,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;CAG5C"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Operation } from "./types/change-tracker.js";
|
|
2
|
+
/**
|
|
3
|
+
* Represents the changes filtered for a specific entity.
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* ```typescript
|
|
7
|
+
* const changes = user.getChanges();
|
|
8
|
+
* const postChanges = changes.for('Post');
|
|
9
|
+
*
|
|
10
|
+
* if (postChanges.hasCreates()) {
|
|
11
|
+
* console.log('Created posts:', postChanges.creates);
|
|
12
|
+
* }
|
|
13
|
+
*
|
|
14
|
+
* if (postChanges.hasUpdates()) {
|
|
15
|
+
* postChanges.updates.forEach(({ entity, changed }) => {
|
|
16
|
+
* console.log(`Post ${entity.id} has changed:`, changed);
|
|
17
|
+
* });
|
|
18
|
+
* }
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
export declare class EntityChanges<T = any> {
|
|
22
|
+
private readonly operations;
|
|
23
|
+
constructor(operations: Operation<T>[]);
|
|
24
|
+
/**
|
|
25
|
+
* Returns all created entities
|
|
26
|
+
*/
|
|
27
|
+
get creates(): T[];
|
|
28
|
+
/**
|
|
29
|
+
* Returns all updated entities with their changed fields
|
|
30
|
+
*/
|
|
31
|
+
get updates(): Array<{
|
|
32
|
+
entity: T;
|
|
33
|
+
changed: Record<string, any>;
|
|
34
|
+
}>;
|
|
35
|
+
/**
|
|
36
|
+
* Returns all deleted entities
|
|
37
|
+
*/
|
|
38
|
+
get deletes(): T[];
|
|
39
|
+
/**
|
|
40
|
+
* Returns the IDs of the created entities
|
|
41
|
+
*/
|
|
42
|
+
get createIds(): string[];
|
|
43
|
+
/**
|
|
44
|
+
* Returns the IDs of the updated entities
|
|
45
|
+
*/
|
|
46
|
+
get updateIds(): string[];
|
|
47
|
+
/**
|
|
48
|
+
* Returns the IDs of the deleted entities
|
|
49
|
+
*/
|
|
50
|
+
get deleteIds(): string[];
|
|
51
|
+
/**
|
|
52
|
+
* Checks if there are any creates
|
|
53
|
+
*/
|
|
54
|
+
hasCreates(): boolean;
|
|
55
|
+
/**
|
|
56
|
+
* Checks if there are any updates
|
|
57
|
+
*/
|
|
58
|
+
hasUpdates(): boolean;
|
|
59
|
+
/**
|
|
60
|
+
* Checks if there are any deletes
|
|
61
|
+
*/
|
|
62
|
+
hasDeletes(): boolean;
|
|
63
|
+
/**
|
|
64
|
+
* Checks if there is any change
|
|
65
|
+
*/
|
|
66
|
+
hasChanges(): boolean;
|
|
67
|
+
/**
|
|
68
|
+
* Checks if it is empty (no changes)
|
|
69
|
+
*/
|
|
70
|
+
isEmpty(): boolean;
|
|
71
|
+
/**
|
|
72
|
+
* Returns the total number of operations
|
|
73
|
+
*/
|
|
74
|
+
get count(): number;
|
|
75
|
+
/**
|
|
76
|
+
* Returns the raw operations (for advanced use cases)
|
|
77
|
+
*/
|
|
78
|
+
get rawOperations(): Operation<T>[];
|
|
79
|
+
/**
|
|
80
|
+
* Extracts the ID from an entity
|
|
81
|
+
*/
|
|
82
|
+
private extractId;
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=entity-changes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"entity-changes.d.ts","sourceRoot":"","sources":["../../src/entity-changes.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAIV,MAAM,2BAA2B,CAAC;AAEnC;;;;;;;;;;;;;;;;;;GAkBG;AACH,qBAAa,aAAa,CAAC,CAAC,GAAG,GAAG;IACpB,OAAO,CAAC,QAAQ,CAAC,UAAU;gBAAV,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE;IAEvD;;OAEG;IACH,IAAI,OAAO,IAAI,CAAC,EAAE,CAIjB;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,KAAK,CAAC;QAAE,MAAM,EAAE,CAAC,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;KAAE,CAAC,CAOhE;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,CAAC,EAAE,CAIjB;IAED;;OAEG;IACH,IAAI,SAAS,IAAI,MAAM,EAAE,CAKxB;IAED;;OAEG;IACH,IAAI,SAAS,IAAI,MAAM,EAAE,CAIxB;IAED;;OAEG;IACH,IAAI,SAAS,IAAI,MAAM,EAAE,CAIxB;IAED;;OAEG;IACH,UAAU,IAAI,OAAO;IAIrB;;OAEG;IACH,UAAU,IAAI,OAAO;IAIrB;;OAEG;IACH,UAAU,IAAI,OAAO;IAIrB;;OAEG;IACH,UAAU,IAAI,OAAO;IAIrB;;OAEG;IACH,OAAO,IAAI,OAAO;IAIlB;;OAEG;IACH,IAAI,KAAK,IAAI,MAAM,CAElB;IAED;;OAEG;IACH,IAAI,aAAa,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,CAElC;IAED;;OAEG;IACH,OAAO,CAAC,SAAS;CAMlB"}
|
|
@@ -0,0 +1,282 @@
|
|
|
1
|
+
import { Entity } from "./entity.js";
|
|
2
|
+
import { ValueObject } from "./value-object.js";
|
|
3
|
+
/**
|
|
4
|
+
* Type of collection relationship.
|
|
5
|
+
* - 'owned': Parent owns the children (1:N). Delete parent = delete children.
|
|
6
|
+
* - 'reference': Parent references existing entities (N:N). Delete parent = unlink only.
|
|
7
|
+
*/
|
|
8
|
+
export type CollectionType = "owned" | "reference";
|
|
9
|
+
/**
|
|
10
|
+
* Configuration for a collection (1:N or N:N relationship).
|
|
11
|
+
*/
|
|
12
|
+
export interface CollectionConfig {
|
|
13
|
+
/**
|
|
14
|
+
* Type of relationship.
|
|
15
|
+
* - 'owned': Children are created/deleted with the parent (default for 1:N)
|
|
16
|
+
* - 'reference': Only the link is created/removed (for N:N)
|
|
17
|
+
* @default 'owned'
|
|
18
|
+
*/
|
|
19
|
+
type: CollectionType;
|
|
20
|
+
/**
|
|
21
|
+
* Target entity name (required for 'reference' type).
|
|
22
|
+
* @example 'Tag'
|
|
23
|
+
*/
|
|
24
|
+
entity?: string;
|
|
25
|
+
/**
|
|
26
|
+
* Junction table configuration (optional, for ORMs that need it like Drizzle).
|
|
27
|
+
* Prisma handles this automatically, so it's optional.
|
|
28
|
+
*/
|
|
29
|
+
junction?: {
|
|
30
|
+
/** Junction table name (e.g., 'post_tags', '_PostToTag') */
|
|
31
|
+
table: string;
|
|
32
|
+
/** FK field pointing to the source entity (e.g., 'post_id') */
|
|
33
|
+
sourceKey: string;
|
|
34
|
+
/** FK field pointing to the target entity (e.g., 'tag_id') */
|
|
35
|
+
targetKey: string;
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Mapping schema for a domain entity.
|
|
40
|
+
*/
|
|
41
|
+
export interface EntitySchema {
|
|
42
|
+
/** Entity name in the domain (e.g., 'User', 'Post') */
|
|
43
|
+
entity: string;
|
|
44
|
+
/** Table name in the database (e.g., 'users', 'blog_posts') */
|
|
45
|
+
table: string;
|
|
46
|
+
/**
|
|
47
|
+
* Field mapping: domain → database.
|
|
48
|
+
* Only include fields with different names.
|
|
49
|
+
* @example { email: 'user_email', createdAt: 'created_at' }
|
|
50
|
+
*/
|
|
51
|
+
fields?: Record<string, string>;
|
|
52
|
+
/**
|
|
53
|
+
* FK configuration for parent relation (1:N owned).
|
|
54
|
+
*/
|
|
55
|
+
parentFk?: {
|
|
56
|
+
/** Name of the FK field in the database (e.g., 'author_id') */
|
|
57
|
+
field: string;
|
|
58
|
+
/** Name of the parent entity (e.g., 'User') */
|
|
59
|
+
parentEntity: string;
|
|
60
|
+
};
|
|
61
|
+
/**
|
|
62
|
+
* Collection configurations for this entity's relations.
|
|
63
|
+
* Key is the property name in the domain entity.
|
|
64
|
+
* @example
|
|
65
|
+
* ```typescript
|
|
66
|
+
* collections: {
|
|
67
|
+
* comments: { type: 'owned' },
|
|
68
|
+
* tags: { type: 'reference', entity: 'Tag' }
|
|
69
|
+
* }
|
|
70
|
+
* ```
|
|
71
|
+
*/
|
|
72
|
+
collections?: Record<string, CollectionConfig>;
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Result of entity mapping.
|
|
76
|
+
*/
|
|
77
|
+
export interface MappedEntityData {
|
|
78
|
+
[key: string]: any;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Registry for mapping domain entities to database tables and fields.
|
|
82
|
+
*
|
|
83
|
+
* @example
|
|
84
|
+
* ```typescript
|
|
85
|
+
* const registry = new EntitySchemaRegistry()
|
|
86
|
+
* .register({
|
|
87
|
+
* entity: 'User',
|
|
88
|
+
* table: 'users',
|
|
89
|
+
* fields: { email: 'user_email', name: 'user_name' },
|
|
90
|
+
* })
|
|
91
|
+
* .register({
|
|
92
|
+
* entity: 'Post',
|
|
93
|
+
* table: 'blog_posts',
|
|
94
|
+
* fields: { content: 'post_content' },
|
|
95
|
+
* parentFk: { field: 'author_id', parentEntity: 'User' },
|
|
96
|
+
* collections: {
|
|
97
|
+
* comments: { type: 'owned' },
|
|
98
|
+
* tags: { type: 'reference', entity: 'Tag' }
|
|
99
|
+
* }
|
|
100
|
+
* });
|
|
101
|
+
*
|
|
102
|
+
* const table = registry.getTable('Post'); // 'blog_posts'
|
|
103
|
+
* const tagConfig = registry.getCollectionConfig('Post', 'tags');
|
|
104
|
+
* // { type: 'reference', entity: 'Tag' }
|
|
105
|
+
* ```
|
|
106
|
+
*/
|
|
107
|
+
export declare class EntitySchemaRegistry {
|
|
108
|
+
private schemas;
|
|
109
|
+
/**
|
|
110
|
+
* Registers an entity schema.
|
|
111
|
+
* @param schema - Schema to be registered.
|
|
112
|
+
* @returns this (for chaining)
|
|
113
|
+
*/
|
|
114
|
+
register(schema: EntitySchema): this;
|
|
115
|
+
/**
|
|
116
|
+
* Registers multiple schemas at once.
|
|
117
|
+
* @param schemas - Array of schemas.
|
|
118
|
+
* @returns this (for chaining)
|
|
119
|
+
*/
|
|
120
|
+
registerAll(schemas: EntitySchema[]): this;
|
|
121
|
+
/**
|
|
122
|
+
* Gets the schema of an entity.
|
|
123
|
+
* @param entity - Entity name.
|
|
124
|
+
* @throws Error if the entity is not registered.
|
|
125
|
+
*/
|
|
126
|
+
getSchema(entity: string): EntitySchema;
|
|
127
|
+
/**
|
|
128
|
+
* Gets all registered schemas.
|
|
129
|
+
*/
|
|
130
|
+
getAllSchemas(): EntitySchema[];
|
|
131
|
+
/**
|
|
132
|
+
* Tries to get the schema of an entity, returns null if not found.
|
|
133
|
+
* @param entity - Entity name.
|
|
134
|
+
*/
|
|
135
|
+
tryGetSchema(entity: string): EntitySchema | null;
|
|
136
|
+
/**
|
|
137
|
+
* Checks if an entity is registered.
|
|
138
|
+
* @param entity - Entity name.
|
|
139
|
+
*/
|
|
140
|
+
has(entity: string): boolean;
|
|
141
|
+
/**
|
|
142
|
+
* Gets the table name for an entity.
|
|
143
|
+
* @param entity - Entity name.
|
|
144
|
+
*/
|
|
145
|
+
getTable(entity: string): string;
|
|
146
|
+
/**
|
|
147
|
+
* Gets the field mapping for an entity.
|
|
148
|
+
* @param entity - Entity name.
|
|
149
|
+
*/
|
|
150
|
+
getFieldsMap(entity: string): Record<string, string>;
|
|
151
|
+
/**
|
|
152
|
+
* Maps a domain field name to the database field name.
|
|
153
|
+
* @param entity - Entity name.
|
|
154
|
+
* @param fieldName - Domain field name.
|
|
155
|
+
*/
|
|
156
|
+
mapFieldName(entity: string, fieldName: string): string;
|
|
157
|
+
/**
|
|
158
|
+
* Maps fields of a domain object to database field names.
|
|
159
|
+
* Ignores values that are Entity, ValueObject, or Arrays.
|
|
160
|
+
*
|
|
161
|
+
* @param entity - Entity name.
|
|
162
|
+
* @param data - Data to be mapped.
|
|
163
|
+
*/
|
|
164
|
+
mapFields(entity: string, data: Record<string, any>): MappedEntityData;
|
|
165
|
+
/**
|
|
166
|
+
* Maps a complete domain entity to database data.
|
|
167
|
+
* Used for CREATE operations.
|
|
168
|
+
*
|
|
169
|
+
* @param entity - Entity name.
|
|
170
|
+
* @param domainEntity - Domain entity instance.
|
|
171
|
+
*/
|
|
172
|
+
mapEntity(entity: string, domainEntity: Entity<any> | ValueObject<any>): MappedEntityData;
|
|
173
|
+
/**
|
|
174
|
+
* Gets the FK object to relate with the parent.
|
|
175
|
+
*
|
|
176
|
+
* @param entity - Entity name.
|
|
177
|
+
* @param parentId - Parent ID.
|
|
178
|
+
* @returns Object with the FK field or null if there is no parent.
|
|
179
|
+
*/
|
|
180
|
+
getParentFk(entity: string, parentId: string): Record<string, string> | null;
|
|
181
|
+
/**
|
|
182
|
+
* Gets the name of the parent entity.
|
|
183
|
+
* @param entity - Entity name.
|
|
184
|
+
*/
|
|
185
|
+
getParentEntity(entity: string): string | null;
|
|
186
|
+
/**
|
|
187
|
+
* Gets the FK field name.
|
|
188
|
+
* @param entity - Entity name.
|
|
189
|
+
*/
|
|
190
|
+
getParentFkField(entity: string): string | null;
|
|
191
|
+
/**
|
|
192
|
+
* Gets the collection configuration for a specific field.
|
|
193
|
+
*
|
|
194
|
+
* @param entity - Parent entity name (e.g., 'Post')
|
|
195
|
+
* @param fieldName - Collection field name (e.g., 'tags')
|
|
196
|
+
* @returns CollectionConfig or null if not configured
|
|
197
|
+
*
|
|
198
|
+
* @example
|
|
199
|
+
* ```typescript
|
|
200
|
+
* const config = registry.getCollectionConfig('Post', 'tags');
|
|
201
|
+
* if (config?.type === 'reference') {
|
|
202
|
+
* // Handle N:N relation - use connect/disconnect
|
|
203
|
+
* } else {
|
|
204
|
+
* // Handle 1:N relation - use create/delete
|
|
205
|
+
* }
|
|
206
|
+
* ```
|
|
207
|
+
*/
|
|
208
|
+
getCollectionConfig(entity: string, fieldName: string): CollectionConfig | null;
|
|
209
|
+
/**
|
|
210
|
+
* Checks if a collection is a reference type (N:N).
|
|
211
|
+
*
|
|
212
|
+
* @param entity - Parent entity name
|
|
213
|
+
* @param fieldName - Collection field name
|
|
214
|
+
* @returns true if the collection is a reference (N:N), false otherwise
|
|
215
|
+
*
|
|
216
|
+
* @example
|
|
217
|
+
* ```typescript
|
|
218
|
+
* if (registry.isReferenceCollection('Post', 'tags')) {
|
|
219
|
+
* // Use connect/disconnect instead of create/delete
|
|
220
|
+
* }
|
|
221
|
+
* ```
|
|
222
|
+
*/
|
|
223
|
+
isReferenceCollection(entity: string, fieldName: string): boolean;
|
|
224
|
+
/**
|
|
225
|
+
* Checks if a collection is owned (1:N).
|
|
226
|
+
* Returns true if explicitly configured as 'owned' or if not configured at all.
|
|
227
|
+
*
|
|
228
|
+
* @param entity - Parent entity name
|
|
229
|
+
* @param fieldName - Collection field name
|
|
230
|
+
* @returns true if the collection is owned (1:N), false if reference
|
|
231
|
+
*/
|
|
232
|
+
isOwnedCollection(entity: string, fieldName: string): boolean;
|
|
233
|
+
/**
|
|
234
|
+
* Gets all collections configured for an entity.
|
|
235
|
+
*
|
|
236
|
+
* @param entity - Entity name
|
|
237
|
+
* @returns Record of field names to collection configs, or empty object
|
|
238
|
+
*/
|
|
239
|
+
getCollections(entity: string): Record<string, CollectionConfig>;
|
|
240
|
+
/**
|
|
241
|
+
* Gets all reference (N:N) collections for an entity.
|
|
242
|
+
*
|
|
243
|
+
* @param entity - Entity name
|
|
244
|
+
* @returns Array of field names that are reference collections
|
|
245
|
+
*/
|
|
246
|
+
getReferenceCollections(entity: string): string[];
|
|
247
|
+
/**
|
|
248
|
+
* Gets the junction table configuration for a reference collection.
|
|
249
|
+
*
|
|
250
|
+
* @param entity - Parent entity name
|
|
251
|
+
* @param fieldName - Collection field name
|
|
252
|
+
* @returns Junction config or null
|
|
253
|
+
*/
|
|
254
|
+
getJunctionConfig(entity: string, fieldName: string): CollectionConfig["junction"] | null;
|
|
255
|
+
/**
|
|
256
|
+
* Lists all registered entities.
|
|
257
|
+
*/
|
|
258
|
+
getRegisteredEntities(): string[];
|
|
259
|
+
/**
|
|
260
|
+
* Clears all registered schemas.
|
|
261
|
+
*/
|
|
262
|
+
clear(): void;
|
|
263
|
+
/**
|
|
264
|
+
* Checks if a value is Entity, ValueObject, or Array.
|
|
265
|
+
*/
|
|
266
|
+
private isEntityOrCollection;
|
|
267
|
+
/**
|
|
268
|
+
* Normalizes a value for persistence.
|
|
269
|
+
*/
|
|
270
|
+
private normalizeValue;
|
|
271
|
+
/**
|
|
272
|
+
* Validates that a relation field exists in the entity's collections.
|
|
273
|
+
*
|
|
274
|
+
* @param entity - Parent entity name
|
|
275
|
+
* @param relationField - Relation field to validate
|
|
276
|
+
* @throws ConfigurationError if the field doesn't exist
|
|
277
|
+
*
|
|
278
|
+
*/
|
|
279
|
+
validateRelationField(entity: string, relationField: string): void;
|
|
280
|
+
private findSimilarNames;
|
|
281
|
+
}
|
|
282
|
+
//# sourceMappingURL=entity-schema-registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"entity-schema-registry.d.ts","sourceRoot":"","sources":["../../src/entity-schema-registry.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { BaseEntity } from "./base-entity.js";
|
|
2
|
+
import { BaseProps } from "./types/index.js";
|
|
3
|
+
export declare class Entity<T extends BaseProps> extends BaseEntity<T> {
|
|
4
|
+
}
|
|
5
|
+
export declare class Aggregate<T extends BaseProps> extends BaseEntity<T> {
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=entity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"entity.d.ts","sourceRoot":"","sources":["../../src/entity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,qBAAa,MAAM,CAAC,CAAC,SAAS,SAAS,CAAE,SAAQ,UAAU,CAAC,CAAC,CAAC;CAAG;AACjE,qBAAa,SAAS,CAAC,CAAC,SAAS,SAAS,CAAE,SAAQ,UAAU,CAAC,CAAC,CAAC;CAAG"}
|