@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,74 @@
|
|
|
1
|
+
const SOURCE = {
|
|
2
|
+
CORE: 'monorise-core',
|
|
3
|
+
GENERAL: 'general',
|
|
4
|
+
};
|
|
5
|
+
const EVENT = {
|
|
6
|
+
CORE: {
|
|
7
|
+
LOGIN_EMAIL_REQUESTED: {
|
|
8
|
+
Source: SOURCE.CORE,
|
|
9
|
+
DetailType: 'login-email-requested',
|
|
10
|
+
},
|
|
11
|
+
/*
|
|
12
|
+
* Entity
|
|
13
|
+
*/
|
|
14
|
+
ENTITY_CREATED: {
|
|
15
|
+
Source: SOURCE.CORE,
|
|
16
|
+
DetailType: 'entity-created',
|
|
17
|
+
},
|
|
18
|
+
ENTITY_UPSERTED: {
|
|
19
|
+
Source: SOURCE.CORE,
|
|
20
|
+
DetailType: 'entity-upserted',
|
|
21
|
+
},
|
|
22
|
+
ENTITY_UPDATED: {
|
|
23
|
+
Source: SOURCE.CORE,
|
|
24
|
+
DetailType: 'entity-updated',
|
|
25
|
+
},
|
|
26
|
+
ENTITY_DELETED: {
|
|
27
|
+
Source: SOURCE.CORE,
|
|
28
|
+
DetailType: 'entity-deleted',
|
|
29
|
+
},
|
|
30
|
+
ENTITY_MUTUAL_TO_CREATE: {
|
|
31
|
+
Source: SOURCE.CORE,
|
|
32
|
+
DetailType: 'entity-mutual-to-create',
|
|
33
|
+
},
|
|
34
|
+
ENTITY_MUTUAL_TO_UPDATE: {
|
|
35
|
+
Source: SOURCE.CORE,
|
|
36
|
+
DetailType: 'entity-mutual-to-update',
|
|
37
|
+
},
|
|
38
|
+
ENTITY_MUTUAL_PROCESSED: {
|
|
39
|
+
Source: SOURCE.CORE,
|
|
40
|
+
DetailType: 'entity-mutual-processed',
|
|
41
|
+
},
|
|
42
|
+
CREATE_ENTITY: {
|
|
43
|
+
Source: SOURCE.CORE,
|
|
44
|
+
DetailType: 'create-entity',
|
|
45
|
+
},
|
|
46
|
+
/*
|
|
47
|
+
* Mutual
|
|
48
|
+
*/
|
|
49
|
+
MUTUAL_CREATED: {
|
|
50
|
+
Source: SOURCE.CORE,
|
|
51
|
+
DetailType: 'mutual-created',
|
|
52
|
+
},
|
|
53
|
+
MUTUAL_UPDATED: {
|
|
54
|
+
Source: SOURCE.CORE,
|
|
55
|
+
DetailType: 'mutual-updated',
|
|
56
|
+
},
|
|
57
|
+
MUTUAL_DELETED: {
|
|
58
|
+
Source: SOURCE.CORE,
|
|
59
|
+
DetailType: 'mutual-deleted',
|
|
60
|
+
},
|
|
61
|
+
PREJOIN_RELATIONSHIP_SYNC: {
|
|
62
|
+
Source: SOURCE.CORE,
|
|
63
|
+
DetailType: 'prejoin-relationship-sync',
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
GENERAL: {
|
|
67
|
+
ENDPOINT_ERROR: {
|
|
68
|
+
Source: SOURCE.GENERAL,
|
|
69
|
+
DetailType: 'endpoint-error',
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
};
|
|
73
|
+
export { SOURCE, EVENT };
|
|
74
|
+
//# sourceMappingURL=event.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.js","sourceRoot":"","sources":["../../types/event.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,GAAG;IACb,IAAI,EAAE,eAAe;IACrB,OAAO,EAAE,SAAS;CACnB,CAAC;AAOF,MAAM,KAAK,GAAG;IACZ,IAAI,EAAE;QACJ,qBAAqB,EAAE;YACrB,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,uBAAuB;SACpC;QAED;;WAEG;QACH,cAAc,EAAE;YACd,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,gBAAgB;SAC7B;QACD,eAAe,EAAE;YACf,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,iBAAiB;SAC9B;QACD,cAAc,EAAE;YACd,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,gBAAgB;SAC7B;QACD,cAAc,EAAE;YACd,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,gBAAgB;SAC7B;QACD,uBAAuB,EAAE;YACvB,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,yBAAyB;SACtC;QACD,uBAAuB,EAAE;YACvB,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,yBAAyB;SACtC;QACD,uBAAuB,EAAE;YACvB,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,yBAAyB;SACtC;QAED,aAAa,EAAE;YACb,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,eAAe;SAC5B;QAED;;WAEG;QACH,cAAc,EAAE;YACd,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,gBAAgB;SAC7B;QACD,cAAc,EAAE;YACd,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,gBAAgB;SAC7B;QACD,cAAc,EAAE;YACd,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,gBAAgB;SAC7B;QACD,yBAAyB,EAAE;YACzB,MAAM,EAAE,MAAM,CAAC,IAAI;YACnB,UAAU,EAAE,2BAA2B;SACxC;KACF;IAED,OAAO,EAAE;QACP,cAAc,EAAE;YACd,MAAM,EAAE,MAAM,CAAC,OAAO;YACtB,UAAU,EAAE,gBAAgB;SAC7B;KACF;CACF,CAAC;AAEF,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import * as httpStatus from 'http-status';
|
|
2
|
+
import ExtendableError from './extendable-error';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Class representing an API error.
|
|
6
|
+
* @extends ExtendableError
|
|
7
|
+
*/
|
|
8
|
+
class APIError extends ExtendableError {
|
|
9
|
+
/**
|
|
10
|
+
* Creates an API error.
|
|
11
|
+
* @param {string} message - Error message.
|
|
12
|
+
* @param {number} status - HTTP status code of error.
|
|
13
|
+
* @param {boolean} isPublic - Whether the message should be visible to user or not.
|
|
14
|
+
* @param {string | undefined} stack - Stack trace.
|
|
15
|
+
*/
|
|
16
|
+
constructor({
|
|
17
|
+
message,
|
|
18
|
+
errors,
|
|
19
|
+
stack,
|
|
20
|
+
status = httpStatus.INTERNAL_SERVER_ERROR,
|
|
21
|
+
isPublic = false,
|
|
22
|
+
}: {
|
|
23
|
+
message: string;
|
|
24
|
+
errors?: any;
|
|
25
|
+
stack?: string;
|
|
26
|
+
status?: number;
|
|
27
|
+
isPublic?: boolean;
|
|
28
|
+
}) {
|
|
29
|
+
super({
|
|
30
|
+
message,
|
|
31
|
+
errors,
|
|
32
|
+
status,
|
|
33
|
+
isPublic,
|
|
34
|
+
stack,
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export default APIError;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
class ExtendableError extends Error {
|
|
2
|
+
public name: string;
|
|
3
|
+
public message: string;
|
|
4
|
+
public errors: any;
|
|
5
|
+
public status: number;
|
|
6
|
+
public isPublic: boolean;
|
|
7
|
+
public isOperational: boolean;
|
|
8
|
+
public stack?: string;
|
|
9
|
+
|
|
10
|
+
constructor({
|
|
11
|
+
message,
|
|
12
|
+
errors,
|
|
13
|
+
status,
|
|
14
|
+
isPublic,
|
|
15
|
+
stack,
|
|
16
|
+
}: {
|
|
17
|
+
message: string;
|
|
18
|
+
errors?: any;
|
|
19
|
+
status?: number;
|
|
20
|
+
isPublic?: boolean;
|
|
21
|
+
stack?: string;
|
|
22
|
+
}) {
|
|
23
|
+
super(message);
|
|
24
|
+
this.name = this.constructor.name;
|
|
25
|
+
this.message = message;
|
|
26
|
+
this.errors = errors;
|
|
27
|
+
this.status = status || 500; // Default value if status is not provided
|
|
28
|
+
this.isPublic = isPublic || false; // Default value if isPublic is not provided
|
|
29
|
+
this.isOperational = true; // This is required since bluebird 4 doesn't append it anymore.
|
|
30
|
+
this.stack = stack;
|
|
31
|
+
// Error.captureStackTrace(this, this.constructor.name);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
export default ExtendableError;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export class StandardError extends Error {
|
|
2
|
+
public code: string;
|
|
3
|
+
public lastError?: object | null;
|
|
4
|
+
public context?: string | null;
|
|
5
|
+
|
|
6
|
+
constructor(
|
|
7
|
+
errorCode: string,
|
|
8
|
+
message: string,
|
|
9
|
+
lastError?: any,
|
|
10
|
+
context?: object | string | null,
|
|
11
|
+
) {
|
|
12
|
+
super(message);
|
|
13
|
+
|
|
14
|
+
// So you can do typeof CustomError
|
|
15
|
+
Object.setPrototypeOf(this, new.target.prototype);
|
|
16
|
+
|
|
17
|
+
this.name = this.constructor.name;
|
|
18
|
+
this.code = errorCode;
|
|
19
|
+
this.lastError = lastError;
|
|
20
|
+
this.context = JSON.stringify(context, null, 2);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
public toJSON() {
|
|
24
|
+
return {
|
|
25
|
+
code: this.code,
|
|
26
|
+
message: this.message,
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
}
|
package/helpers/event.ts
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import {
|
|
2
|
+
EventBridgeClient,
|
|
3
|
+
PutEventsCommand,
|
|
4
|
+
} from '@aws-sdk/client-eventbridge';
|
|
5
|
+
import { CORE_EVENT_BUS } from '#/configs/service.config';
|
|
6
|
+
import { EVENT, type EventDetail } from '#/types/event';
|
|
7
|
+
|
|
8
|
+
const eventBridge = new EventBridgeClient();
|
|
9
|
+
|
|
10
|
+
type PublishEventProps<T> = {
|
|
11
|
+
payload: T;
|
|
12
|
+
event: EventDetail;
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
type ParsedSQSBusEvent<T = Record<string, any>> = {
|
|
16
|
+
event: EventDetail;
|
|
17
|
+
detail: T;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export function parseSQSBusEvent<T>(
|
|
21
|
+
evRecordBody: string,
|
|
22
|
+
): ParsedSQSBusEvent<T> {
|
|
23
|
+
const body = JSON.parse(evRecordBody);
|
|
24
|
+
return {
|
|
25
|
+
...body,
|
|
26
|
+
detail: body.detail,
|
|
27
|
+
event: {
|
|
28
|
+
Source: body.source,
|
|
29
|
+
DetailType: body['detail-type'],
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export async function publishEvent<T extends Record<string, any>>({
|
|
35
|
+
payload,
|
|
36
|
+
event,
|
|
37
|
+
}: PublishEventProps<T>): Promise<void> {
|
|
38
|
+
const params = {
|
|
39
|
+
Entries: [
|
|
40
|
+
{
|
|
41
|
+
...event,
|
|
42
|
+
Detail: JSON.stringify(payload),
|
|
43
|
+
EventBusName: CORE_EVENT_BUS,
|
|
44
|
+
},
|
|
45
|
+
],
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
await eventBridge.send(new PutEventsCommand(params));
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
type PublishErrorEventPayload = {
|
|
52
|
+
id: string;
|
|
53
|
+
serviceName: string;
|
|
54
|
+
method: string;
|
|
55
|
+
path: string;
|
|
56
|
+
body?: Record<string, any>;
|
|
57
|
+
error: Error;
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
export async function publishErrorEvent({
|
|
61
|
+
id,
|
|
62
|
+
serviceName,
|
|
63
|
+
method,
|
|
64
|
+
path,
|
|
65
|
+
body,
|
|
66
|
+
error,
|
|
67
|
+
}: PublishErrorEventPayload) {
|
|
68
|
+
await publishEvent({
|
|
69
|
+
event: EVENT.GENERAL.ENDPOINT_ERROR,
|
|
70
|
+
payload: {
|
|
71
|
+
id,
|
|
72
|
+
serviceName,
|
|
73
|
+
method,
|
|
74
|
+
path,
|
|
75
|
+
...(body ? { requestBody: body } : {}),
|
|
76
|
+
error: {
|
|
77
|
+
name: error.name,
|
|
78
|
+
message: error.message,
|
|
79
|
+
// @ts-ignore
|
|
80
|
+
cause: error.cause,
|
|
81
|
+
stack: error.stack,
|
|
82
|
+
},
|
|
83
|
+
},
|
|
84
|
+
});
|
|
85
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { NativeAttributeValue } from '@aws-sdk/util-dynamodb';
|
|
2
|
+
|
|
3
|
+
export function fromLastKeyQuery(
|
|
4
|
+
lastKeyQuery?: string,
|
|
5
|
+
): Record<string, NativeAttributeValue> | undefined {
|
|
6
|
+
if (!lastKeyQuery) {
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
return JSON.parse(Buffer.from(lastKeyQuery, 'base64').toString('utf-8'));
|
|
11
|
+
}
|
package/helpers/sleep.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const sleep = (ms: number) => new Promise((res) => setTimeout(res, ms));
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { NativeAttributeValue } from '@aws-sdk/util-dynamodb';
|
|
2
|
+
|
|
3
|
+
export function toLastKeyResponse(
|
|
4
|
+
lastKey?: Record<string, NativeAttributeValue>,
|
|
5
|
+
): string | undefined {
|
|
6
|
+
if (!lastKey) {
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
return Buffer.from(JSON.stringify(lastKey)).toString('base64');
|
|
11
|
+
}
|
package/index.ts
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { setupCommonRoutes } from './controllers/setupRoutes';
|
|
2
|
+
import { Entity } from './data/Entity';
|
|
3
|
+
import { Mutual } from './data/Mutual';
|
|
4
|
+
import { PROJECTION_EXPRESSION } from './data/ProjectionExpression';
|
|
5
|
+
import { handler as createEntityProcessor } from './processors/create-entity-processor';
|
|
6
|
+
import { handler as mutualProcessor } from './processors/mutual-processor';
|
|
7
|
+
import { handler as prejoinProcessor } from './processors/prejoin-processor';
|
|
8
|
+
import { handler as replicationProcessor } from './processors/replication-processor';
|
|
9
|
+
import { handler as tagProcessor } from './processors/tag-processor';
|
|
10
|
+
import { DependencyContainer } from './services/DependencyContainer';
|
|
11
|
+
|
|
12
|
+
export {
|
|
13
|
+
setupCommonRoutes,
|
|
14
|
+
Entity,
|
|
15
|
+
Mutual,
|
|
16
|
+
PROJECTION_EXPRESSION,
|
|
17
|
+
createEntityProcessor,
|
|
18
|
+
mutualProcessor,
|
|
19
|
+
prejoinProcessor,
|
|
20
|
+
replicationProcessor,
|
|
21
|
+
tagProcessor,
|
|
22
|
+
DependencyContainer,
|
|
23
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { Entity } from '@monorise/base';
|
|
2
|
+
import type { NextFunction, Request, Response } from 'express';
|
|
3
|
+
import httpStatus from 'http-status';
|
|
4
|
+
import { AllowedEntityTypes } from '#/lambda-layer/monorise';
|
|
5
|
+
|
|
6
|
+
export const entityTypeCheck: (
|
|
7
|
+
req: Request,
|
|
8
|
+
res: Response,
|
|
9
|
+
next: NextFunction,
|
|
10
|
+
) => void = (req, res, next) => {
|
|
11
|
+
const { entityType } = req.params as unknown as { entityType: Entity };
|
|
12
|
+
|
|
13
|
+
if (!AllowedEntityTypes.includes(entityType)) {
|
|
14
|
+
return res.status(httpStatus.NOT_FOUND).json({
|
|
15
|
+
code: 'NOT_FOUND',
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
next();
|
|
20
|
+
};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { Entity } from '@monorise/base';
|
|
2
|
+
import type { NextFunction, Request, Response } from 'express';
|
|
3
|
+
import httpStatus from 'http-status';
|
|
4
|
+
import { AllowedEntityTypes } from '#/lambda-layer/monorise';
|
|
5
|
+
|
|
6
|
+
export const mutualTypeCheck: (
|
|
7
|
+
req: Request,
|
|
8
|
+
res: Response,
|
|
9
|
+
next: NextFunction,
|
|
10
|
+
) => void = (req, res, next) => {
|
|
11
|
+
const { entityType, byEntityType } = req.params as unknown as {
|
|
12
|
+
entityType: Entity;
|
|
13
|
+
byEntityType: Entity;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
if (
|
|
17
|
+
!AllowedEntityTypes.includes(entityType) ||
|
|
18
|
+
!AllowedEntityTypes.includes(byEntityType)
|
|
19
|
+
) {
|
|
20
|
+
return res.status(httpStatus.NOT_FOUND).json({
|
|
21
|
+
code: 'NOT_FOUND',
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
next();
|
|
26
|
+
};
|
package/mock/entity.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export enum Entity {
|
|
2
|
+
ADMIN = 'admin',
|
|
3
|
+
CHAPTER = 'chapter',
|
|
4
|
+
COURSE = 'course',
|
|
5
|
+
LEARNER = 'learner',
|
|
6
|
+
LEARNING_ACTIVITY = 'learning-activity',
|
|
7
|
+
LEARNING_JOURNEY_CONFIG = 'learning-journey-config',
|
|
8
|
+
MODULE = 'module',
|
|
9
|
+
ORGANIZATION = 'organization',
|
|
10
|
+
REFERENCE = 'reference',
|
|
11
|
+
VIDEO = 'video',
|
|
12
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { createEntityConfig } from '@monorise/cli';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
|
|
4
|
+
const baseSchema = z
|
|
5
|
+
.object({
|
|
6
|
+
email: z.string().toLowerCase(),
|
|
7
|
+
displayName: z.string(),
|
|
8
|
+
})
|
|
9
|
+
.partial();
|
|
10
|
+
|
|
11
|
+
const createSchema = baseSchema.extend({
|
|
12
|
+
email: z
|
|
13
|
+
.string()
|
|
14
|
+
.toLowerCase()
|
|
15
|
+
.regex(
|
|
16
|
+
/^[a-zA-Z0-9.!#$%&’*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*$/,
|
|
17
|
+
"Doesn't seems like an email",
|
|
18
|
+
),
|
|
19
|
+
displayName: z.string().min(1, 'Please provide a name for this user account'),
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
const config = createEntityConfig({
|
|
23
|
+
name: 'admin',
|
|
24
|
+
displayName: 'Admin',
|
|
25
|
+
authMethod: {
|
|
26
|
+
email: {
|
|
27
|
+
tokenExpiresIn: 1000 * 60 * 60 * 24 * 14, // 14 days
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
baseSchema,
|
|
31
|
+
createSchema,
|
|
32
|
+
searchableFields: ['email', 'displayName'],
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
export default config;
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { createEntityConfig } from '@monorise/cli';
|
|
2
|
+
import type { Mutual } from '@monorise/react';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
import { Entity } from '../entity';
|
|
5
|
+
|
|
6
|
+
export enum CHAPTER_TYPE {
|
|
7
|
+
CHAPTER = 'CHAPTER',
|
|
8
|
+
CUSTOM = 'CUSTOM',
|
|
9
|
+
TOUCHPOINT = 'TOUCHPOINT',
|
|
10
|
+
CHECKPOINT = 'CHECKPOINT',
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
const baseSchema = z
|
|
14
|
+
.object({
|
|
15
|
+
description: z.string(),
|
|
16
|
+
discussionLink: z.string(),
|
|
17
|
+
remark: z.string(),
|
|
18
|
+
type: z.nativeEnum(CHAPTER_TYPE),
|
|
19
|
+
title: z.string(),
|
|
20
|
+
learningActivityDescription: z.string(),
|
|
21
|
+
body: z
|
|
22
|
+
.object({
|
|
23
|
+
type: z.string(),
|
|
24
|
+
id: z.string(),
|
|
25
|
+
content: z.any(),
|
|
26
|
+
})
|
|
27
|
+
.array()
|
|
28
|
+
.optional(),
|
|
29
|
+
progress: z.coerce.number().int(),
|
|
30
|
+
})
|
|
31
|
+
.partial();
|
|
32
|
+
|
|
33
|
+
const createSchema = baseSchema.extend({
|
|
34
|
+
remark: z.string(),
|
|
35
|
+
type: z.nativeEnum(CHAPTER_TYPE),
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
const mutualSchema = z
|
|
39
|
+
.object({
|
|
40
|
+
learningActivityOrders: z.string().array(),
|
|
41
|
+
referenceOrders: z.string().array(),
|
|
42
|
+
videos: z.string().array().max(1),
|
|
43
|
+
})
|
|
44
|
+
.partial();
|
|
45
|
+
|
|
46
|
+
const config = createEntityConfig({
|
|
47
|
+
name: 'chapter',
|
|
48
|
+
displayName: 'Chapter',
|
|
49
|
+
baseSchema,
|
|
50
|
+
createSchema,
|
|
51
|
+
searchableFields: ['remark', 'title'],
|
|
52
|
+
mutual: {
|
|
53
|
+
mutualSchema,
|
|
54
|
+
mutualFields: {
|
|
55
|
+
learningActivityOrders: {
|
|
56
|
+
entityType: Entity.LEARNING_ACTIVITY,
|
|
57
|
+
mutualDataProcessor: (
|
|
58
|
+
ids: string[],
|
|
59
|
+
context: Mutual<Entity.CHAPTER, Entity.LEARNING_ACTIVITY>,
|
|
60
|
+
) => {
|
|
61
|
+
return { index: ids.indexOf(context.entityId) };
|
|
62
|
+
},
|
|
63
|
+
},
|
|
64
|
+
referenceOrders: {
|
|
65
|
+
entityType: Entity.REFERENCE,
|
|
66
|
+
mutualDataProcessor: (
|
|
67
|
+
ids: string[],
|
|
68
|
+
context: Mutual<Entity.CHAPTER, Entity.REFERENCE>,
|
|
69
|
+
) => {
|
|
70
|
+
return { index: ids.indexOf(context.entityId) };
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
videos: {
|
|
74
|
+
entityType: Entity.VIDEO,
|
|
75
|
+
},
|
|
76
|
+
},
|
|
77
|
+
},
|
|
78
|
+
effect: (schema) => {
|
|
79
|
+
return schema.superRefine((value, ctx) => {
|
|
80
|
+
if (
|
|
81
|
+
value.type === CHAPTER_TYPE.CHAPTER &&
|
|
82
|
+
'videos' in value &&
|
|
83
|
+
!value.videos?.length
|
|
84
|
+
)
|
|
85
|
+
ctx.addIssue({
|
|
86
|
+
code: z.ZodIssueCode.custom,
|
|
87
|
+
message: 'Video is required',
|
|
88
|
+
path: ['videos'],
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
},
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
export default config;
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
import { createEntityConfig } from '@monorise/cli';
|
|
2
|
+
import type { Mutual } from '@monorise/react';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
import { Entity } from '../entity';
|
|
5
|
+
|
|
6
|
+
const baseSchema = z
|
|
7
|
+
.object({
|
|
8
|
+
title: z.string(),
|
|
9
|
+
categories: z.string().array(),
|
|
10
|
+
duration: z.number(),
|
|
11
|
+
description: z.string(),
|
|
12
|
+
learningOutcomes: z.string().array(),
|
|
13
|
+
infographics: z.string().array(),
|
|
14
|
+
tags: z.string().array(),
|
|
15
|
+
})
|
|
16
|
+
.partial();
|
|
17
|
+
|
|
18
|
+
const createSchema = baseSchema.extend({
|
|
19
|
+
title: z.string().min(4, {
|
|
20
|
+
message: 'Title must be at least 4 characters.',
|
|
21
|
+
}),
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
const mutualSchema = z
|
|
25
|
+
.object({
|
|
26
|
+
moduleOrders: z.string().array(),
|
|
27
|
+
videos: z.string().array(),
|
|
28
|
+
chapters: z.string().array(),
|
|
29
|
+
learningActivities: z.string().array(),
|
|
30
|
+
})
|
|
31
|
+
.partial();
|
|
32
|
+
|
|
33
|
+
const config = createEntityConfig({
|
|
34
|
+
name: 'course',
|
|
35
|
+
displayName: 'Course',
|
|
36
|
+
baseSchema: baseSchema,
|
|
37
|
+
createSchema,
|
|
38
|
+
searchableFields: ['title'],
|
|
39
|
+
mutual: {
|
|
40
|
+
subscribes: [{ entityType: Entity.MODULE }],
|
|
41
|
+
mutualSchema,
|
|
42
|
+
mutualFields: {
|
|
43
|
+
moduleOrders: {
|
|
44
|
+
entityType: Entity.MODULE,
|
|
45
|
+
mutualDataProcessor: (
|
|
46
|
+
ids: string[],
|
|
47
|
+
context: Mutual<Entity.COURSE, Entity.MODULE>,
|
|
48
|
+
) => {
|
|
49
|
+
return { index: ids.indexOf(context.entityId) };
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
videos: {
|
|
53
|
+
entityType: Entity.VIDEO,
|
|
54
|
+
mutualDataProcessor: (
|
|
55
|
+
ids: string[],
|
|
56
|
+
context: Mutual<Entity.COURSE, Entity.VIDEO>,
|
|
57
|
+
prejoinContext?: Record<string, any>,
|
|
58
|
+
) => {
|
|
59
|
+
return {
|
|
60
|
+
index: ids.indexOf(context.entityId),
|
|
61
|
+
moduleId: prejoinContext?.[context.entityId],
|
|
62
|
+
};
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
chapters: {
|
|
66
|
+
entityType: Entity.CHAPTER,
|
|
67
|
+
mutualDataProcessor: (
|
|
68
|
+
ids: string[],
|
|
69
|
+
context: Mutual<Entity.COURSE, Entity.CHAPTER>,
|
|
70
|
+
prejoinContext?: Record<string, any>,
|
|
71
|
+
) => ({
|
|
72
|
+
index: ids.indexOf(context.entityId),
|
|
73
|
+
moduleId: prejoinContext?.[context.entityId],
|
|
74
|
+
}),
|
|
75
|
+
},
|
|
76
|
+
learningActivities: {
|
|
77
|
+
entityType: Entity.LEARNING_ACTIVITY,
|
|
78
|
+
mutualDataProcessor: (
|
|
79
|
+
ids: string[],
|
|
80
|
+
context: Mutual<Entity.COURSE, Entity.LEARNING_ACTIVITY>,
|
|
81
|
+
prejoinContext?: Record<string, any>,
|
|
82
|
+
) => {
|
|
83
|
+
return {
|
|
84
|
+
index: ids.indexOf(context.entityId),
|
|
85
|
+
moduleId: prejoinContext?.[context.entityId],
|
|
86
|
+
};
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
|
|
91
|
+
prejoins: [
|
|
92
|
+
{
|
|
93
|
+
mutualField: 'chapters',
|
|
94
|
+
targetEntityType: Entity.CHAPTER,
|
|
95
|
+
entityPaths: [
|
|
96
|
+
{
|
|
97
|
+
entityType: Entity.COURSE,
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
entityType: Entity.MODULE,
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
entityType: Entity.CHAPTER,
|
|
104
|
+
},
|
|
105
|
+
],
|
|
106
|
+
},
|
|
107
|
+
{
|
|
108
|
+
mutualField: 'videos',
|
|
109
|
+
targetEntityType: Entity.VIDEO,
|
|
110
|
+
entityPaths: [
|
|
111
|
+
{
|
|
112
|
+
entityType: Entity.COURSE,
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
entityType: Entity.MODULE,
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
skipCache: true,
|
|
119
|
+
entityType: Entity.CHAPTER,
|
|
120
|
+
},
|
|
121
|
+
{
|
|
122
|
+
entityType: Entity.VIDEO,
|
|
123
|
+
},
|
|
124
|
+
],
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
mutualField: 'learningActivities',
|
|
128
|
+
targetEntityType: Entity.LEARNING_ACTIVITY,
|
|
129
|
+
entityPaths: [
|
|
130
|
+
{
|
|
131
|
+
entityType: Entity.COURSE,
|
|
132
|
+
},
|
|
133
|
+
{
|
|
134
|
+
entityType: Entity.MODULE,
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
skipCache: true,
|
|
138
|
+
entityType: Entity.CHAPTER,
|
|
139
|
+
},
|
|
140
|
+
{
|
|
141
|
+
entityType: Entity.LEARNING_ACTIVITY,
|
|
142
|
+
},
|
|
143
|
+
],
|
|
144
|
+
},
|
|
145
|
+
],
|
|
146
|
+
},
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
export default config;
|