@monorise/core 1.0.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/configs/service.config.ts +14 -0
- package/constants/table.ts +3 -0
- package/controllers/entity/create-entity.controller.ts +51 -0
- package/controllers/entity/delete-entity.controller.ts +35 -0
- package/controllers/entity/entity.http +62 -0
- package/controllers/entity/get-entity.controller.ts +33 -0
- package/controllers/entity/list-entities.controller.ts +69 -0
- package/controllers/entity/update-entity.controller.ts +56 -0
- package/controllers/entity/upsert-entity.controller.ts +97 -0
- package/controllers/mutual/create-mutual.controller.ts +89 -0
- package/controllers/mutual/delete-mutual.controller.ts +40 -0
- package/controllers/mutual/get-mutual.controller.ts +38 -0
- package/controllers/mutual/list-entities-by-entity.controller.ts +76 -0
- package/controllers/mutual/mutual.http +88 -0
- package/controllers/mutual/update-mutual.controller.ts +50 -0
- package/controllers/setupRoutes.ts +73 -0
- package/controllers/tag/list-tags.controller.ts +57 -0
- package/data/DbUtils.ts +40 -0
- package/data/Entity.ts +499 -0
- package/data/EventUtils.ts +47 -0
- package/data/FileObject.ts +16 -0
- package/data/Mutual.ts +779 -0
- package/data/ProjectionExpression.ts +8 -0
- package/data/Tag.ts +470 -0
- package/data/abstract/Item.base.ts +19 -0
- package/data/abstract/Repository.base.ts +92 -0
- package/dist/configs/service.config.d.ts +5 -0
- package/dist/configs/service.config.d.ts.map +1 -0
- package/dist/configs/service.config.js +5 -0
- package/dist/configs/service.config.js.map +1 -0
- package/dist/constants/table.d.ts +4 -0
- package/dist/constants/table.d.ts.map +1 -0
- package/dist/constants/table.js +4 -0
- package/dist/constants/table.js.map +1 -0
- package/dist/controllers/entity/create-entity.controller.d.ts +8 -0
- package/dist/controllers/entity/create-entity.controller.d.ts.map +1 -0
- package/dist/controllers/entity/create-entity.controller.js +44 -0
- package/dist/controllers/entity/create-entity.controller.js.map +1 -0
- package/dist/controllers/entity/delete-entity.controller.d.ts +8 -0
- package/dist/controllers/entity/delete-entity.controller.d.ts.map +1 -0
- package/dist/controllers/entity/delete-entity.controller.js +29 -0
- package/dist/controllers/entity/delete-entity.controller.js.map +1 -0
- package/dist/controllers/entity/get-entity.controller.d.ts +8 -0
- package/dist/controllers/entity/get-entity.controller.d.ts.map +1 -0
- package/dist/controllers/entity/get-entity.controller.js +24 -0
- package/dist/controllers/entity/get-entity.controller.js.map +1 -0
- package/dist/controllers/entity/list-entities.controller.d.ts +8 -0
- package/dist/controllers/entity/list-entities.controller.d.ts.map +1 -0
- package/dist/controllers/entity/list-entities.controller.js +56 -0
- package/dist/controllers/entity/list-entities.controller.js.map +1 -0
- package/dist/controllers/entity/update-entity.controller.d.ts +8 -0
- package/dist/controllers/entity/update-entity.controller.d.ts.map +1 -0
- package/dist/controllers/entity/update-entity.controller.js +45 -0
- package/dist/controllers/entity/update-entity.controller.js.map +1 -0
- package/dist/controllers/entity/upsert-entity.controller.d.ts +10 -0
- package/dist/controllers/entity/upsert-entity.controller.d.ts.map +1 -0
- package/dist/controllers/entity/upsert-entity.controller.js +73 -0
- package/dist/controllers/entity/upsert-entity.controller.js.map +1 -0
- package/dist/controllers/mutual/create-mutual.controller.d.ts +10 -0
- package/dist/controllers/mutual/create-mutual.controller.d.ts.map +1 -0
- package/dist/controllers/mutual/create-mutual.controller.js +70 -0
- package/dist/controllers/mutual/create-mutual.controller.js.map +1 -0
- package/dist/controllers/mutual/delete-mutual.controller.d.ts +8 -0
- package/dist/controllers/mutual/delete-mutual.controller.d.ts.map +1 -0
- package/dist/controllers/mutual/delete-mutual.controller.js +31 -0
- package/dist/controllers/mutual/delete-mutual.controller.js.map +1 -0
- package/dist/controllers/mutual/get-mutual.controller.d.ts +8 -0
- package/dist/controllers/mutual/get-mutual.controller.d.ts.map +1 -0
- package/dist/controllers/mutual/get-mutual.controller.js +24 -0
- package/dist/controllers/mutual/get-mutual.controller.js.map +1 -0
- package/dist/controllers/mutual/list-entities-by-entity.controller.d.ts +8 -0
- package/dist/controllers/mutual/list-entities-by-entity.controller.d.ts.map +1 -0
- package/dist/controllers/mutual/list-entities-by-entity.controller.js +56 -0
- package/dist/controllers/mutual/list-entities-by-entity.controller.js.map +1 -0
- package/dist/controllers/mutual/update-mutual.controller.d.ts +8 -0
- package/dist/controllers/mutual/update-mutual.controller.d.ts.map +1 -0
- package/dist/controllers/mutual/update-mutual.controller.js +40 -0
- package/dist/controllers/mutual/update-mutual.controller.js.map +1 -0
- package/dist/controllers/setupRoutes.d.ts +4 -0
- package/dist/controllers/setupRoutes.d.ts.map +1 -0
- package/dist/controllers/setupRoutes.js +31 -0
- package/dist/controllers/setupRoutes.js.map +1 -0
- package/dist/controllers/tag/list-tags.controller.d.ts +8 -0
- package/dist/controllers/tag/list-tags.controller.d.ts.map +1 -0
- package/dist/controllers/tag/list-tags.controller.js +48 -0
- package/dist/controllers/tag/list-tags.controller.js.map +1 -0
- package/dist/data/DbUtils.d.ts +7 -0
- package/dist/data/DbUtils.d.ts.map +1 -0
- package/dist/data/DbUtils.js +23 -0
- package/dist/data/DbUtils.js.map +1 -0
- package/dist/data/Entity.d.ts +71 -0
- package/dist/data/Entity.d.ts.map +1 -0
- package/dist/data/Entity.js +358 -0
- package/dist/data/Entity.js.map +1 -0
- package/dist/data/EventUtils.d.ts +14 -0
- package/dist/data/EventUtils.d.ts.map +1 -0
- package/dist/data/EventUtils.js +34 -0
- package/dist/data/EventUtils.js.map +1 -0
- package/dist/data/FileObject.d.ts +62 -0
- package/dist/data/FileObject.d.ts.map +1 -0
- package/dist/data/FileObject.js +13 -0
- package/dist/data/FileObject.js.map +1 -0
- package/dist/data/Mutual.d.ts +94 -0
- package/dist/data/Mutual.d.ts.map +1 -0
- package/dist/data/Mutual.js +492 -0
- package/dist/data/Mutual.js.map +1 -0
- package/dist/data/ProjectionExpression.d.ts +6 -0
- package/dist/data/ProjectionExpression.d.ts.map +1 -0
- package/dist/data/ProjectionExpression.js +5 -0
- package/dist/data/ProjectionExpression.js.map +1 -0
- package/dist/data/Tag.d.ts +77 -0
- package/dist/data/Tag.d.ts.map +1 -0
- package/dist/data/Tag.js +330 -0
- package/dist/data/Tag.js.map +1 -0
- package/dist/data/abstract/Item.base.d.ts +11 -0
- package/dist/data/abstract/Item.base.d.ts.map +1 -0
- package/dist/data/abstract/Item.base.js +9 -0
- package/dist/data/abstract/Item.base.js.map +1 -0
- package/dist/data/abstract/Repository.base.d.ts +11 -0
- package/dist/data/abstract/Repository.base.d.ts.map +1 -0
- package/dist/data/abstract/Repository.base.js +54 -0
- package/dist/data/abstract/Repository.base.js.map +1 -0
- package/dist/errors/api-error.d.ts +23 -0
- package/dist/errors/api-error.d.ts.map +1 -0
- package/dist/errors/api-error.js +26 -0
- package/dist/errors/api-error.js.map +1 -0
- package/dist/errors/extendable-error.d.ts +18 -0
- package/dist/errors/extendable-error.d.ts.map +1 -0
- package/dist/errors/extendable-error.js +22 -0
- package/dist/errors/extendable-error.js.map +1 -0
- package/dist/errors/standard-error.d.ts +11 -0
- package/dist/errors/standard-error.d.ts.map +1 -0
- package/dist/errors/standard-error.js +21 -0
- package/dist/errors/standard-error.js.map +1 -0
- package/dist/helpers/dependencies.d.ts +8 -0
- package/dist/helpers/dependencies.d.ts.map +1 -0
- package/dist/helpers/dependencies.js +10 -0
- package/dist/helpers/dependencies.js.map +1 -0
- package/dist/helpers/event.d.ts +22 -0
- package/dist/helpers/event.d.ts.map +1 -0
- package/dist/helpers/event.js +47 -0
- package/dist/helpers/event.js.map +1 -0
- package/dist/helpers/fromLastKeyQuery.d.ts +3 -0
- package/dist/helpers/fromLastKeyQuery.d.ts.map +1 -0
- package/dist/helpers/fromLastKeyQuery.js +7 -0
- package/dist/helpers/fromLastKeyQuery.js.map +1 -0
- package/dist/helpers/sleep.d.ts +2 -0
- package/dist/helpers/sleep.d.ts.map +1 -0
- package/dist/helpers/sleep.js +2 -0
- package/dist/helpers/sleep.js.map +1 -0
- package/dist/helpers/toLastKeyResponse.d.ts +3 -0
- package/dist/helpers/toLastKeyResponse.d.ts.map +1 -0
- package/dist/helpers/toLastKeyResponse.js +7 -0
- package/dist/helpers/toLastKeyResponse.js.map +1 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +12 -0
- package/dist/index.js.map +1 -0
- package/dist/middlewares/entity-type-check.d.ts +3 -0
- package/dist/middlewares/entity-type-check.d.ts.map +1 -0
- package/dist/middlewares/entity-type-check.js +12 -0
- package/dist/middlewares/entity-type-check.js.map +1 -0
- package/dist/middlewares/mutual-type-check.d.ts +3 -0
- package/dist/middlewares/mutual-type-check.d.ts.map +1 -0
- package/dist/middlewares/mutual-type-check.js +13 -0
- package/dist/middlewares/mutual-type-check.js.map +1 -0
- package/dist/mock/container.d.ts +3 -0
- package/dist/mock/container.d.ts.map +1 -0
- package/dist/mock/container.js +3 -0
- package/dist/mock/container.js.map +1 -0
- package/dist/mock/entity.d.ts +13 -0
- package/dist/mock/entity.d.ts.map +1 -0
- package/dist/mock/entity.js +14 -0
- package/dist/mock/entity.js.map +1 -0
- package/dist/mock/monorise/admin.d.ts +127 -0
- package/dist/mock/monorise/admin.d.ts.map +1 -0
- package/dist/mock/monorise/admin.js +29 -0
- package/dist/mock/monorise/admin.js.map +1 -0
- package/dist/mock/monorise/chapter.d.ts +457 -0
- package/dist/mock/monorise/chapter.d.ts.map +1 -0
- package/dist/mock/monorise/chapter.js +81 -0
- package/dist/mock/monorise/chapter.js.map +1 -0
- package/dist/mock/monorise/course.d.ts +311 -0
- package/dist/mock/monorise/course.d.ts.map +1 -0
- package/dist/mock/monorise/course.js +128 -0
- package/dist/mock/monorise/course.js.map +1 -0
- package/dist/mock/monorise/index.d.ts +3599 -0
- package/dist/mock/monorise/index.d.ts.map +1 -0
- package/dist/mock/monorise/index.js +62 -0
- package/dist/mock/monorise/index.js.map +1 -0
- package/dist/mock/monorise/learner.d.ts +390 -0
- package/dist/mock/monorise/learner.d.ts.map +1 -0
- package/dist/mock/monorise/learner.js +59 -0
- package/dist/mock/monorise/learner.js.map +1 -0
- package/dist/mock/monorise/learning-activity.d.ts +266 -0
- package/dist/mock/monorise/learning-activity.d.ts.map +1 -0
- package/dist/mock/monorise/learning-activity.js +50 -0
- package/dist/mock/monorise/learning-activity.js.map +1 -0
- package/dist/mock/monorise/learning-journey-config.d.ts +84 -0
- package/dist/mock/monorise/learning-journey-config.d.ts.map +1 -0
- package/dist/mock/monorise/learning-journey-config.js +27 -0
- package/dist/mock/monorise/learning-journey-config.js.map +1 -0
- package/dist/mock/monorise/module.d.ts +211 -0
- package/dist/mock/monorise/module.d.ts.map +1 -0
- package/dist/mock/monorise/module.js +91 -0
- package/dist/mock/monorise/module.js.map +1 -0
- package/dist/mock/monorise/organization.d.ts +346 -0
- package/dist/mock/monorise/organization.d.ts.map +1 -0
- package/dist/mock/monorise/organization.js +54 -0
- package/dist/mock/monorise/organization.js.map +1 -0
- package/dist/mock/monorise/reference.d.ts +171 -0
- package/dist/mock/monorise/reference.d.ts.map +1 -0
- package/dist/mock/monorise/reference.js +25 -0
- package/dist/mock/monorise/reference.js.map +1 -0
- package/dist/mock/monorise/video.d.ts +346 -0
- package/dist/mock/monorise/video.d.ts.map +1 -0
- package/dist/mock/monorise/video.js +33 -0
- package/dist/mock/monorise/video.js.map +1 -0
- package/dist/packages/core/configs/service.config.d.ts +5 -0
- package/dist/packages/core/configs/service.config.d.ts.map +1 -0
- package/dist/packages/core/configs/service.config.js +5 -0
- package/dist/packages/core/configs/service.config.js.map +1 -0
- package/dist/packages/core/constants/table.d.ts +4 -0
- package/dist/packages/core/constants/table.d.ts.map +1 -0
- package/dist/packages/core/constants/table.js +4 -0
- package/dist/packages/core/constants/table.js.map +1 -0
- package/dist/packages/core/controllers/entity/create-entity.controller.d.ts +8 -0
- package/dist/packages/core/controllers/entity/create-entity.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/entity/create-entity.controller.js +44 -0
- package/dist/packages/core/controllers/entity/create-entity.controller.js.map +1 -0
- package/dist/packages/core/controllers/entity/delete-entity.controller.d.ts +8 -0
- package/dist/packages/core/controllers/entity/delete-entity.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/entity/delete-entity.controller.js +29 -0
- package/dist/packages/core/controllers/entity/delete-entity.controller.js.map +1 -0
- package/dist/packages/core/controllers/entity/get-entity.controller.d.ts +8 -0
- package/dist/packages/core/controllers/entity/get-entity.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/entity/get-entity.controller.js +24 -0
- package/dist/packages/core/controllers/entity/get-entity.controller.js.map +1 -0
- package/dist/packages/core/controllers/entity/list-entities.controller.d.ts +8 -0
- package/dist/packages/core/controllers/entity/list-entities.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/entity/list-entities.controller.js +56 -0
- package/dist/packages/core/controllers/entity/list-entities.controller.js.map +1 -0
- package/dist/packages/core/controllers/entity/update-entity.controller.d.ts +8 -0
- package/dist/packages/core/controllers/entity/update-entity.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/entity/update-entity.controller.js +45 -0
- package/dist/packages/core/controllers/entity/update-entity.controller.js.map +1 -0
- package/dist/packages/core/controllers/entity/upsert-entity.controller.d.ts +10 -0
- package/dist/packages/core/controllers/entity/upsert-entity.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/entity/upsert-entity.controller.js +73 -0
- package/dist/packages/core/controllers/entity/upsert-entity.controller.js.map +1 -0
- package/dist/packages/core/controllers/mutual/create-mutual.controller.d.ts +10 -0
- package/dist/packages/core/controllers/mutual/create-mutual.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/mutual/create-mutual.controller.js +70 -0
- package/dist/packages/core/controllers/mutual/create-mutual.controller.js.map +1 -0
- package/dist/packages/core/controllers/mutual/delete-mutual.controller.d.ts +8 -0
- package/dist/packages/core/controllers/mutual/delete-mutual.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/mutual/delete-mutual.controller.js +31 -0
- package/dist/packages/core/controllers/mutual/delete-mutual.controller.js.map +1 -0
- package/dist/packages/core/controllers/mutual/get-mutual.controller.d.ts +8 -0
- package/dist/packages/core/controllers/mutual/get-mutual.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/mutual/get-mutual.controller.js +24 -0
- package/dist/packages/core/controllers/mutual/get-mutual.controller.js.map +1 -0
- package/dist/packages/core/controllers/mutual/list-entities-by-entity.controller.d.ts +8 -0
- package/dist/packages/core/controllers/mutual/list-entities-by-entity.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/mutual/list-entities-by-entity.controller.js +56 -0
- package/dist/packages/core/controllers/mutual/list-entities-by-entity.controller.js.map +1 -0
- package/dist/packages/core/controllers/mutual/update-mutual.controller.d.ts +8 -0
- package/dist/packages/core/controllers/mutual/update-mutual.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/mutual/update-mutual.controller.js +40 -0
- package/dist/packages/core/controllers/mutual/update-mutual.controller.js.map +1 -0
- package/dist/packages/core/controllers/setupRoutes.d.ts +3 -0
- package/dist/packages/core/controllers/setupRoutes.d.ts.map +1 -0
- package/dist/packages/core/controllers/setupRoutes.js +33 -0
- package/dist/packages/core/controllers/setupRoutes.js.map +1 -0
- package/dist/packages/core/controllers/tag/list-tags.controller.d.ts +8 -0
- package/dist/packages/core/controllers/tag/list-tags.controller.d.ts.map +1 -0
- package/dist/packages/core/controllers/tag/list-tags.controller.js +48 -0
- package/dist/packages/core/controllers/tag/list-tags.controller.js.map +1 -0
- package/dist/packages/core/data/DbUtils.d.ts +7 -0
- package/dist/packages/core/data/DbUtils.d.ts.map +1 -0
- package/dist/packages/core/data/DbUtils.js +23 -0
- package/dist/packages/core/data/DbUtils.js.map +1 -0
- package/dist/packages/core/data/Entity.d.ts +71 -0
- package/dist/packages/core/data/Entity.d.ts.map +1 -0
- package/dist/packages/core/data/Entity.js +358 -0
- package/dist/packages/core/data/Entity.js.map +1 -0
- package/dist/packages/core/data/EventUtils.d.ts +14 -0
- package/dist/packages/core/data/EventUtils.d.ts.map +1 -0
- package/dist/packages/core/data/EventUtils.js +34 -0
- package/dist/packages/core/data/EventUtils.js.map +1 -0
- package/dist/packages/core/data/FileObject.d.ts +62 -0
- package/dist/packages/core/data/FileObject.d.ts.map +1 -0
- package/dist/packages/core/data/FileObject.js +13 -0
- package/dist/packages/core/data/FileObject.js.map +1 -0
- package/dist/packages/core/data/Mutual.d.ts +94 -0
- package/dist/packages/core/data/Mutual.d.ts.map +1 -0
- package/dist/packages/core/data/Mutual.js +492 -0
- package/dist/packages/core/data/Mutual.js.map +1 -0
- package/dist/packages/core/data/ProjectionExpression.d.ts +6 -0
- package/dist/packages/core/data/ProjectionExpression.d.ts.map +1 -0
- package/dist/packages/core/data/ProjectionExpression.js +5 -0
- package/dist/packages/core/data/ProjectionExpression.js.map +1 -0
- package/dist/packages/core/data/Tag.d.ts +77 -0
- package/dist/packages/core/data/Tag.d.ts.map +1 -0
- package/dist/packages/core/data/Tag.js +330 -0
- package/dist/packages/core/data/Tag.js.map +1 -0
- package/dist/packages/core/data/abstract/Item.base.d.ts +11 -0
- package/dist/packages/core/data/abstract/Item.base.d.ts.map +1 -0
- package/dist/packages/core/data/abstract/Item.base.js +9 -0
- package/dist/packages/core/data/abstract/Item.base.js.map +1 -0
- package/dist/packages/core/data/abstract/Repository.base.d.ts +11 -0
- package/dist/packages/core/data/abstract/Repository.base.d.ts.map +1 -0
- package/dist/packages/core/data/abstract/Repository.base.js +54 -0
- package/dist/packages/core/data/abstract/Repository.base.js.map +1 -0
- package/dist/packages/core/errors/api-error.d.ts +23 -0
- package/dist/packages/core/errors/api-error.d.ts.map +1 -0
- package/dist/packages/core/errors/api-error.js +26 -0
- package/dist/packages/core/errors/api-error.js.map +1 -0
- package/dist/packages/core/errors/extendable-error.d.ts +18 -0
- package/dist/packages/core/errors/extendable-error.d.ts.map +1 -0
- package/dist/packages/core/errors/extendable-error.js +22 -0
- package/dist/packages/core/errors/extendable-error.js.map +1 -0
- package/dist/packages/core/errors/standard-error.d.ts +11 -0
- package/dist/packages/core/errors/standard-error.d.ts.map +1 -0
- package/dist/packages/core/errors/standard-error.js +21 -0
- package/dist/packages/core/errors/standard-error.js.map +1 -0
- package/dist/packages/core/helpers/dependencies.d.ts +8 -0
- package/dist/packages/core/helpers/dependencies.d.ts.map +1 -0
- package/dist/packages/core/helpers/dependencies.js +10 -0
- package/dist/packages/core/helpers/dependencies.js.map +1 -0
- package/dist/packages/core/helpers/event.d.ts +22 -0
- package/dist/packages/core/helpers/event.d.ts.map +1 -0
- package/dist/packages/core/helpers/event.js +47 -0
- package/dist/packages/core/helpers/event.js.map +1 -0
- package/dist/packages/core/helpers/fromLastKeyQuery.d.ts +3 -0
- package/dist/packages/core/helpers/fromLastKeyQuery.d.ts.map +1 -0
- package/dist/packages/core/helpers/fromLastKeyQuery.js +7 -0
- package/dist/packages/core/helpers/fromLastKeyQuery.js.map +1 -0
- package/dist/packages/core/helpers/sleep.d.ts +2 -0
- package/dist/packages/core/helpers/sleep.d.ts.map +1 -0
- package/dist/packages/core/helpers/sleep.js +2 -0
- package/dist/packages/core/helpers/sleep.js.map +1 -0
- package/dist/packages/core/helpers/toLastKeyResponse.d.ts +3 -0
- package/dist/packages/core/helpers/toLastKeyResponse.d.ts.map +1 -0
- package/dist/packages/core/helpers/toLastKeyResponse.js +7 -0
- package/dist/packages/core/helpers/toLastKeyResponse.js.map +1 -0
- package/dist/packages/core/index.d.ts +12 -0
- package/dist/packages/core/index.d.ts.map +1 -0
- package/dist/packages/core/index.js +12 -0
- package/dist/packages/core/index.js.map +1 -0
- package/dist/packages/core/middlewares/entity-type-check.d.ts +3 -0
- package/dist/packages/core/middlewares/entity-type-check.d.ts.map +1 -0
- package/dist/packages/core/middlewares/entity-type-check.js +12 -0
- package/dist/packages/core/middlewares/entity-type-check.js.map +1 -0
- package/dist/packages/core/middlewares/mutual-type-check.d.ts +3 -0
- package/dist/packages/core/middlewares/mutual-type-check.d.ts.map +1 -0
- package/dist/packages/core/middlewares/mutual-type-check.js +13 -0
- package/dist/packages/core/middlewares/mutual-type-check.js.map +1 -0
- package/dist/packages/core/mock/container.d.ts +3 -0
- package/dist/packages/core/mock/container.d.ts.map +1 -0
- package/dist/packages/core/mock/container.js +3 -0
- package/dist/packages/core/mock/container.js.map +1 -0
- package/dist/packages/core/mock/entity.d.ts +13 -0
- package/dist/packages/core/mock/entity.d.ts.map +1 -0
- package/dist/packages/core/mock/entity.js +14 -0
- package/dist/packages/core/mock/entity.js.map +1 -0
- package/dist/packages/core/mock/monorise/admin.d.ts +127 -0
- package/dist/packages/core/mock/monorise/admin.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/admin.js +29 -0
- package/dist/packages/core/mock/monorise/admin.js.map +1 -0
- package/dist/packages/core/mock/monorise/audio.d.ts +324 -0
- package/dist/packages/core/mock/monorise/audio.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/audio.js +32 -0
- package/dist/packages/core/mock/monorise/audio.js.map +1 -0
- package/dist/packages/core/mock/monorise/chapter.d.ts +457 -0
- package/dist/packages/core/mock/monorise/chapter.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/chapter.js +81 -0
- package/dist/packages/core/mock/monorise/chapter.js.map +1 -0
- package/dist/packages/core/mock/monorise/cohort-track.d.ts +118 -0
- package/dist/packages/core/mock/monorise/cohort-track.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/cohort-track.js +38 -0
- package/dist/packages/core/mock/monorise/cohort-track.js.map +1 -0
- package/dist/packages/core/mock/monorise/course-banner.d.ts +149 -0
- package/dist/packages/core/mock/monorise/course-banner.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/course-banner.js +24 -0
- package/dist/packages/core/mock/monorise/course-banner.js.map +1 -0
- package/dist/packages/core/mock/monorise/course.d.ts +311 -0
- package/dist/packages/core/mock/monorise/course.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/course.js +128 -0
- package/dist/packages/core/mock/monorise/course.js.map +1 -0
- package/dist/packages/core/mock/monorise/expert.d.ts +380 -0
- package/dist/packages/core/mock/monorise/expert.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/expert.js +32 -0
- package/dist/packages/core/mock/monorise/expert.js.map +1 -0
- package/dist/packages/core/mock/monorise/index.d.ts +3599 -0
- package/dist/packages/core/mock/monorise/index.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/index.js +62 -0
- package/dist/packages/core/mock/monorise/index.js.map +1 -0
- package/dist/packages/core/mock/monorise/learner-video-progress.d.ts +198 -0
- package/dist/packages/core/mock/monorise/learner-video-progress.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/learner-video-progress.js +21 -0
- package/dist/packages/core/mock/monorise/learner-video-progress.js.map +1 -0
- package/dist/packages/core/mock/monorise/learner.d.ts +390 -0
- package/dist/packages/core/mock/monorise/learner.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/learner.js +59 -0
- package/dist/packages/core/mock/monorise/learner.js.map +1 -0
- package/dist/packages/core/mock/monorise/learning-activity-submission.d.ts +160 -0
- package/dist/packages/core/mock/monorise/learning-activity-submission.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/learning-activity-submission.js +17 -0
- package/dist/packages/core/mock/monorise/learning-activity-submission.js.map +1 -0
- package/dist/packages/core/mock/monorise/learning-activity.d.ts +266 -0
- package/dist/packages/core/mock/monorise/learning-activity.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/learning-activity.js +50 -0
- package/dist/packages/core/mock/monorise/learning-activity.js.map +1 -0
- package/dist/packages/core/mock/monorise/learning-journey-config.d.ts +84 -0
- package/dist/packages/core/mock/monorise/learning-journey-config.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/learning-journey-config.js +27 -0
- package/dist/packages/core/mock/monorise/learning-journey-config.js.map +1 -0
- package/dist/packages/core/mock/monorise/learning-journey-progress.d.ts +290 -0
- package/dist/packages/core/mock/monorise/learning-journey-progress.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/learning-journey-progress.js +46 -0
- package/dist/packages/core/mock/monorise/learning-journey-progress.js.map +1 -0
- package/dist/packages/core/mock/monorise/module.d.ts +211 -0
- package/dist/packages/core/mock/monorise/module.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/module.js +91 -0
- package/dist/packages/core/mock/monorise/module.js.map +1 -0
- package/dist/packages/core/mock/monorise/organization.d.ts +346 -0
- package/dist/packages/core/mock/monorise/organization.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/organization.js +54 -0
- package/dist/packages/core/mock/monorise/organization.js.map +1 -0
- package/dist/packages/core/mock/monorise/pathway.d.ts +267 -0
- package/dist/packages/core/mock/monorise/pathway.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/pathway.js +221 -0
- package/dist/packages/core/mock/monorise/pathway.js.map +1 -0
- package/dist/packages/core/mock/monorise/phase.d.ts +580 -0
- package/dist/packages/core/mock/monorise/phase.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/phase.js +166 -0
- package/dist/packages/core/mock/monorise/phase.js.map +1 -0
- package/dist/packages/core/mock/monorise/reference.d.ts +171 -0
- package/dist/packages/core/mock/monorise/reference.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/reference.js +25 -0
- package/dist/packages/core/mock/monorise/reference.js.map +1 -0
- package/dist/packages/core/mock/monorise/track.d.ts +617 -0
- package/dist/packages/core/mock/monorise/track.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/track.js +270 -0
- package/dist/packages/core/mock/monorise/track.js.map +1 -0
- package/dist/packages/core/mock/monorise/video.d.ts +346 -0
- package/dist/packages/core/mock/monorise/video.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise/video.js +33 -0
- package/dist/packages/core/mock/monorise/video.js.map +1 -0
- package/dist/packages/core/mock/monorise.d.ts +6 -0
- package/dist/packages/core/mock/monorise.d.ts.map +1 -0
- package/dist/packages/core/mock/monorise.js +5 -0
- package/dist/packages/core/mock/monorise.js.map +1 -0
- package/dist/packages/core/processors/create-entity-processor.d.ts +5 -0
- package/dist/packages/core/processors/create-entity-processor.d.ts.map +1 -0
- package/dist/packages/core/processors/create-entity-processor.js +32 -0
- package/dist/packages/core/processors/create-entity-processor.js.map +1 -0
- package/dist/packages/core/processors/mutual-processor.d.ts +15 -0
- package/dist/packages/core/processors/mutual-processor.d.ts.map +1 -0
- package/dist/packages/core/processors/mutual-processor.js +128 -0
- package/dist/packages/core/processors/mutual-processor.js.map +1 -0
- package/dist/packages/core/processors/prejoin-processor.d.ts +12 -0
- package/dist/packages/core/processors/prejoin-processor.d.ts.map +1 -0
- package/dist/packages/core/processors/prejoin-processor.js +150 -0
- package/dist/packages/core/processors/prejoin-processor.js.map +1 -0
- package/dist/packages/core/processors/replication-processor.d.ts +8 -0
- package/dist/packages/core/processors/replication-processor.d.ts.map +1 -0
- package/dist/packages/core/processors/replication-processor.js +180 -0
- package/dist/packages/core/processors/replication-processor.js.map +1 -0
- package/dist/packages/core/processors/tag-processor.d.ts +11 -0
- package/dist/packages/core/processors/tag-processor.d.ts.map +1 -0
- package/dist/packages/core/processors/tag-processor.js +106 -0
- package/dist/packages/core/processors/tag-processor.js.map +1 -0
- package/dist/packages/core/services/DependencyContainer.d.ts +51 -0
- package/dist/packages/core/services/DependencyContainer.d.ts.map +1 -0
- package/dist/packages/core/services/DependencyContainer.js +115 -0
- package/dist/packages/core/services/DependencyContainer.js.map +1 -0
- package/dist/packages/core/services/entity-service-lifecycle.d.ts +12 -0
- package/dist/packages/core/services/entity-service-lifecycle.d.ts.map +1 -0
- package/dist/packages/core/services/entity-service-lifecycle.js +23 -0
- package/dist/packages/core/services/entity-service-lifecycle.js.map +1 -0
- package/dist/packages/core/services/entity.service.d.ts +32 -0
- package/dist/packages/core/services/entity.service.d.ts.map +1 -0
- package/dist/packages/core/services/entity.service.js +121 -0
- package/dist/packages/core/services/entity.service.js.map +1 -0
- package/dist/packages/core/services/mutual.service.d.ts +64 -0
- package/dist/packages/core/services/mutual.service.d.ts.map +1 -0
- package/dist/packages/core/services/mutual.service.js +144 -0
- package/dist/packages/core/services/mutual.service.js.map +1 -0
- package/dist/packages/core/types/entity.type.d.ts +20 -0
- package/dist/packages/core/types/entity.type.d.ts.map +1 -0
- package/dist/packages/core/types/entity.type.js +2 -0
- package/dist/packages/core/types/entity.type.js.map +1 -0
- package/dist/processors/create-entity-processor.d.ts +5 -0
- package/dist/processors/create-entity-processor.d.ts.map +1 -0
- package/dist/processors/create-entity-processor.js +33 -0
- package/dist/processors/create-entity-processor.js.map +1 -0
- package/dist/processors/mutual-processor.d.ts +15 -0
- package/dist/processors/mutual-processor.d.ts.map +1 -0
- package/dist/processors/mutual-processor.js +129 -0
- package/dist/processors/mutual-processor.js.map +1 -0
- package/dist/processors/prejoin-processor.d.ts +12 -0
- package/dist/processors/prejoin-processor.d.ts.map +1 -0
- package/dist/processors/prejoin-processor.js +151 -0
- package/dist/processors/prejoin-processor.js.map +1 -0
- package/dist/processors/replication-processor.d.ts +8 -0
- package/dist/processors/replication-processor.d.ts.map +1 -0
- package/dist/processors/replication-processor.js +181 -0
- package/dist/processors/replication-processor.js.map +1 -0
- package/dist/processors/tag-processor.d.ts +11 -0
- package/dist/processors/tag-processor.d.ts.map +1 -0
- package/dist/processors/tag-processor.js +107 -0
- package/dist/processors/tag-processor.js.map +1 -0
- package/dist/services/DependencyContainer.d.ts +51 -0
- package/dist/services/DependencyContainer.d.ts.map +1 -0
- package/dist/services/DependencyContainer.js +115 -0
- package/dist/services/DependencyContainer.js.map +1 -0
- package/dist/services/entity-service-lifecycle.d.ts +12 -0
- package/dist/services/entity-service-lifecycle.d.ts.map +1 -0
- package/dist/services/entity-service-lifecycle.js +23 -0
- package/dist/services/entity-service-lifecycle.js.map +1 -0
- package/dist/services/entity.service.d.ts +32 -0
- package/dist/services/entity.service.d.ts.map +1 -0
- package/dist/services/entity.service.js +121 -0
- package/dist/services/entity.service.js.map +1 -0
- package/dist/services/mutual.service.d.ts +64 -0
- package/dist/services/mutual.service.d.ts.map +1 -0
- package/dist/services/mutual.service.js +144 -0
- package/dist/services/mutual.service.js.map +1 -0
- package/dist/shared/types/event.d.ts +72 -0
- package/dist/shared/types/event.d.ts.map +1 -0
- package/dist/shared/types/event.js +74 -0
- package/dist/shared/types/event.js.map +1 -0
- package/dist/types/entity.type.d.ts +20 -0
- package/dist/types/entity.type.d.ts.map +1 -0
- package/dist/types/entity.type.js +2 -0
- package/dist/types/entity.type.js.map +1 -0
- package/dist/types/event.d.ts +72 -0
- package/dist/types/event.d.ts.map +1 -0
- package/dist/types/event.js +74 -0
- package/dist/types/event.js.map +1 -0
- package/errors/api-error.ts +39 -0
- package/errors/extendable-error.ts +35 -0
- package/errors/standard-error.ts +29 -0
- package/helpers/dependencies.ts +10 -0
- package/helpers/event.ts +85 -0
- package/helpers/fromLastKeyQuery.ts +11 -0
- package/helpers/sleep.ts +1 -0
- package/helpers/toLastKeyResponse.ts +11 -0
- package/index.ts +23 -0
- package/middlewares/entity-type-check.ts +20 -0
- package/middlewares/mutual-type-check.ts +26 -0
- package/mock/entity.ts +12 -0
- package/mock/monorise/admin.ts +35 -0
- package/mock/monorise/chapter.ts +94 -0
- package/mock/monorise/course.ts +149 -0
- package/mock/monorise/index.ts +143 -0
- package/mock/monorise/learner.ts +66 -0
- package/mock/monorise/learning-activity.ts +62 -0
- package/mock/monorise/learning-journey-config.ts +34 -0
- package/mock/monorise/module.ts +108 -0
- package/mock/monorise/organization.ts +63 -0
- package/mock/monorise/reference.ts +28 -0
- package/mock/monorise/video.ts +36 -0
- package/package.json +31 -0
- package/processors/create-entity-processor.ts +55 -0
- package/processors/mutual-processor.ts +262 -0
- package/processors/prejoin-processor.ts +264 -0
- package/processors/replication-processor.ts +261 -0
- package/processors/tag-processor.ts +174 -0
- package/services/DependencyContainer.ts +208 -0
- package/services/entity-service-lifecycle.ts +41 -0
- package/services/entity.service.ts +201 -0
- package/services/mutual.service.ts +285 -0
- package/tsconfig.json +118 -0
- package/types/entity.type.ts +62 -0
- package/types/event.ts +84 -0
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { parseSQSBusEvent } from '#/helpers/event';
|
|
2
|
+
import { container } from '#/lambda-layer/container';
|
|
3
|
+
import { EntityConfig } from '#/lambda-layer/monorise';
|
|
4
|
+
function compareTags(existingTags, newTags) {
|
|
5
|
+
const oldMap = new Map(existingTags.map((item) => [`${item.group}#${item.sortValue}`, item]));
|
|
6
|
+
const newMap = new Map(newTags.map((item) => [`${item.group}#${item.sortValue}`, item]));
|
|
7
|
+
const remain = [];
|
|
8
|
+
const oldDiff = [];
|
|
9
|
+
const newDiff = [];
|
|
10
|
+
for (const [key, oldItem] of oldMap.entries()) {
|
|
11
|
+
if (newMap.has(key)) {
|
|
12
|
+
remain.push(oldItem);
|
|
13
|
+
newMap.delete(key); // Remove from newMap as it's already in remain
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
oldDiff.push(oldItem);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
// Remaining entries in newMap are new
|
|
20
|
+
for (const newItem of newMap.values()) {
|
|
21
|
+
newDiff.push(newItem);
|
|
22
|
+
}
|
|
23
|
+
return {
|
|
24
|
+
old: oldDiff,
|
|
25
|
+
new: newDiff,
|
|
26
|
+
remain,
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
async function batchUpdateTags({ tagName, entity, diff, }) {
|
|
30
|
+
if (!entity.entityId) {
|
|
31
|
+
throw new Error('entityId is required');
|
|
32
|
+
}
|
|
33
|
+
const { old: tagsToRemove, new: tagsToAdd } = diff;
|
|
34
|
+
const { entityType, entityId } = entity;
|
|
35
|
+
const removePromises = tagsToRemove.reduce((acc, tag) => [
|
|
36
|
+
...acc,
|
|
37
|
+
container.tagRepository.deleteTag({
|
|
38
|
+
tagName,
|
|
39
|
+
group: tag.group,
|
|
40
|
+
sortValue: tag.sortValue,
|
|
41
|
+
entityType,
|
|
42
|
+
entityId,
|
|
43
|
+
}),
|
|
44
|
+
], []);
|
|
45
|
+
const addPromises = tagsToAdd.reduce((acc, tag) => [
|
|
46
|
+
...acc,
|
|
47
|
+
container.tagRepository.createTag({
|
|
48
|
+
tagName,
|
|
49
|
+
group: tag.group,
|
|
50
|
+
sortValue: tag.sortValue,
|
|
51
|
+
entity,
|
|
52
|
+
}),
|
|
53
|
+
], []);
|
|
54
|
+
await Promise.all([...removePromises, ...addPromises]);
|
|
55
|
+
}
|
|
56
|
+
export const handler = async (ev) => {
|
|
57
|
+
const batchItemFailures = [];
|
|
58
|
+
for (const record of ev.Records) {
|
|
59
|
+
const body = parseSQSBusEvent(record.body);
|
|
60
|
+
const { detail } = body;
|
|
61
|
+
const { entityType, entityId } = detail;
|
|
62
|
+
const errorContext = {};
|
|
63
|
+
errorContext.body = body;
|
|
64
|
+
try {
|
|
65
|
+
const tagConfigs = EntityConfig[entityType]?.tags;
|
|
66
|
+
if (!tagConfigs || !tagConfigs.length) {
|
|
67
|
+
// skip if entity has no tag configs
|
|
68
|
+
continue;
|
|
69
|
+
}
|
|
70
|
+
await container.tagRepository.createLock({
|
|
71
|
+
entityType,
|
|
72
|
+
entityId,
|
|
73
|
+
});
|
|
74
|
+
for (const tagConfig of tagConfigs) {
|
|
75
|
+
const { name, processor } = tagConfig;
|
|
76
|
+
const existingTags = await container.tagRepository.getExistingTags({
|
|
77
|
+
entityType,
|
|
78
|
+
entityId,
|
|
79
|
+
tagName: name,
|
|
80
|
+
});
|
|
81
|
+
errorContext.existingTags = existingTags;
|
|
82
|
+
const entity = await container.entityRepository.getEntity(entityType, entityId);
|
|
83
|
+
errorContext.entity = entity;
|
|
84
|
+
const newTags = await processor(entity);
|
|
85
|
+
errorContext.newTags = newTags;
|
|
86
|
+
const diff = compareTags(existingTags, newTags);
|
|
87
|
+
errorContext.diff = diff;
|
|
88
|
+
await batchUpdateTags({
|
|
89
|
+
tagName: name,
|
|
90
|
+
entity,
|
|
91
|
+
diff,
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
await container.tagRepository.deleteLock({
|
|
95
|
+
entityType,
|
|
96
|
+
entityId,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
catch (err) {
|
|
100
|
+
console.log('===TAG-PROCESSOR ERROR===', err, JSON.stringify({ errorContext }, null, 2));
|
|
101
|
+
batchItemFailures.push({ itemIdentifier: record.messageId });
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return { batchItemFailures };
|
|
105
|
+
};
|
|
106
|
+
//# sourceMappingURL=tag-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tag-processor.js","sourceRoot":"","sources":["../../../../processors/tag-processor.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AASvD,SAAS,WAAW,CAClB,YAAmB,EACnB,OAAc;IAMd,MAAM,MAAM,GAAG,IAAI,GAAG,CACpB,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,IAAI,CAAC,CAAC,CACtE,CAAC;IACF,MAAM,MAAM,GAAG,IAAI,GAAG,CACpB,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,IAAI,CAAC,CAAC,CACjE,CAAC;IAEF,MAAM,MAAM,GAAU,EAAE,CAAC;IACzB,MAAM,OAAO,GAAU,EAAE,CAAC;IAC1B,MAAM,OAAO,GAAU,EAAE,CAAC;IAE1B,KAAK,MAAM,CAAC,GAAG,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,EAAE,EAAE,CAAC;QAC9C,IAAI,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YACpB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACrB,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,+CAA+C;QACrE,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;IAED,sCAAsC;IACtC,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC;QACtC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxB,CAAC;IAED,OAAO;QACL,GAAG,EAAE,OAAO;QACZ,GAAG,EAAE,OAAO;QACZ,MAAM;KACP,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,eAAe,CAAC,EAC7B,OAAO,EACP,MAAM,EACN,IAAI,GAKL;IACC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACrB,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;IAC1C,CAAC;IAED,MAAM,EAAE,GAAG,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC;IACnD,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;IAExC,MAAM,cAAc,GAAG,YAAY,CAAC,MAAM,CACxC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC;QACZ,GAAG,GAAG;QACN,SAAS,CAAC,aAAa,CAAC,SAAS,CAAC;YAChC,OAAO;YACP,KAAK,EAAE,GAAG,CAAC,KAAK;YAChB,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,UAAU;YACV,QAAQ;SACT,CAAC;KACH,EACD,EAAoB,CACrB,CAAC;IAEF,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,CAClC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC;QACZ,GAAG,GAAG;QACN,SAAS,CAAC,aAAa,CAAC,SAAS,CAAC;YAChC,OAAO;YACP,KAAK,EAAE,GAAG,CAAC,KAAK;YAChB,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,MAAM;SACP,CAAC;KACH,EACD,EAAoB,CACrB,CAAC;IAEF,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,cAAc,EAAE,GAAG,WAAW,CAAC,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,EAAE,EAAY,EAAE,EAAE;IAC5C,MAAM,iBAAiB,GAA0B,EAAE,CAAC;IAEpD,KAAK,MAAM,MAAM,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;QAChC,MAAM,IAAI,GAAG,gBAAgB,CAAkB,MAAM,CAAC,IAAI,CAAC,CAAC;QAC5D,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;QACxB,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;QAExC,MAAM,YAAY,GAA4B,EAAE,CAAC;QACjD,YAAY,CAAC,IAAI,GAAG,IAAI,CAAC;QAEzB,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,YAAY,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC;YAElD,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;gBACtC,oCAAoC;gBACpC,SAAS;YACX,CAAC;YAED,MAAM,SAAS,CAAC,aAAa,CAAC,UAAU,CAAC;gBACvC,UAAU;gBACV,QAAQ;aACT,CAAC,CAAC;YAEH,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;gBACnC,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,GAAG,SAAS,CAAC;gBAEtC,MAAM,YAAY,GAAG,MAAM,SAAS,CAAC,aAAa,CAAC,eAAe,CAAC;oBACjE,UAAU;oBACV,QAAQ;oBACR,OAAO,EAAE,IAAI;iBACd,CAAC,CAAC;gBACH,YAAY,CAAC,YAAY,GAAG,YAAY,CAAC;gBAEzC,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,gBAAgB,CAAC,SAAS,CACvD,UAAU,EACV,QAAQ,CACT,CAAC;gBACF,YAAY,CAAC,MAAM,GAAG,MAAM,CAAC;gBAE7B,MAAM,OAAO,GAAG,MAAM,SAAS,CAC7B,MAA8C,CAC/C,CAAC;gBACF,YAAY,CAAC,OAAO,GAAG,OAAO,CAAC;gBAE/B,MAAM,IAAI,GAAG,WAAW,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;gBAChD,YAAY,CAAC,IAAI,GAAG,IAAI,CAAC;gBAEzB,MAAM,eAAe,CAAC;oBACpB,OAAO,EAAE,IAAI;oBACb,MAAM;oBACN,IAAI;iBACL,CAAC,CAAC;YACL,CAAC;YAED,MAAM,SAAS,CAAC,aAAa,CAAC,UAAU,CAAC;gBACvC,UAAU;gBACV,QAAQ;aACT,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,GAAG,CACT,2BAA2B,EAC3B,GAAG,EACH,IAAI,CAAC,SAAS,CAAC,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CAC1C,CAAC;YAEF,iBAAiB,CAAC,IAAI,CAAC,EAAE,cAAc,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;IAED,OAAO,EAAE,iBAAiB,EAAE,CAAC;AAC/B,CAAC,CAAC"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { DynamoDB } from '@aws-sdk/client-dynamodb';
|
|
2
|
+
import type { publishEvent as publishEventType } from '#/helpers/event';
|
|
3
|
+
import { DbUtils } from '#/data/DbUtils';
|
|
4
|
+
import { EntityRepository } from '#/data/Entity';
|
|
5
|
+
import { EventUtils } from '#/data/EventUtils';
|
|
6
|
+
import { MutualRepository } from '#/data/Mutual';
|
|
7
|
+
import { TagRepository } from '#/data/Tag';
|
|
8
|
+
import { CreateEntityController } from '#/controllers/entity/create-entity.controller';
|
|
9
|
+
import { DeleteEntityController } from '#/controllers/entity/delete-entity.controller';
|
|
10
|
+
import { GetEntityController } from '#/controllers/entity/get-entity.controller';
|
|
11
|
+
import { ListEntitiesController } from '#/controllers/entity/list-entities.controller';
|
|
12
|
+
import { UpdateEntityController } from '#/controllers/entity/update-entity.controller';
|
|
13
|
+
import { UpsertEntityController } from '#/controllers/entity/upsert-entity.controller';
|
|
14
|
+
import { CreateMutualController } from '#/controllers/mutual/create-mutual.controller';
|
|
15
|
+
import { DeleteMutualController } from '#/controllers/mutual/delete-mutual.controller';
|
|
16
|
+
import { GetMutualController } from '#/controllers/mutual/get-mutual.controller';
|
|
17
|
+
import { ListEntitiesByEntityController } from '#/controllers/mutual/list-entities-by-entity.controller';
|
|
18
|
+
import { UpdateMutualController } from '#/controllers/mutual/update-mutual.controller';
|
|
19
|
+
import { EntityService } from './entity.service';
|
|
20
|
+
import { MutualService } from './mutual.service';
|
|
21
|
+
import { ListTagsController } from '#/controllers/tag/list-tags.controller';
|
|
22
|
+
export declare class DependencyContainer {
|
|
23
|
+
private _instanceCache;
|
|
24
|
+
private _publishEvent;
|
|
25
|
+
private _tableName;
|
|
26
|
+
constructor(tableName: string);
|
|
27
|
+
createCachedInstance<T extends new (...args: any[]) => any>(ClassRef: T, ...args: ConstructorParameters<T>): InstanceType<T>;
|
|
28
|
+
get coreTable(): string;
|
|
29
|
+
get publishEvent(): typeof publishEventType;
|
|
30
|
+
get dynamodbClient(): DynamoDB;
|
|
31
|
+
get dbUtils(): DbUtils;
|
|
32
|
+
get eventUtils(): EventUtils;
|
|
33
|
+
get entityRepository(): EntityRepository;
|
|
34
|
+
get mutualRepository(): MutualRepository;
|
|
35
|
+
get entityService(): EntityService;
|
|
36
|
+
get mutualService(): MutualService;
|
|
37
|
+
get tagRepository(): TagRepository;
|
|
38
|
+
get getEntityController(): GetEntityController;
|
|
39
|
+
get listEntitiesController(): ListEntitiesController;
|
|
40
|
+
get createEntityController(): CreateEntityController;
|
|
41
|
+
get upsertEntityController(): UpsertEntityController;
|
|
42
|
+
get updateEntityController(): UpdateEntityController;
|
|
43
|
+
get deleteEntityController(): DeleteEntityController;
|
|
44
|
+
get listEntitiesByEntityController(): ListEntitiesByEntityController;
|
|
45
|
+
get getMutualController(): GetMutualController;
|
|
46
|
+
get createMutualController(): CreateMutualController;
|
|
47
|
+
get updateMutualController(): UpdateMutualController;
|
|
48
|
+
get deleteMutualController(): DeleteMutualController;
|
|
49
|
+
get listTagsController(): ListTagsController;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=DependencyContainer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DependencyContainer.d.ts","sourceRoot":"","sources":["../../../../services/DependencyContainer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAGpD,OAAO,KAAK,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAExE,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,mBAAmB,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,mBAAmB,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAE,8BAA8B,EAAE,MAAM,yDAAyD,CAAC;AACzG,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wCAAwC,CAAC;AAE5E,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,cAAc,CAAmB;IACzC,OAAO,CAAC,aAAa,CAAiC;IACtD,OAAO,CAAC,UAAU,CAAS;gBAEf,SAAS,EAAE,MAAM;IAM7B,oBAAoB,CAAC,CAAC,SAAS,KAAK,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,EACxD,QAAQ,EAAE,CAAC,EACX,GAAG,IAAI,EAAE,qBAAqB,CAAC,CAAC,CAAC,GAChC,YAAY,CAAC,CAAC,CAAC;IAYlB,IAAI,SAAS,IAAI,MAAM,CAKtB;IAED,IAAI,YAAY,IAAI,OAAO,gBAAgB,CAM1C;IAED,IAAI,cAAc,IAAI,QAAQ,CAE7B;IAED,IAAI,OAAO,IAAI,OAAO,CAErB;IAED,IAAI,UAAU,IAAI,UAAU,CAE3B;IAED,IAAI,gBAAgB,IAAI,gBAAgB,CAMvC;IAED,IAAI,gBAAgB,IAAI,gBAAgB,CAOvC;IAED,IAAI,aAAa,IAAI,aAAa,CAOjC;IAED,IAAI,aAAa,IAAI,aAAa,CASjC;IAED,IAAI,aAAa,IAAI,aAAa,CAMjC;IAED,IAAI,mBAAmB,IAAI,mBAAmB,CAK7C;IAED,IAAI,sBAAsB,IAAI,sBAAsB,CAKnD;IAED,IAAI,sBAAsB,IAAI,sBAAsB,CAKnD;IAED,IAAI,sBAAsB,IAAI,sBAAsB,CAMnD;IAED,IAAI,sBAAsB,IAAI,sBAAsB,CAKnD;IAED,IAAI,sBAAsB,IAAI,sBAAsB,CAKnD;IAED,IAAI,8BAA8B,IAAI,8BAA8B,CAKnE;IAED,IAAI,mBAAmB,IAAI,mBAAmB,CAK7C;IAED,IAAI,sBAAsB,IAAI,sBAAsB,CAMnD;IAED,IAAI,sBAAsB,IAAI,sBAAsB,CAKnD;IAED,IAAI,sBAAsB,IAAI,sBAAsB,CAKnD;IAED,IAAI,kBAAkB,IAAI,kBAAkB,CAE3C;CACF"}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { DynamoDB } from '@aws-sdk/client-dynamodb';
|
|
2
|
+
import { CORE_TABLE } from '#/configs/service.config';
|
|
3
|
+
import { getDependencies } from '#/helpers/dependencies';
|
|
4
|
+
import { DbUtils } from '#/data/DbUtils';
|
|
5
|
+
import { EntityRepository } from '#/data/Entity';
|
|
6
|
+
import { EventUtils } from '#/data/EventUtils';
|
|
7
|
+
import { MutualRepository } from '#/data/Mutual';
|
|
8
|
+
import { TagRepository } from '#/data/Tag';
|
|
9
|
+
import { CreateEntityController } from '#/controllers/entity/create-entity.controller';
|
|
10
|
+
import { DeleteEntityController } from '#/controllers/entity/delete-entity.controller';
|
|
11
|
+
import { GetEntityController } from '#/controllers/entity/get-entity.controller';
|
|
12
|
+
import { ListEntitiesController } from '#/controllers/entity/list-entities.controller';
|
|
13
|
+
import { UpdateEntityController } from '#/controllers/entity/update-entity.controller';
|
|
14
|
+
import { UpsertEntityController } from '#/controllers/entity/upsert-entity.controller';
|
|
15
|
+
import { CreateMutualController } from '#/controllers/mutual/create-mutual.controller';
|
|
16
|
+
import { DeleteMutualController } from '#/controllers/mutual/delete-mutual.controller';
|
|
17
|
+
import { GetMutualController } from '#/controllers/mutual/get-mutual.controller';
|
|
18
|
+
import { ListEntitiesByEntityController } from '#/controllers/mutual/list-entities-by-entity.controller';
|
|
19
|
+
import { UpdateMutualController } from '#/controllers/mutual/update-mutual.controller';
|
|
20
|
+
import { EntityService } from './entity.service';
|
|
21
|
+
import { MutualService } from './mutual.service';
|
|
22
|
+
import { ListTagsController } from '#/controllers/tag/list-tags.controller';
|
|
23
|
+
export class DependencyContainer {
|
|
24
|
+
_instanceCache;
|
|
25
|
+
_publishEvent;
|
|
26
|
+
_tableName;
|
|
27
|
+
constructor(tableName) {
|
|
28
|
+
this._instanceCache = new Map();
|
|
29
|
+
this._publishEvent = null;
|
|
30
|
+
this._tableName = tableName;
|
|
31
|
+
}
|
|
32
|
+
createCachedInstance(ClassRef, ...args) {
|
|
33
|
+
const cacheKey = ClassRef.name;
|
|
34
|
+
if (this._instanceCache.has(cacheKey)) {
|
|
35
|
+
return this._instanceCache.get(cacheKey);
|
|
36
|
+
}
|
|
37
|
+
const instance = new ClassRef(...args);
|
|
38
|
+
this._instanceCache.set(cacheKey, instance);
|
|
39
|
+
return instance;
|
|
40
|
+
}
|
|
41
|
+
get coreTable() {
|
|
42
|
+
if (this._tableName)
|
|
43
|
+
return this._tableName;
|
|
44
|
+
this._tableName = CORE_TABLE;
|
|
45
|
+
return this._tableName;
|
|
46
|
+
}
|
|
47
|
+
get publishEvent() {
|
|
48
|
+
// for non class based function you can still have your own way of constructing
|
|
49
|
+
if (this._publishEvent)
|
|
50
|
+
return this._publishEvent;
|
|
51
|
+
this._publishEvent = getDependencies().publishEvent;
|
|
52
|
+
return this._publishEvent;
|
|
53
|
+
}
|
|
54
|
+
get dynamodbClient() {
|
|
55
|
+
return this.createCachedInstance(DynamoDB);
|
|
56
|
+
}
|
|
57
|
+
get dbUtils() {
|
|
58
|
+
return this.createCachedInstance(DbUtils, this.dynamodbClient);
|
|
59
|
+
}
|
|
60
|
+
get eventUtils() {
|
|
61
|
+
return this.createCachedInstance(EventUtils, this.publishEvent);
|
|
62
|
+
}
|
|
63
|
+
get entityRepository() {
|
|
64
|
+
return this.createCachedInstance(EntityRepository, this.coreTable, this.dynamodbClient);
|
|
65
|
+
}
|
|
66
|
+
get mutualRepository() {
|
|
67
|
+
return this.createCachedInstance(MutualRepository, this.coreTable, this.dynamodbClient, this.dbUtils);
|
|
68
|
+
}
|
|
69
|
+
get entityService() {
|
|
70
|
+
return this.createCachedInstance(EntityService, this.entityRepository, this.publishEvent, this.eventUtils);
|
|
71
|
+
}
|
|
72
|
+
get mutualService() {
|
|
73
|
+
return this.createCachedInstance(MutualService, this.entityRepository, this.mutualRepository, this.publishEvent, this.eventUtils, this.dbUtils);
|
|
74
|
+
}
|
|
75
|
+
get tagRepository() {
|
|
76
|
+
return this.createCachedInstance(TagRepository, this.coreTable, this.dynamodbClient);
|
|
77
|
+
}
|
|
78
|
+
get getEntityController() {
|
|
79
|
+
return this.createCachedInstance(GetEntityController, this.entityRepository);
|
|
80
|
+
}
|
|
81
|
+
get listEntitiesController() {
|
|
82
|
+
return this.createCachedInstance(ListEntitiesController, this.entityRepository);
|
|
83
|
+
}
|
|
84
|
+
get createEntityController() {
|
|
85
|
+
return this.createCachedInstance(CreateEntityController, this.entityService);
|
|
86
|
+
}
|
|
87
|
+
get upsertEntityController() {
|
|
88
|
+
return this.createCachedInstance(UpsertEntityController, this.entityRepository, this.publishEvent);
|
|
89
|
+
}
|
|
90
|
+
get updateEntityController() {
|
|
91
|
+
return this.createCachedInstance(UpdateEntityController, this.entityService);
|
|
92
|
+
}
|
|
93
|
+
get deleteEntityController() {
|
|
94
|
+
return this.createCachedInstance(DeleteEntityController, this.entityService);
|
|
95
|
+
}
|
|
96
|
+
get listEntitiesByEntityController() {
|
|
97
|
+
return this.createCachedInstance(ListEntitiesByEntityController, this.mutualRepository);
|
|
98
|
+
}
|
|
99
|
+
get getMutualController() {
|
|
100
|
+
return this.createCachedInstance(GetMutualController, this.mutualRepository);
|
|
101
|
+
}
|
|
102
|
+
get createMutualController() {
|
|
103
|
+
return this.createCachedInstance(CreateMutualController, this.mutualService, this.publishEvent);
|
|
104
|
+
}
|
|
105
|
+
get updateMutualController() {
|
|
106
|
+
return this.createCachedInstance(UpdateMutualController, this.mutualService);
|
|
107
|
+
}
|
|
108
|
+
get deleteMutualController() {
|
|
109
|
+
return this.createCachedInstance(DeleteMutualController, this.mutualService);
|
|
110
|
+
}
|
|
111
|
+
get listTagsController() {
|
|
112
|
+
return this.createCachedInstance(ListTagsController, this.tagRepository);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
//# sourceMappingURL=DependencyContainer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DependencyContainer.js","sourceRoot":"","sources":["../../../../services/DependencyContainer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAGzD,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,mBAAmB,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,mBAAmB,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAE,8BAA8B,EAAE,MAAM,yDAAyD,CAAC;AACzG,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wCAAwC,CAAC;AAE5E,MAAM,OAAO,mBAAmB;IACtB,cAAc,CAAmB;IACjC,aAAa,CAAiC;IAC9C,UAAU,CAAS;IAE3B,YAAY,SAAiB;QAC3B,IAAI,CAAC,cAAc,GAAG,IAAI,GAAG,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAC9B,CAAC;IAED,oBAAoB,CAClB,QAAW,EACX,GAAG,IAA8B;QAEjC,MAAM,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC;QAE/B,IAAI,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YACtC,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAoB,CAAC;QAC9D,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,GAAG,IAAI,CAAC,CAAC;QACvC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC5C,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,UAAU;YAAE,OAAO,IAAI,CAAC,UAAU,CAAC;QAE5C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,YAAY;QACd,+EAA+E;QAC/E,IAAI,IAAI,CAAC,aAAa;YAAE,OAAO,IAAI,CAAC,aAAa,CAAC;QAElD,IAAI,CAAC,aAAa,GAAG,eAAe,EAAE,CAAC,YAAY,CAAC;QACpD,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IACjE,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAClE,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,gBAAgB,EAChB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,cAAc,CACpB,CAAC;IACJ,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,gBAAgB,EAChB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,OAAO,CACb,CAAC;IACJ,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,oBAAoB,CAC9B,aAAa,EACb,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,UAAU,CAChB,CAAC;IACJ,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,oBAAoB,CAC9B,aAAa,EACb,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,OAAO,CACb,CAAC;IACJ,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,oBAAoB,CAC9B,aAAa,EACb,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,cAAc,CACpB,CAAC;IACJ,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,mBAAmB,EACnB,IAAI,CAAC,gBAAgB,CACtB,CAAC;IACJ,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,sBAAsB,EACtB,IAAI,CAAC,gBAAgB,CACtB,CAAC;IACJ,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,sBAAsB,EACtB,IAAI,CAAC,aAAa,CACnB,CAAC;IACJ,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,sBAAsB,EACtB,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,YAAY,CAClB,CAAC;IACJ,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,sBAAsB,EACtB,IAAI,CAAC,aAAa,CACnB,CAAC;IACJ,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,sBAAsB,EACtB,IAAI,CAAC,aAAa,CACnB,CAAC;IACJ,CAAC;IAED,IAAI,8BAA8B;QAChC,OAAO,IAAI,CAAC,oBAAoB,CAC9B,8BAA8B,EAC9B,IAAI,CAAC,gBAAgB,CACtB,CAAC;IACJ,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,mBAAmB,EACnB,IAAI,CAAC,gBAAgB,CACtB,CAAC;IACJ,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,sBAAsB,EACtB,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,YAAY,CAClB,CAAC;IACJ,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,sBAAsB,EACtB,IAAI,CAAC,aAAa,CACnB,CAAC;IACJ,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAC9B,sBAAsB,EACtB,IAAI,CAAC,aAAa,CACnB,CAAC;IACJ,CAAC;IAED,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;IAC3E,CAAC;CACF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Entity as EntityType } from '@monorise/base';
|
|
2
|
+
import type { Entity } from '#/data/Entity';
|
|
3
|
+
import type { EventUtils } from '#/data/EventUtils';
|
|
4
|
+
import type { publishEvent as publishEventType } from '#/helpers/event';
|
|
5
|
+
export declare const afterCreateEntityHook: <T extends EntityType>({ entity, entityPayload, accountId, publishEvent, eventUtils, }: {
|
|
6
|
+
entity: Entity<T>;
|
|
7
|
+
entityPayload?: Record<string, unknown>;
|
|
8
|
+
accountId?: string | string[];
|
|
9
|
+
publishEvent: typeof publishEventType;
|
|
10
|
+
eventUtils: EventUtils;
|
|
11
|
+
}) => Promise<void>;
|
|
12
|
+
//# sourceMappingURL=entity-service-lifecycle.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"entity-service-lifecycle.d.ts","sourceRoot":"","sources":["../../../../services/entity-service-lifecycle.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,KAAK,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAIxE,eAAO,MAAM,qBAAqB,GAAU,CAAC,SAAS,UAAU,EAAE,iEAM/D;IACD,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;IAClB,aAAa,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACxC,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAC9B,YAAY,EAAE,OAAO,gBAAgB,CAAC;IACtC,UAAU,EAAE,UAAU,CAAC;CACxB,kBAqBA,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { EntityConfig } from '#/lambda-layer/monorise';
|
|
2
|
+
import { EVENT } from '#/shared/types/event';
|
|
3
|
+
export const afterCreateEntityHook = async ({ entity, entityPayload = {}, accountId, publishEvent, eventUtils, }) => {
|
|
4
|
+
const mutualSchema = EntityConfig[entity.entityType].mutual?.mutualSchema;
|
|
5
|
+
const parsedMutualPayload = mutualSchema?.parse(entityPayload);
|
|
6
|
+
if (parsedMutualPayload) {
|
|
7
|
+
await eventUtils.publishCreateMutualsEvent({
|
|
8
|
+
entity,
|
|
9
|
+
mutualPayload: parsedMutualPayload,
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
await publishEvent({
|
|
13
|
+
event: EVENT.CORE.ENTITY_CREATED,
|
|
14
|
+
payload: {
|
|
15
|
+
entityType: entity.entityType,
|
|
16
|
+
entityId: entity.entityId,
|
|
17
|
+
data: entity.data,
|
|
18
|
+
createdByAccountId: accountId,
|
|
19
|
+
publishedAt: entity.updatedAt || new Date().toISOString(),
|
|
20
|
+
},
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=entity-service-lifecycle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"entity-service-lifecycle.js","sourceRoot":"","sources":["../../../../services/entity-service-lifecycle.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAE7C,MAAM,CAAC,MAAM,qBAAqB,GAAG,KAAK,EAAwB,EAChE,MAAM,EACN,aAAa,GAAG,EAAE,EAClB,SAAS,EACT,YAAY,EACZ,UAAU,GAOX,EAAE,EAAE;IACH,MAAM,YAAY,GAAG,YAAY,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,YAAY,CAAC;IAC1E,MAAM,mBAAmB,GAAG,YAAY,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;IAE/D,IAAI,mBAAmB,EAAE,CAAC;QACxB,MAAM,UAAU,CAAC,yBAAyB,CAAC;YACzC,MAAM;YACN,aAAa,EAAE,mBAAmB;SACnC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,YAAY,CAAC;QACjB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,cAAc;QAChC,OAAO,EAAE;YACP,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,kBAAkB,EAAE,SAAS;YAC7B,WAAW,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SAC1D;KACF,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { Entity, EntitySchemaMap } from '@monorise/base';
|
|
2
|
+
import type { EntityRepository } from '#/data/Entity';
|
|
3
|
+
import type { EventUtils } from '#/data/EventUtils';
|
|
4
|
+
import type { publishEvent as publishEventType } from '#/helpers/event';
|
|
5
|
+
export declare class EntityService {
|
|
6
|
+
private entityRepository;
|
|
7
|
+
private publishEvent;
|
|
8
|
+
private eventUtils;
|
|
9
|
+
constructor(entityRepository: EntityRepository, publishEvent: typeof publishEventType, eventUtils: EventUtils);
|
|
10
|
+
createEntity: <T extends Entity>({ entityType, entityId, entityPayload, accountId, options, }: {
|
|
11
|
+
entityType: T;
|
|
12
|
+
entityPayload: EntitySchemaMap[T];
|
|
13
|
+
entityId?: string;
|
|
14
|
+
accountId?: string | string[];
|
|
15
|
+
options?: {
|
|
16
|
+
createAndUpdateDatetime?: string;
|
|
17
|
+
mutualId?: string;
|
|
18
|
+
};
|
|
19
|
+
}) => Promise<import("#/data/Entity").Entity<T>>;
|
|
20
|
+
updateEntity: <T extends Entity>({ entityType, entityId, entityPayload, accountId, }: {
|
|
21
|
+
entityType: T;
|
|
22
|
+
entityId: string;
|
|
23
|
+
entityPayload: Partial<EntitySchemaMap[T]>;
|
|
24
|
+
accountId?: string | string[];
|
|
25
|
+
}) => Promise<import("#/data/Entity").Entity<T>>;
|
|
26
|
+
deleteEntity: <T extends Entity>({ entityType, entityId, accountId, }: {
|
|
27
|
+
entityType: T;
|
|
28
|
+
entityId: string;
|
|
29
|
+
accountId?: string | string[];
|
|
30
|
+
}) => Promise<void>;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=entity.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"entity.service.d.ts","sourceRoot":"","sources":["../../../../services/entity.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAE9D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAEpD,OAAO,KAAK,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AASxE,qBAAa,aAAa;IAEtB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,UAAU;gBAFV,gBAAgB,EAAE,gBAAgB,EAClC,YAAY,EAAE,OAAO,gBAAgB,EACrC,UAAU,EAAE,UAAU;IAGhC,YAAY,GAAU,CAAC,SAAS,MAAM,EAAE,8DAMrC;QACD,UAAU,EAAE,CAAC,CAAC;QACd,aAAa,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC;QAClC,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;QAC9B,OAAO,CAAC,EAAE;YACR,uBAAuB,CAAC,EAAE,MAAM,CAAC;YACjC,QAAQ,CAAC,EAAE,MAAM,CAAC;SACnB,CAAC;KACH,gDAsDC;IAEF,YAAY,GAAU,CAAC,SAAS,MAAM,EAAE,qDAKrC;QACD,UAAU,EAAE,CAAC,CAAC;QACd,QAAQ,EAAE,MAAM,CAAC;QACjB,aAAa,EAAE,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;KAC/B,gDA4EC;IAEF,YAAY,GAAU,CAAC,SAAS,MAAM,EAAE,sCAIrC;QACD,UAAU,EAAE,CAAC,CAAC;QACd,QAAQ,EAAE,MAAM,CAAC;QACjB,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;KAC/B,mBAWC;CACH"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { StandardError } from '#/errors/standard-error';
|
|
3
|
+
import { EmailAuthEnabledEntities, EntityConfig, } from '#/lambda-layer/monorise';
|
|
4
|
+
import { EVENT } from '#/shared/types/event';
|
|
5
|
+
import { afterCreateEntityHook } from './entity-service-lifecycle';
|
|
6
|
+
export class EntityService {
|
|
7
|
+
entityRepository;
|
|
8
|
+
publishEvent;
|
|
9
|
+
eventUtils;
|
|
10
|
+
constructor(entityRepository, publishEvent, eventUtils) {
|
|
11
|
+
this.entityRepository = entityRepository;
|
|
12
|
+
this.publishEvent = publishEvent;
|
|
13
|
+
this.eventUtils = eventUtils;
|
|
14
|
+
}
|
|
15
|
+
createEntity = async ({ entityType, entityId, entityPayload, accountId, options, }) => {
|
|
16
|
+
const finalSchema = EntityConfig[entityType].finalSchema;
|
|
17
|
+
const entitySchema = EntityConfig[entityType]?.createSchema ||
|
|
18
|
+
EntityConfig[entityType]?.baseSchema ||
|
|
19
|
+
z.object({});
|
|
20
|
+
// const mutualSchema = EntityConfig[entityType]?.mutual?.mutualSchema;
|
|
21
|
+
if (!finalSchema || !entitySchema) {
|
|
22
|
+
throw new StandardError('INVALID_ENTITY_TYPE', 'Invalid entity type');
|
|
23
|
+
}
|
|
24
|
+
finalSchema.parse(entityPayload);
|
|
25
|
+
const parsedEntityPayload = entitySchema.parse(entityPayload);
|
|
26
|
+
// TODO: Create entity to accept mutual payload, so that mutual
|
|
27
|
+
// relationship can be formed when creating entity
|
|
28
|
+
// const parsedMutualPayload = mutualSchema?.parse(entityPayload);
|
|
29
|
+
if (EmailAuthEnabledEntities.includes(entityType)) {
|
|
30
|
+
await this.entityRepository.getEmailAvailability(entityType, parsedEntityPayload.email);
|
|
31
|
+
}
|
|
32
|
+
const entity = await this.entityRepository.createEntity(entityType, parsedEntityPayload, entityId, {
|
|
33
|
+
...(options?.mutualId
|
|
34
|
+
? {
|
|
35
|
+
mutualId: `MUTUAL#${options.mutualId}`,
|
|
36
|
+
}
|
|
37
|
+
: {}),
|
|
38
|
+
createAndUpdateDatetime: options?.createAndUpdateDatetime
|
|
39
|
+
? new Date(options.createAndUpdateDatetime)
|
|
40
|
+
: new Date(),
|
|
41
|
+
});
|
|
42
|
+
await afterCreateEntityHook({
|
|
43
|
+
entity,
|
|
44
|
+
entityPayload,
|
|
45
|
+
accountId,
|
|
46
|
+
publishEvent: this.publishEvent,
|
|
47
|
+
eventUtils: this.eventUtils,
|
|
48
|
+
});
|
|
49
|
+
return entity;
|
|
50
|
+
};
|
|
51
|
+
updateEntity = async ({ entityType, entityId, entityPayload, accountId, }) => {
|
|
52
|
+
const errorContext = {};
|
|
53
|
+
try {
|
|
54
|
+
const entitySchema = EntityConfig[entityType].baseSchema;
|
|
55
|
+
const mutualSchema = EntityConfig[entityType].mutual?.mutualSchema;
|
|
56
|
+
if (!entitySchema) {
|
|
57
|
+
throw new StandardError('Invalid entity type', 'INVALID_ENTITY_TYPE');
|
|
58
|
+
}
|
|
59
|
+
const parsedEntityPayload = entitySchema.parse(entityPayload);
|
|
60
|
+
const parsedMutualPayload = mutualSchema?.parse(entityPayload);
|
|
61
|
+
errorContext.parsedMutualPayload = parsedMutualPayload;
|
|
62
|
+
const entity = await this.entityRepository.updateEntity(entityType, entityId, { data: parsedEntityPayload });
|
|
63
|
+
errorContext.entity = entity;
|
|
64
|
+
if (parsedMutualPayload) {
|
|
65
|
+
const byEntityType = entityType;
|
|
66
|
+
const byEntityId = entityId;
|
|
67
|
+
const publishEventPromises = [];
|
|
68
|
+
for (const [fieldKey, config] of Object.entries(EntityConfig[entityType].mutual?.mutualFields || {})) {
|
|
69
|
+
const toMutualIds = config.toMutualIds;
|
|
70
|
+
const mutualPayload = parsedMutualPayload[fieldKey];
|
|
71
|
+
if (!mutualPayload)
|
|
72
|
+
continue;
|
|
73
|
+
publishEventPromises.push(this.publishEvent({
|
|
74
|
+
event: EVENT.CORE.ENTITY_MUTUAL_TO_UPDATE,
|
|
75
|
+
payload: {
|
|
76
|
+
byEntityType,
|
|
77
|
+
byEntityId,
|
|
78
|
+
entityType: config.entityType,
|
|
79
|
+
field: fieldKey,
|
|
80
|
+
mutualIds: toMutualIds
|
|
81
|
+
? toMutualIds(mutualPayload)
|
|
82
|
+
: mutualPayload,
|
|
83
|
+
customContext: toMutualIds ? mutualPayload : {},
|
|
84
|
+
publishedAt: entity.updatedAt || new Date().toISOString(),
|
|
85
|
+
},
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
await Promise.allSettled(publishEventPromises);
|
|
89
|
+
}
|
|
90
|
+
await this.publishEvent({
|
|
91
|
+
event: EVENT.CORE.ENTITY_UPDATED,
|
|
92
|
+
payload: {
|
|
93
|
+
entityType,
|
|
94
|
+
entityId,
|
|
95
|
+
data: entity.data,
|
|
96
|
+
updatedByAccountId: accountId,
|
|
97
|
+
publishedAt: entity.updatedAt || new Date().toISOString(),
|
|
98
|
+
},
|
|
99
|
+
});
|
|
100
|
+
return entity;
|
|
101
|
+
}
|
|
102
|
+
catch (error) {
|
|
103
|
+
if (error && typeof error === 'object') {
|
|
104
|
+
error.context = errorContext;
|
|
105
|
+
}
|
|
106
|
+
throw error;
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
deleteEntity = async ({ entityType, entityId, accountId, }) => {
|
|
110
|
+
await this.entityRepository.deleteEntity(entityType, entityId);
|
|
111
|
+
await this.publishEvent({
|
|
112
|
+
event: EVENT.CORE.ENTITY_DELETED,
|
|
113
|
+
payload: {
|
|
114
|
+
entityType,
|
|
115
|
+
entityId,
|
|
116
|
+
deletedByAccountId: accountId,
|
|
117
|
+
},
|
|
118
|
+
});
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
//# sourceMappingURL=entity.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"entity.service.js","sourceRoot":"","sources":["../../../../services/entity.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAExD,OAAO,EACL,wBAAwB,EACxB,YAAY,GACb,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAC7C,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,MAAM,OAAO,aAAa;IAEd;IACA;IACA;IAHV,YACU,gBAAkC,EAClC,YAAqC,EACrC,UAAsB;QAFtB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,iBAAY,GAAZ,YAAY,CAAyB;QACrC,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAEJ,YAAY,GAAG,KAAK,EAAoB,EACtC,UAAU,EACV,QAAQ,EACR,aAAa,EACb,SAAS,EACT,OAAO,GAUR,EAAE,EAAE;QACH,MAAM,WAAW,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC,WAAW,CAAC;QACzD,MAAM,YAAY,GAChB,YAAY,CAAC,UAAU,CAAC,EAAE,YAAY;YACtC,YAAY,CAAC,UAAU,CAAC,EAAE,UAAU;YACpC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACf,uEAAuE;QAEvE,IAAI,CAAC,WAAW,IAAI,CAAC,YAAY,EAAE,CAAC;YAClC,MAAM,IAAI,aAAa,CAAC,qBAAqB,EAAE,qBAAqB,CAAC,CAAC;QACxE,CAAC;QAED,WAAW,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAEjC,MAAM,mBAAmB,GAAG,YAAY,CAAC,KAAK,CAC5C,aAAa,CAC4B,CAAC;QAE5C,+DAA+D;QAC/D,kDAAkD;QAClD,kEAAkE;QAElE,IAAI,wBAAwB,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YAClD,MAAM,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CAC9C,UAAU,EACV,mBAAmB,CAAC,KAAK,CAC1B,CAAC;QACJ,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,YAAY,CACrD,UAAU,EACV,mBAAmB,EACnB,QAAQ,EACR;YACE,GAAG,CAAC,OAAO,EAAE,QAAQ;gBACnB,CAAC,CAAC;oBACE,QAAQ,EAAE,UAAU,OAAO,CAAC,QAAQ,EAAE;iBACvC;gBACH,CAAC,CAAC,EAAE,CAAC;YACP,uBAAuB,EAAE,OAAO,EAAE,uBAAuB;gBACvD,CAAC,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,uBAAuB,CAAC;gBAC3C,CAAC,CAAC,IAAI,IAAI,EAAE;SACf,CACF,CAAC;QAEF,MAAM,qBAAqB,CAAC;YAC1B,MAAM;YACN,aAAa;YACb,SAAS;YACT,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,UAAU,EAAE,IAAI,CAAC,UAAU;SAC5B,CAAC,CAAC;QAEH,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC;IAEF,YAAY,GAAG,KAAK,EAAoB,EACtC,UAAU,EACV,QAAQ,EACR,aAAa,EACb,SAAS,GAMV,EAAE,EAAE;QACH,MAAM,YAAY,GAA4B,EAAE,CAAC;QAEjD,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC;YACzD,MAAM,YAAY,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,YAAY,CAAC;YAEnE,IAAI,CAAC,YAAY,EAAE,CAAC;gBAClB,MAAM,IAAI,aAAa,CAAC,qBAAqB,EAAE,qBAAqB,CAAC,CAAC;YACxE,CAAC;YAED,MAAM,mBAAmB,GAAG,YAAY,CAAC,KAAK,CAAC,aAAa,CAE3D,CAAC;YACF,MAAM,mBAAmB,GAAG,YAAY,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;YAC/D,YAAY,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;YAEvD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,YAAY,CACrD,UAAU,EACV,QAAQ,EACR,EAAE,IAAI,EAAE,mBAAmB,EAAE,CAC9B,CAAC;YACF,YAAY,CAAC,MAAM,GAAG,MAAM,CAAC;YAE7B,IAAI,mBAAmB,EAAE,CAAC;gBACxB,MAAM,YAAY,GAAG,UAAU,CAAC;gBAChC,MAAM,UAAU,GAAG,QAAQ,CAAC;gBAC5B,MAAM,oBAAoB,GAAG,EAAE,CAAC;gBAEhC,KAAK,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,CAC7C,YAAY,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,YAAY,IAAI,EAAE,CACpD,EAAE,CAAC;oBACF,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC;oBACvC,MAAM,aAAa,GAAI,mBAA2C,CAChE,QAAQ,CACT,CAAC;oBACF,IAAI,CAAC,aAAa;wBAAE,SAAS;oBAE7B,oBAAoB,CAAC,IAAI,CACvB,IAAI,CAAC,YAAY,CAAiC;wBAChD,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,uBAAuB;wBACzC,OAAO,EAAE;4BACP,YAAY;4BACZ,UAAU;4BACV,UAAU,EAAE,MAAM,CAAC,UAAU;4BAC7B,KAAK,EAAE,QAAQ;4BACf,SAAS,EAAE,WAAW;gCACpB,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC;gCAC5B,CAAC,CAAC,aAAa;4BACjB,aAAa,EAAE,WAAW,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;4BAC/C,WAAW,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;yBAC1D;qBACF,CAAC,CACH,CAAC;gBACJ,CAAC;gBACD,MAAM,OAAO,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;YACjD,CAAC;YAED,MAAM,IAAI,CAAC,YAAY,CAAC;gBACtB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,cAAc;gBAChC,OAAO,EAAE;oBACP,UAAU;oBACV,QAAQ;oBACR,IAAI,EAAE,MAAM,CAAC,IAAI;oBACjB,kBAAkB,EAAE,SAAS;oBAC7B,WAAW,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;iBAC1D;aACF,CAAC,CAAC;YAEH,OAAO,MAAM,CAAC;QAChB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBACtC,KAAiC,CAAC,OAAO,GAAG,YAAY,CAAC;YAC5D,CAAC;YACD,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC,CAAC;IAEF,YAAY,GAAG,KAAK,EAAoB,EACtC,UAAU,EACV,QAAQ,EACR,SAAS,GAKV,EAAE,EAAE;QACH,MAAM,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QAE/D,MAAM,IAAI,CAAC,YAAY,CAAC;YACtB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,cAAc;YAChC,OAAO,EAAE;gBACP,UAAU;gBACV,QAAQ;gBACR,kBAAkB,EAAE,SAAS;aAC9B;SACF,CAAC,CAAC;IACL,CAAC,CAAC;CACH"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import type { AttributeValue } from '@aws-sdk/client-dynamodb';
|
|
2
|
+
import type { Entity as EntityType } from '@monorise/base';
|
|
3
|
+
import type { DbUtils } from '#/data/DbUtils';
|
|
4
|
+
import { type EntityRepository } from '#/data/Entity';
|
|
5
|
+
import type { EventUtils } from '#/data/EventUtils';
|
|
6
|
+
import { Mutual, type MutualRepository } from '#/data/Mutual';
|
|
7
|
+
import type { publishEvent as publishEventType } from '#/helpers/event';
|
|
8
|
+
export declare class MutualService {
|
|
9
|
+
private entityRepository;
|
|
10
|
+
private mutualRepository;
|
|
11
|
+
private publishEvent;
|
|
12
|
+
private eventUtils;
|
|
13
|
+
private ddbUtils;
|
|
14
|
+
constructor(entityRepository: EntityRepository, mutualRepository: MutualRepository, publishEvent: typeof publishEventType, eventUtils: EventUtils, ddbUtils: DbUtils);
|
|
15
|
+
createMutual: <B extends EntityType, T extends EntityType, A extends EntityType>({ byEntityType, byEntityId, entityType, entityId, mutualPayload, accountId, options, }: {
|
|
16
|
+
byEntityType: B;
|
|
17
|
+
byEntityId: string;
|
|
18
|
+
entityType: T;
|
|
19
|
+
entityId: string;
|
|
20
|
+
mutualPayload?: Record<string, unknown>;
|
|
21
|
+
accountId?: string | string[];
|
|
22
|
+
options?: {
|
|
23
|
+
asEntity?: A;
|
|
24
|
+
ensureEntityStrongConsistentWrite?: boolean;
|
|
25
|
+
mutualId?: string;
|
|
26
|
+
skipMutualCreation?: boolean;
|
|
27
|
+
createAndUpdateDatetime?: Date;
|
|
28
|
+
ConditionExpression?: string;
|
|
29
|
+
ExpressionAttributeNames?: Record<string, string>;
|
|
30
|
+
ExpressionAttributeValues?: Record<string, AttributeValue>;
|
|
31
|
+
};
|
|
32
|
+
}) => Promise<{
|
|
33
|
+
mutual: Mutual<B, T, Record<string, any>>;
|
|
34
|
+
eventPayload: {
|
|
35
|
+
byEntityType: B;
|
|
36
|
+
byEntityId: string;
|
|
37
|
+
entityType: T;
|
|
38
|
+
entityId: string;
|
|
39
|
+
parsedMutualPayload: Record<string, any>;
|
|
40
|
+
accountId: string | string[] | undefined;
|
|
41
|
+
publishedAt: string;
|
|
42
|
+
};
|
|
43
|
+
}>;
|
|
44
|
+
updateMutual: <B extends EntityType, T extends EntityType, M extends Record<string, unknown>>({ byEntityType, byEntityId, entityType, entityId, mutualPayload, accountId, options, }: {
|
|
45
|
+
byEntityType: B;
|
|
46
|
+
byEntityId: string;
|
|
47
|
+
entityType: T;
|
|
48
|
+
entityId: string;
|
|
49
|
+
mutualPayload: M;
|
|
50
|
+
accountId?: string | string[];
|
|
51
|
+
options?: {
|
|
52
|
+
maxObjectUpdateLevel?: number;
|
|
53
|
+
returnUpdatedValue?: boolean;
|
|
54
|
+
};
|
|
55
|
+
}) => Promise<Mutual<B, T, Record<string, unknown>> | undefined>;
|
|
56
|
+
deleteMutual: ({ byEntityType, byEntityId, entityType, entityId, accountId, }: {
|
|
57
|
+
byEntityType: EntityType;
|
|
58
|
+
byEntityId: string;
|
|
59
|
+
entityType: EntityType;
|
|
60
|
+
entityId: string;
|
|
61
|
+
accountId?: string | string[];
|
|
62
|
+
}) => Promise<Mutual<EntityType, EntityType, Record<string, unknown>>>;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=mutual.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mutual.service.d.ts","sourceRoot":"","sources":["../../../../services/mutual.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,KAAK,EAAmB,MAAM,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAG5E,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAU,KAAK,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,KAAK,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,KAAK,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAIxE,qBAAa,aAAa;IAEtB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,QAAQ;gBAJR,gBAAgB,EAAE,gBAAgB,EAClC,gBAAgB,EAAE,gBAAgB,EAClC,YAAY,EAAE,OAAO,gBAAgB,EACrC,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,OAAO;IAG3B,YAAY,GACV,CAAC,SAAS,UAAU,EACpB,CAAC,SAAS,UAAU,EACpB,CAAC,SAAS,UAAU,EACpB,wFAQC;QACD,YAAY,EAAE,CAAC,CAAC;QAChB,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,CAAC,CAAC;QACd,QAAQ,EAAE,MAAM,CAAC;QACjB,aAAa,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACxC,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;QAC9B,OAAO,CAAC,EAAE;YACR,QAAQ,CAAC,EAAE,CAAC,CAAC;YAKb,iCAAiC,CAAC,EAAE,OAAO,CAAC;YAC5C,QAAQ,CAAC,EAAE,MAAM,CAAC;YAGlB,kBAAkB,CAAC,EAAE,OAAO,CAAC;YAC7B,uBAAuB,CAAC,EAAE,IAAI,CAAC;YAC/B,mBAAmB,CAAC,EAAE,MAAM,CAAC;YAC7B,wBAAwB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;YAClD,yBAAyB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;SAC5D,CAAC;KACH;;;;;;;;;;;OA+IC;IAEF,YAAY,GACV,CAAC,SAAS,UAAU,EACpB,CAAC,SAAS,UAAU,EACpB,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACjC,wFAQC;QACD,YAAY,EAAE,CAAC,CAAC;QAChB,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,CAAC,CAAC;QACd,QAAQ,EAAE,MAAM,CAAC;QACjB,aAAa,EAAE,CAAC,CAAC;QACjB,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;QAC9B,OAAO,CAAC,EAAE;YACR,oBAAoB,CAAC,EAAE,MAAM,CAAC;YAC9B,kBAAkB,CAAC,EAAE,OAAO,CAAC;SAC9B,CAAC;KACH,gEAyBC;IAEF,YAAY,GAAU,gEAMnB;QACD,YAAY,EAAE,UAAU,CAAC;QACzB,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,UAAU,CAAC;QACvB,QAAQ,EAAE,MAAM,CAAC;QACjB,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;KAC/B,sEAoBC;CACH"}
|