rez_core 5.0.97 → 5.0.98
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/.claude/settings.local.json +26 -0
- package/.idea/250218_nodejs_core.iml +9 -0
- package/.idea/codeStyles/Project.xml +59 -0
- package/.idea/codeStyles/codeStyleConfig.xml +5 -0
- package/.idea/copilot.data.migration.agent.xml +6 -0
- package/.idea/copilot.data.migration.ask.xml +6 -0
- package/.idea/copilot.data.migration.ask2agent.xml +6 -0
- package/.idea/copilot.data.migration.edit.xml +6 -0
- package/.idea/inspectionProfiles/Project_Default.xml +6 -0
- package/.idea/misc.xml +6 -0
- package/.idea/modules.xml +8 -0
- package/.idea/prettier.xml +6 -0
- package/.idea/vcs.xml +6 -0
- package/.prettierrc +3 -3
- package/README.md +99 -99
- package/dist/module/auth/guards/role.guard.js +3 -3
- package/dist/module/filter/service/filter.service.js +22 -22
- package/dist/module/filter/service/filter.service.js.map +1 -1
- package/dist/module/integration/examples/usage.example.js +9 -9
- package/dist/module/meta/repository/attribute-master.repository.js +8 -8
- package/dist/module/meta/service/entity-dynamic.service.js +19 -19
- package/dist/module/meta/service/entity-list.service.js +3 -3
- package/dist/module/meta/service/entity-service-impl.service.js +3 -3
- package/dist/module/meta/service/media-data.service.js +6 -6
- package/dist/module/meta/service/resolver.service.js +15 -15
- package/dist/module/module/repository/menu.repository.js +4 -4
- package/dist/module/notification/service/notification.service.js +6 -6
- package/dist/module/user/controller/login.controller.js +18 -18
- package/dist/module/workflow/repository/action.repository.js +2 -2
- package/dist/module/workflow/repository/stage.repository.js +8 -8
- package/dist/module/workflow/service/action-template-mapping.service.js +12 -8
- package/dist/module/workflow/service/action-template-mapping.service.js.map +1 -1
- package/dist/module/workflow/service/action.service.js +10 -10
- package/dist/module/workflow/service/entity-modification.service.js +2 -2
- package/dist/module/workflow/service/task.service.js +5 -5
- package/dist/module/workflow-automation/service/schedule-handler.service.js +9 -9
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/utils/service/reflection-helper.service.js +2 -2
- package/docs/modules/event-driven-integration-design.md +91 -91
- package/docs/modules/integration.md +250 -250
- package/eslint.config.mjs +34 -34
- package/nest-cli.json +14 -14
- package/package.json +125 -125
- package/server.log +850 -0
- package/src/app.controller.ts +12 -12
- package/src/app.module.ts +66 -66
- package/src/app.service.ts +8 -8
- package/src/config/bull.config.ts +69 -69
- package/src/config/config.module.ts +17 -17
- package/src/config/database.config.ts +48 -48
- package/src/constant/global.constant.ts +67 -67
- package/src/core.module.ts +91 -91
- package/src/decorators/roles.decorator.ts +7 -7
- package/src/dtos/response.dto.ts +6 -6
- package/src/dtos/response.ts +5 -5
- package/src/index.ts +1 -1
- package/src/module/auth/auth.module.ts +49 -49
- package/src/module/auth/controller/auth.controller.ts +28 -28
- package/src/module/auth/guards/google-auth.guard.ts +9 -9
- package/src/module/auth/guards/jwt.guard.ts +22 -22
- package/src/module/auth/guards/role.guard.ts +68 -68
- package/src/module/auth/services/auth.service.ts +56 -56
- package/src/module/auth/services/jwt.service.ts +11 -11
- package/src/module/auth/strategies/google.strategy.ts +54 -54
- package/src/module/auth/strategies/jwt.strategy.ts +58 -58
- package/src/module/auth/strategies/local.strategy.ts +13 -13
- package/src/module/dashboard/controller/dashboard.controller.ts +36 -36
- package/src/module/dashboard/dashboard.module.ts +21 -21
- package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
- package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
- package/src/module/dashboard/repository/dashboard.repository.ts +51 -51
- package/src/module/dashboard/service/dashboard.service.ts +73 -73
- package/src/module/enterprise/controller/organization.controller.ts +36 -36
- package/src/module/enterprise/enterprise.module.ts +30 -30
- package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
- package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
- package/src/module/enterprise/entity/organization.entity.ts +92 -92
- package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
- package/src/module/enterprise/repository/organization.repository.ts +26 -26
- package/src/module/enterprise/repository/school.repository.ts +272 -272
- package/src/module/enterprise/service/brand.service.ts +5 -5
- package/src/module/enterprise/service/enterprise.service.ts +16 -16
- package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
- package/src/module/enterprise/service/organization.service.ts +145 -145
- package/src/module/entity_json/controller/entity_json.controller.ts +47 -47
- package/src/module/entity_json/entity/entityJson.entity.ts +39 -39
- package/src/module/entity_json/entity_json.module.ts +18 -18
- package/src/module/entity_json/service/entityJson.repository.ts +37 -37
- package/src/module/entity_json/service/entity_json.service.ts +234 -234
- package/src/module/filter/controller/filter.controller.ts +84 -84
- package/src/module/filter/dto/filter-request.dto.ts +38 -38
- package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
- package/src/module/filter/entity/saved-filter-master.entity.ts +23 -23
- package/src/module/filter/filter.module.ts +33 -33
- package/src/module/filter/repository/saved-filter.repository.ts +168 -168
- package/src/module/filter/repository/saved.filter-detail.repository.ts +19 -19
- package/src/module/filter/service/filter-evaluator.service.ts +82 -82
- package/src/module/filter/service/filter.service.ts +1307 -1304
- package/src/module/filter/service/saved-filter.service.ts +170 -170
- package/src/module/ics/controller/ics.controller.ts +21 -21
- package/src/module/ics/dto/ics.dto.ts +55 -55
- package/src/module/ics/ics.module.ts +13 -13
- package/src/module/ics/service/ics.service.ts +57 -57
- package/src/module/integration/controller/calender-event.controller.ts +31 -31
- package/src/module/integration/controller/integration.controller.ts +662 -662
- package/src/module/integration/controller/wrapper.controller.ts +37 -37
- package/src/module/integration/dto/create-config.dto.ts +526 -526
- package/src/module/integration/entity/integration-config.entity.ts +112 -112
- package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
- package/src/module/integration/entity/integration-source.entity.ts +17 -17
- package/src/module/integration/entity/user-integration.entity.ts +71 -71
- package/src/module/integration/examples/usage.example.ts +338 -338
- package/src/module/integration/factories/base.factory.ts +7 -7
- package/src/module/integration/factories/email.factory.ts +49 -49
- package/src/module/integration/factories/integration.factory.ts +121 -121
- package/src/module/integration/factories/sms.factory.ts +51 -51
- package/src/module/integration/factories/telephone.factory.ts +41 -41
- package/src/module/integration/factories/whatsapp.factory.ts +56 -56
- package/src/module/integration/integration.module.ts +110 -110
- package/src/module/integration/service/calendar-event.service.ts +118 -118
- package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
- package/src/module/integration/service/integration-queue.service.ts +229 -229
- package/src/module/integration/service/integration.service.ts +2634 -2634
- package/src/module/integration/service/oauth.service.ts +224 -224
- package/src/module/integration/service/wrapper.service.ts +716 -716
- package/src/module/integration/strategies/email/gmail-api.strategy.ts +280 -280
- package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
- package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
- package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +260 -260
- package/src/module/integration/strategies/integration.strategy.ts +97 -97
- package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
- package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
- package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
- package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
- package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
- package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
- package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
- package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
- package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
- package/src/module/layout/controller/layout.controller.ts +47 -47
- package/src/module/layout/entity/header-items.entity.ts +28 -28
- package/src/module/layout/entity/header-section.entity.ts +19 -19
- package/src/module/layout/layout.module.ts +21 -21
- package/src/module/layout/repository/header-items.repository.ts +18 -18
- package/src/module/layout/repository/header-section.repository.ts +22 -22
- package/src/module/layout/service/header-section.service.ts +25 -25
- package/src/module/layout_preference/controller/layout_preference.controller.ts +73 -73
- package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
- package/src/module/layout_preference/layout_preference.module.ts +22 -22
- package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
- package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
- package/src/module/lead/controller/lead.controller.ts +30 -30
- package/src/module/lead/lead.module.ts +14 -14
- package/src/module/lead/repository/lead.repository.ts +41 -41
- package/src/module/lead/service/lead.service.ts +54 -54
- package/src/module/linked_attributes/controller/linked_attributes.controller.ts +37 -37
- package/src/module/linked_attributes/entity/linked_attribute.entity.ts +51 -51
- package/src/module/linked_attributes/linked_attributes.module.ts +16 -16
- package/src/module/linked_attributes/repository/linked_attribute.repository.ts +12 -12
- package/src/module/linked_attributes/service/linked_attributes.service.ts +75 -75
- package/src/module/listmaster/controller/list-master.controller.ts +230 -230
- package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
- package/src/module/listmaster/entity/list-master.entity.ts +33 -33
- package/src/module/listmaster/listmaster.module.ts +46 -46
- package/src/module/listmaster/repository/list-master-items.repository.ts +173 -173
- package/src/module/listmaster/repository/list-master.repository.ts +56 -56
- package/src/module/listmaster/service/list-master-engine.ts +19 -19
- package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
- package/src/module/listmaster/service/list-master-item.service.ts +281 -281
- package/src/module/listmaster/service/list-master-registry.ts +15 -15
- package/src/module/listmaster/service/list-master.service.ts +535 -535
- package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
- package/src/module/mapper/controller/mapper.controller.ts +20 -20
- package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
- package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
- package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
- package/src/module/mapper/entity/mapper.entity.ts +16 -16
- package/src/module/mapper/mapper.module.ts +35 -35
- package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
- package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
- package/src/module/mapper/repository/mapper.repository.ts +32 -32
- package/src/module/mapper/service/field-mapper.service.ts +269 -269
- package/src/module/mapper/service/mapper.service.ts +81 -81
- package/src/module/master/controller/master.controller.ts +74 -74
- package/src/module/master/service/master.service.ts +483 -483
- package/src/module/meta/controller/app-master.controller.ts +38 -38
- package/src/module/meta/controller/attribute-master.controller.ts +84 -84
- package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
- package/src/module/meta/controller/entity-master.controller.ts +41 -41
- package/src/module/meta/controller/entity-relation.controller.ts +36 -36
- package/src/module/meta/controller/entity.controller.ts +392 -392
- package/src/module/meta/controller/entity.public.controller.ts +75 -75
- package/src/module/meta/controller/media.controller.ts +107 -107
- package/src/module/meta/controller/meta.controller.ts +96 -96
- package/src/module/meta/controller/view-master.controller.ts +86 -86
- package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
- package/src/module/meta/dto/entity-tab.dto.ts +4 -4
- package/src/module/meta/dto/entity-table.dto.ts +9 -9
- package/src/module/meta/entity/app-master.entity.ts +34 -34
- package/src/module/meta/entity/attribute-master.entity.ts +92 -92
- package/src/module/meta/entity/base-entity.entity.ts +75 -75
- package/src/module/meta/entity/entity-master.entity.ts +85 -85
- package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
- package/src/module/meta/entity/entity-relation.entity.ts +23 -23
- package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
- package/src/module/meta/entity/entity-table.entity.ts +50 -50
- package/src/module/meta/entity/media-data.entity.ts +32 -32
- package/src/module/meta/entity/preference.entity.ts +62 -62
- package/src/module/meta/entity/view-master.entity.ts +41 -41
- package/src/module/meta/entity.module.ts +166 -166
- package/src/module/meta/repository/app-master.repository.ts +20 -20
- package/src/module/meta/repository/attribute-master.repository.ts +156 -156
- package/src/module/meta/repository/entity-attribute-update.repository.ts +48 -48
- package/src/module/meta/repository/entity-master.repository.ts +110 -110
- package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
- package/src/module/meta/repository/entity-table.repository.ts +53 -53
- package/src/module/meta/repository/media-data.repository.ts +50 -50
- package/src/module/meta/repository/preference.repository.ts +20 -20
- package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
- package/src/module/meta/repository/view-master.repository.ts +42 -42
- package/src/module/meta/service/app-master.service.ts +37 -37
- package/src/module/meta/service/attribute-master.service.ts +130 -130
- package/src/module/meta/service/common.service.ts +9 -9
- package/src/module/meta/service/entity-attribute-update.service.ts +28 -28
- package/src/module/meta/service/entity-dynamic.service.ts +818 -818
- package/src/module/meta/service/entity-list.service.ts +205 -205
- package/src/module/meta/service/entity-master.service.ts +171 -171
- package/src/module/meta/service/entity-realation-data.service.ts +9 -9
- package/src/module/meta/service/entity-relation.service.ts +69 -69
- package/src/module/meta/service/entity-service-impl.service.ts +525 -525
- package/src/module/meta/service/entity-table-column.service.ts +39 -39
- package/src/module/meta/service/entity-table.service.ts +150 -150
- package/src/module/meta/service/entity-validation.service.ts +187 -187
- package/src/module/meta/service/entity.service.ts +67 -67
- package/src/module/meta/service/field-group.service.ts +103 -103
- package/src/module/meta/service/media-data.service.ts +510 -510
- package/src/module/meta/service/populate-meta.service.ts +222 -222
- package/src/module/meta/service/preference.service.ts +16 -16
- package/src/module/meta/service/resolver.service.ts +293 -293
- package/src/module/meta/service/section-master.service.ts +104 -104
- package/src/module/meta/service/update-form-json.service.ts +22 -22
- package/src/module/meta/service/user-app-mapping.service.ts +17 -17
- package/src/module/meta/service/view-master.service.ts +127 -127
- package/src/module/microservice-client/microservice-clients.module.ts +13 -13
- package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
- package/src/module/microservice-client/service/microservice-clients.ts +4 -4
- package/src/module/module/controller/menu.controller.ts +15 -15
- package/src/module/module/controller/module-access.controller.ts +134 -134
- package/src/module/module/entity/menu.entity.ts +43 -43
- package/src/module/module/entity/module-access.entity.ts +25 -25
- package/src/module/module/entity/module-action.entity.ts +17 -17
- package/src/module/module/entity/module.entity.ts +52 -52
- package/src/module/module/module.module.ts +42 -42
- package/src/module/module/repository/menu.repository.ts +184 -184
- package/src/module/module/repository/module-access.repository.ts +344 -344
- package/src/module/module/service/menu.service.ts +82 -82
- package/src/module/module/service/module-access.service.ts +199 -199
- package/src/module/notification/controller/notification.controller.ts +58 -58
- package/src/module/notification/controller/otp.controller.ts +117 -117
- package/src/module/notification/entity/notification.entity.ts +26 -26
- package/src/module/notification/entity/otp.entity.ts +28 -28
- package/src/module/notification/firebase-admin.config.ts +22 -22
- package/src/module/notification/notification.module.ts +69 -69
- package/src/module/notification/repository/otp.repository.ts +27 -27
- package/src/module/notification/service/email.service.ts +127 -127
- package/src/module/notification/service/notification.service.ts +164 -164
- package/src/module/notification/service/otp.service.ts +133 -133
- package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
- package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
- package/src/module/third-party-module/service/api-registry.service.ts +13 -13
- package/src/module/third-party-module/third-party.module.ts +12 -12
- package/src/module/user/controller/login.controller.ts +198 -198
- package/src/module/user/controller/user.controller.ts +40 -40
- package/src/module/user/dto/create-user.dto.ts +62 -62
- package/src/module/user/dto/update-user.dto.ts +4 -4
- package/src/module/user/entity/role.entity.ts +33 -33
- package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
- package/src/module/user/entity/user-session.entity.ts +73 -73
- package/src/module/user/entity/user.entity.ts +59 -59
- package/src/module/user/repository/role.repository.ts +96 -96
- package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
- package/src/module/user/repository/user.repository.ts +50 -50
- package/src/module/user/repository/userSession.repository.ts +33 -33
- package/src/module/user/service/login.service.ts +326 -326
- package/src/module/user/service/role.service.ts +197 -197
- package/src/module/user/service/user-role-mapping.service.ts +98 -98
- package/src/module/user/service/user-session.service.ts +177 -177
- package/src/module/user/service/user.service.ts +368 -368
- package/src/module/user/user.module.ts +65 -65
- package/src/module/workflow/controller/action-category.controller.ts +54 -54
- package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
- package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
- package/src/module/workflow/controller/action.controller.ts +111 -111
- package/src/module/workflow/controller/activity-log.controller.ts +55 -55
- package/src/module/workflow/controller/comm-template.controller.ts +43 -43
- package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
- package/src/module/workflow/controller/form-master.controller.ts +43 -43
- package/src/module/workflow/controller/stage-group.controller.ts +48 -48
- package/src/module/workflow/controller/stage.controller.ts +50 -50
- package/src/module/workflow/controller/task.controller.ts +77 -77
- package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
- package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
- package/src/module/workflow/controller/workflow.controller.ts +67 -67
- package/src/module/workflow/entity/action-category.entity.ts +38 -38
- package/src/module/workflow/entity/action-data.entity.ts +55 -55
- package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
- package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
- package/src/module/workflow/entity/action.entity.ts +53 -53
- package/src/module/workflow/entity/activity-log.entity.ts +43 -43
- package/src/module/workflow/entity/comm-template.entity.ts +43 -43
- package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
- package/src/module/workflow/entity/form.entity.ts +25 -25
- package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
- package/src/module/workflow/entity/stage-group.entity.ts +23 -23
- package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
- package/src/module/workflow/entity/stage.entity.ts +20 -20
- package/src/module/workflow/entity/task-data.entity.ts +88 -88
- package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
- package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
- package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
- package/src/module/workflow/entity/workflow.entity.ts +20 -20
- package/src/module/workflow/repository/action-category.repository.ts +79 -79
- package/src/module/workflow/repository/action-data.repository.ts +346 -346
- package/src/module/workflow/repository/action.repository.ts +338 -338
- package/src/module/workflow/repository/activity-log.repository.ts +148 -148
- package/src/module/workflow/repository/comm-template.repository.ts +157 -157
- package/src/module/workflow/repository/form-master.repository.ts +50 -50
- package/src/module/workflow/repository/stage-group.repository.ts +186 -186
- package/src/module/workflow/repository/stage-movement.repository.ts +262 -262
- package/src/module/workflow/repository/stage.repository.ts +160 -160
- package/src/module/workflow/repository/task.repository.ts +151 -151
- package/src/module/workflow/repository/workflow.repository.ts +42 -42
- package/src/module/workflow/service/action-category.service.ts +33 -33
- package/src/module/workflow/service/action-data.service.ts +62 -62
- package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
- package/src/module/workflow/service/action-template-mapping.service.ts +140 -131
- package/src/module/workflow/service/action.service.ts +306 -306
- package/src/module/workflow/service/activity-log.service.ts +107 -107
- package/src/module/workflow/service/comm-template.service.ts +180 -180
- package/src/module/workflow/service/entity-modification.service.ts +61 -61
- package/src/module/workflow/service/form-master.service.ts +35 -35
- package/src/module/workflow/service/populate-workflow.service.ts +320 -320
- package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
- package/src/module/workflow/service/stage-group.service.ts +344 -344
- package/src/module/workflow/service/stage.service.ts +207 -207
- package/src/module/workflow/service/task.service.ts +546 -546
- package/src/module/workflow/service/workflow-list-master.service.ts +68 -68
- package/src/module/workflow/service/workflow-meta.service.ts +639 -639
- package/src/module/workflow/service/workflow.service.ts +213 -213
- package/src/module/workflow/workflow.module.ts +180 -180
- package/src/module/workflow-automation/SCHEDULING_GUIDE.md +145 -145
- package/src/module/workflow-automation/controller/workflow-automation.controller.ts +43 -43
- package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
- package/src/module/workflow-automation/entity/workflow-automation.entity.ts +40 -40
- package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
- package/src/module/workflow-automation/interface/action.interface.ts +5 -5
- package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
- package/src/module/workflow-automation/service/schedule-handler.service.ts +168 -168
- package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +219 -219
- package/src/module/workflow-automation/service/workflow-automation.service.ts +515 -515
- package/src/module/workflow-automation/workflow-automation.module.ts +54 -54
- package/src/module/workflow-schedule/INSTALLATION.md +244 -244
- package/src/module/workflow-schedule/MULTI_PROJECT_GUIDE.md +196 -196
- package/src/module/workflow-schedule/README.md +422 -422
- package/src/module/workflow-schedule/constants/schedule.constants.ts +48 -48
- package/src/module/workflow-schedule/controller/workflow-schedule.controller.ts +255 -255
- package/src/module/workflow-schedule/docs/CLAUDE_CODE_GUIDE.md +510 -510
- package/src/module/workflow-schedule/docs/CLAUDE_CODE_PROMPT.md +362 -362
- package/src/module/workflow-schedule/docs/RUN_CLAUDE_CODE.sh +68 -68
- package/src/module/workflow-schedule/dto/create-schedule.dto.ts +147 -147
- package/src/module/workflow-schedule/dto/get-execution-logs.dto.ts +119 -119
- package/src/module/workflow-schedule/dto/update-schedule.dto.ts +96 -96
- package/src/module/workflow-schedule/entities/scheduled-workflow.entity.ts +148 -148
- package/src/module/workflow-schedule/entities/workflow-execution-log.entity.ts +154 -154
- package/src/module/workflow-schedule/interfaces/schedule-job-data.interface.ts +53 -53
- package/src/module/workflow-schedule/interfaces/workflow-schedule-options.interface.ts +12 -12
- package/src/module/workflow-schedule/processors/schedule.processor.ts +620 -620
- package/src/module/workflow-schedule/service/workflow-schedule.service.ts +598 -598
- package/src/module/workflow-schedule/workflow-schedule.module.ts +67 -67
- package/src/resources/dev.properties.yaml +31 -31
- package/src/resources/local.properties.yaml +27 -27
- package/src/resources/properties.module.ts +12 -12
- package/src/resources/properties.yaml.ts +11 -11
- package/src/resources/uat.properties.yaml +31 -31
- package/src/table.config.ts +133 -133
- package/src/utils/dto/excel-data.dto.ts +14 -14
- package/src/utils/dto/excelsheet-data.dto.ts +5 -5
- package/src/utils/service/base64util.service.ts +18 -18
- package/src/utils/service/clockIDGenUtil.service.ts +21 -21
- package/src/utils/service/codeGenerator.service.ts +22 -22
- package/src/utils/service/dateUtil.service.ts +17 -17
- package/src/utils/service/encryptUtil.service.ts +97 -97
- package/src/utils/service/excel-helper.service.ts +72 -72
- package/src/utils/service/excelUtil.service.ts +15 -15
- package/src/utils/service/file-util.service.ts +11 -11
- package/src/utils/service/json-util.service.ts +23 -23
- package/src/utils/service/loggingUtil.service.ts +88 -88
- package/src/utils/service/reflection-helper.service.ts +62 -62
- package/src/utils/service/wbsCodeGen.service.ts +8 -8
- package/src/utils/utils.module.ts +27 -27
- package/tsconfig.build.json +4 -4
- package/tsconfig.json +24 -24
- package/.vscode/extensions.json +0 -5
|
@@ -1,262 +1,262 @@
|
|
|
1
|
-
import { Injectable } from '@nestjs/common';
|
|
2
|
-
import { InjectRepository } from '@nestjs/typeorm';
|
|
3
|
-
import { MoreThan, Repository } from 'typeorm';
|
|
4
|
-
import { WorkflowLevelMappingEntity } from '../entity/workflow-level-mapping.entity';
|
|
5
|
-
import { StageGroup } from '../entity/stage-group.entity';
|
|
6
|
-
import { Stage } from '../entity/stage.entity';
|
|
7
|
-
import { UserData } from 'src/module/user/entity/user.entity';
|
|
8
|
-
import { ReflectionHelper } from '../../../utils/service/reflection-helper.service';
|
|
9
|
-
import { ActionDataEntity } from '../entity/action-data.entity';
|
|
10
|
-
import { TaskDataEntity } from '../entity/task-data.entity';
|
|
11
|
-
|
|
12
|
-
@Injectable()
|
|
13
|
-
export class StageMovementRepository {
|
|
14
|
-
constructor(
|
|
15
|
-
@InjectRepository(WorkflowLevelMappingEntity)
|
|
16
|
-
private readonly workflowLevelMappingRepo: Repository<WorkflowLevelMappingEntity>,
|
|
17
|
-
@InjectRepository(StageGroup)
|
|
18
|
-
private readonly stageGroupRepo: Repository<StageGroup>,
|
|
19
|
-
@InjectRepository(Stage)
|
|
20
|
-
private readonly stageRepo: Repository<Stage>,
|
|
21
|
-
private readonly reflectionHelper: ReflectionHelper,
|
|
22
|
-
@InjectRepository(ActionDataEntity)
|
|
23
|
-
private readonly actionDataEntityRepository: Repository<ActionDataEntity>,
|
|
24
|
-
@InjectRepository(TaskDataEntity)
|
|
25
|
-
private readonly taskDataEntityRepository: Repository<TaskDataEntity>,
|
|
26
|
-
) {}
|
|
27
|
-
|
|
28
|
-
async getFirstStage({
|
|
29
|
-
loggedInUser,
|
|
30
|
-
mapped_entity_type,
|
|
31
|
-
mapped_entity_id,
|
|
32
|
-
}: {
|
|
33
|
-
loggedInUser: any;
|
|
34
|
-
mapped_entity_type: string;
|
|
35
|
-
mapped_entity_id: string | number;
|
|
36
|
-
}): Promise<any | null> {
|
|
37
|
-
// Try finding mapping at user's level
|
|
38
|
-
let workflowLevelMapping = await this.workflowLevelMappingRepo.findOne({
|
|
39
|
-
where: {
|
|
40
|
-
mapped_level_type: loggedInUser.level_type,
|
|
41
|
-
mapped_level_id: loggedInUser.level_id,
|
|
42
|
-
},
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
// If not found, fallback to organization-level mapping
|
|
46
|
-
if (!workflowLevelMapping) {
|
|
47
|
-
workflowLevelMapping = await this.workflowLevelMappingRepo.findOne({
|
|
48
|
-
where: {
|
|
49
|
-
mapped_level_type: 'ORG',
|
|
50
|
-
mapped_level_id: loggedInUser.organization_id,
|
|
51
|
-
},
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
// If still not found, return null
|
|
56
|
-
if (!workflowLevelMapping) return null;
|
|
57
|
-
|
|
58
|
-
// Find the stage group for this workflow
|
|
59
|
-
const stageGroup = await this.stageGroupRepo.findOne({
|
|
60
|
-
where: {
|
|
61
|
-
workflow_id: workflowLevelMapping.workflow_id,
|
|
62
|
-
},
|
|
63
|
-
order: { id: 'ASC' }, // Ensure you get the earliest/first group if needed
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
if (!stageGroup) return null;
|
|
67
|
-
|
|
68
|
-
// Find the first stage within this group
|
|
69
|
-
const firstStage = await this.stageRepo.findOne({
|
|
70
|
-
where: {
|
|
71
|
-
stage_group_id: stageGroup.id,
|
|
72
|
-
},
|
|
73
|
-
order: { id: 'ASC' }, // Change ordering as per your "first" logic
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
if (!firstStage) return null;
|
|
77
|
-
|
|
78
|
-
// Return comprehensive result
|
|
79
|
-
return {
|
|
80
|
-
mappingUsed: workflowLevelMapping,
|
|
81
|
-
stageGroup,
|
|
82
|
-
firstStage,
|
|
83
|
-
};
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
// async getNextStage(
|
|
87
|
-
// stageGroupId: number,
|
|
88
|
-
// currentStageId: number,
|
|
89
|
-
// ): Promise<any | null> {
|
|
90
|
-
// // 1. Get current stage to find its sequence number
|
|
91
|
-
// const currentStage = await this.stageRepo.findOne({
|
|
92
|
-
// where: { id: currentStageId, stage_group_id: stageGroupId },
|
|
93
|
-
// });
|
|
94
|
-
// if (!currentStage) return null;
|
|
95
|
-
|
|
96
|
-
// // 2. Find the next stage with sequence just after the current one
|
|
97
|
-
// const nextStage = await this.stageRepo.findOne({
|
|
98
|
-
// where: {
|
|
99
|
-
// stage_group_id: stageGroupId,
|
|
100
|
-
// sequence: MoreThan(currentStage.sequence),
|
|
101
|
-
// },
|
|
102
|
-
// order: { sequence: 'ASC' },
|
|
103
|
-
// });
|
|
104
|
-
|
|
105
|
-
// return nextStage || null;
|
|
106
|
-
// }
|
|
107
|
-
|
|
108
|
-
// async getNextStageGroup(
|
|
109
|
-
// currentStageGroupId: number,
|
|
110
|
-
// ): Promise<StageGroup | null> {
|
|
111
|
-
// // 1. Get current stage group
|
|
112
|
-
// const currentStageGroup = await this.stageGroupRepo.findOne({
|
|
113
|
-
// where: { id: currentStageGroupId },
|
|
114
|
-
// });
|
|
115
|
-
// if (!currentStageGroup) return null;
|
|
116
|
-
// // 2. Find the next stage group with a higher sequence
|
|
117
|
-
// const nextStageGroup = await this.stageGroupRepo.findOne({
|
|
118
|
-
// where: {
|
|
119
|
-
// sequence: MoreThan(currentStageGroup.sequence),
|
|
120
|
-
// },
|
|
121
|
-
// order: { sequence: 'ASC' }, // Get the immediate next
|
|
122
|
-
// });
|
|
123
|
-
// return nextStageGroup || null;
|
|
124
|
-
// }
|
|
125
|
-
|
|
126
|
-
async getNextStage(
|
|
127
|
-
stageGroupId: number,
|
|
128
|
-
currentStageId: number,
|
|
129
|
-
): Promise<any | null> {
|
|
130
|
-
const allStages = await this.stageRepo.find({
|
|
131
|
-
where: { stage_group_id: stageGroupId },
|
|
132
|
-
order: { sequence: 'ASC' },
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
if (currentStageId === 0) return allStages.length > 0 ? allStages[0] : null;
|
|
136
|
-
|
|
137
|
-
const currentStage = allStages.find((s) => s.id == currentStageId);
|
|
138
|
-
if (!currentStage) return null;
|
|
139
|
-
|
|
140
|
-
// Filter for stages with a greater sequence, then pick the smallest one
|
|
141
|
-
const higherStages = allStages
|
|
142
|
-
.filter((s) => s.sequence > currentStage.sequence)
|
|
143
|
-
.sort((a, b) => a.sequence - b.sequence);
|
|
144
|
-
|
|
145
|
-
return higherStages.length > 0 ? higherStages[0] : null;
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
async getNextStageGroup(currentStageGroupId: number): Promise<any | null> {
|
|
149
|
-
const currentStageGroup = await this.stageGroupRepo.findOne({
|
|
150
|
-
where: { id: currentStageGroupId },
|
|
151
|
-
});
|
|
152
|
-
if (!currentStageGroup) return null;
|
|
153
|
-
|
|
154
|
-
//get workflow id of current stage group
|
|
155
|
-
const workflowId = currentStageGroup.workflow_id;
|
|
156
|
-
|
|
157
|
-
// Find the next stage group with a higher sequence
|
|
158
|
-
const nextStageGroup = await this.stageGroupRepo.findOne({
|
|
159
|
-
where: {
|
|
160
|
-
workflow_id: workflowId,
|
|
161
|
-
sequence: MoreThan(currentStageGroup.sequence),
|
|
162
|
-
},
|
|
163
|
-
order: { sequence: 'ASC' }, // Get the immediate next
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
return nextStageGroup || null;
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
async getNextStageOrFirstOfNextGroup(
|
|
170
|
-
stageGroupId: number,
|
|
171
|
-
currentStageId: number,
|
|
172
|
-
): Promise<any | null> {
|
|
173
|
-
// 1. Try to get the next stage in same group
|
|
174
|
-
const nextStage = await this.getNextStage(stageGroupId, currentStageId);
|
|
175
|
-
if (nextStage) return nextStage;
|
|
176
|
-
|
|
177
|
-
// 2. No next stage. Try to get next stage group
|
|
178
|
-
const nextStageGroup = await this.getNextStageGroup(stageGroupId);
|
|
179
|
-
if (!nextStageGroup) return null;
|
|
180
|
-
|
|
181
|
-
const nextStageGroupFirstStage = await this.getNextStage(
|
|
182
|
-
nextStageGroup.id,
|
|
183
|
-
0,
|
|
184
|
-
);
|
|
185
|
-
return nextStageGroupFirstStage || null;
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
async getAllActionByStageId(stageId: number): Promise<any> {
|
|
189
|
-
const actionRepo = this.reflectionHelper.getRepoService('ActionEntity');
|
|
190
|
-
const result = await actionRepo
|
|
191
|
-
.createQueryBuilder('a')
|
|
192
|
-
.innerJoin(
|
|
193
|
-
'frm_wf_stage_action_mapping',
|
|
194
|
-
'm',
|
|
195
|
-
'a.id = m.action_id::bigint',
|
|
196
|
-
)
|
|
197
|
-
.leftJoin(
|
|
198
|
-
'frm_wf_action_category',
|
|
199
|
-
'ac',
|
|
200
|
-
'a.action_category::bigint = ac.id',
|
|
201
|
-
)
|
|
202
|
-
.leftJoin(
|
|
203
|
-
'frm_wf_action_resources_mapping',
|
|
204
|
-
'arm',
|
|
205
|
-
'm.id = arm.stg_act_mapping_id::bigint',
|
|
206
|
-
)
|
|
207
|
-
.where('m.stage_id::bigint = :stageId', { stageId: Number(stageId) })
|
|
208
|
-
.select([
|
|
209
|
-
'a.*',
|
|
210
|
-
'm.id AS mapping_id',
|
|
211
|
-
'm.stage_id AS stage_id',
|
|
212
|
-
'ac.code AS action_category_code',
|
|
213
|
-
'arm.form_id AS form_id',
|
|
214
|
-
])
|
|
215
|
-
.orderBy('a.sequence', 'ASC')
|
|
216
|
-
.getRawMany();
|
|
217
|
-
|
|
218
|
-
// Use for..of with await instead of map
|
|
219
|
-
const actionResourceMappingRepo = this.reflectionHelper.getRepoService(
|
|
220
|
-
'ActionResourcesMapping',
|
|
221
|
-
);
|
|
222
|
-
for (const item of result) {
|
|
223
|
-
if (item.action_category_code === 'SDFM') {
|
|
224
|
-
const actionData = await actionResourceMappingRepo.findOne({
|
|
225
|
-
where: {
|
|
226
|
-
stg_act_mapping_id: item.mapping_id,
|
|
227
|
-
},
|
|
228
|
-
});
|
|
229
|
-
|
|
230
|
-
item.form_id = actionData?.form_id || null;
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
return result;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
async saveActionData(action: any, loggedInUser: UserData): Promise<any> {
|
|
238
|
-
// Implement the logic to save action data
|
|
239
|
-
|
|
240
|
-
if (action.length > 0) {
|
|
241
|
-
for (const act of action) {
|
|
242
|
-
await this.actionDataEntityRepository.save({
|
|
243
|
-
stage_id: act.stage_id,
|
|
244
|
-
user_id: loggedInUser.id,
|
|
245
|
-
action_id: act.id,
|
|
246
|
-
});
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
async saveTaskData(actionData: any, loggedInUser: UserData): Promise<any> {
|
|
252
|
-
// Implement the logic to save task data
|
|
253
|
-
if (actionData.length > 0) {
|
|
254
|
-
for (const action of actionData) {
|
|
255
|
-
await this.taskDataEntityRepository.save({
|
|
256
|
-
action_id: action.id,
|
|
257
|
-
user_id: String(loggedInUser.id),
|
|
258
|
-
});
|
|
259
|
-
}
|
|
260
|
-
}
|
|
261
|
-
}
|
|
262
|
-
}
|
|
1
|
+
import { Injectable } from '@nestjs/common';
|
|
2
|
+
import { InjectRepository } from '@nestjs/typeorm';
|
|
3
|
+
import { MoreThan, Repository } from 'typeorm';
|
|
4
|
+
import { WorkflowLevelMappingEntity } from '../entity/workflow-level-mapping.entity';
|
|
5
|
+
import { StageGroup } from '../entity/stage-group.entity';
|
|
6
|
+
import { Stage } from '../entity/stage.entity';
|
|
7
|
+
import { UserData } from 'src/module/user/entity/user.entity';
|
|
8
|
+
import { ReflectionHelper } from '../../../utils/service/reflection-helper.service';
|
|
9
|
+
import { ActionDataEntity } from '../entity/action-data.entity';
|
|
10
|
+
import { TaskDataEntity } from '../entity/task-data.entity';
|
|
11
|
+
|
|
12
|
+
@Injectable()
|
|
13
|
+
export class StageMovementRepository {
|
|
14
|
+
constructor(
|
|
15
|
+
@InjectRepository(WorkflowLevelMappingEntity)
|
|
16
|
+
private readonly workflowLevelMappingRepo: Repository<WorkflowLevelMappingEntity>,
|
|
17
|
+
@InjectRepository(StageGroup)
|
|
18
|
+
private readonly stageGroupRepo: Repository<StageGroup>,
|
|
19
|
+
@InjectRepository(Stage)
|
|
20
|
+
private readonly stageRepo: Repository<Stage>,
|
|
21
|
+
private readonly reflectionHelper: ReflectionHelper,
|
|
22
|
+
@InjectRepository(ActionDataEntity)
|
|
23
|
+
private readonly actionDataEntityRepository: Repository<ActionDataEntity>,
|
|
24
|
+
@InjectRepository(TaskDataEntity)
|
|
25
|
+
private readonly taskDataEntityRepository: Repository<TaskDataEntity>,
|
|
26
|
+
) {}
|
|
27
|
+
|
|
28
|
+
async getFirstStage({
|
|
29
|
+
loggedInUser,
|
|
30
|
+
mapped_entity_type,
|
|
31
|
+
mapped_entity_id,
|
|
32
|
+
}: {
|
|
33
|
+
loggedInUser: any;
|
|
34
|
+
mapped_entity_type: string;
|
|
35
|
+
mapped_entity_id: string | number;
|
|
36
|
+
}): Promise<any | null> {
|
|
37
|
+
// Try finding mapping at user's level
|
|
38
|
+
let workflowLevelMapping = await this.workflowLevelMappingRepo.findOne({
|
|
39
|
+
where: {
|
|
40
|
+
mapped_level_type: loggedInUser.level_type,
|
|
41
|
+
mapped_level_id: loggedInUser.level_id,
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
// If not found, fallback to organization-level mapping
|
|
46
|
+
if (!workflowLevelMapping) {
|
|
47
|
+
workflowLevelMapping = await this.workflowLevelMappingRepo.findOne({
|
|
48
|
+
where: {
|
|
49
|
+
mapped_level_type: 'ORG',
|
|
50
|
+
mapped_level_id: loggedInUser.organization_id,
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// If still not found, return null
|
|
56
|
+
if (!workflowLevelMapping) return null;
|
|
57
|
+
|
|
58
|
+
// Find the stage group for this workflow
|
|
59
|
+
const stageGroup = await this.stageGroupRepo.findOne({
|
|
60
|
+
where: {
|
|
61
|
+
workflow_id: workflowLevelMapping.workflow_id,
|
|
62
|
+
},
|
|
63
|
+
order: { id: 'ASC' }, // Ensure you get the earliest/first group if needed
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
if (!stageGroup) return null;
|
|
67
|
+
|
|
68
|
+
// Find the first stage within this group
|
|
69
|
+
const firstStage = await this.stageRepo.findOne({
|
|
70
|
+
where: {
|
|
71
|
+
stage_group_id: stageGroup.id,
|
|
72
|
+
},
|
|
73
|
+
order: { id: 'ASC' }, // Change ordering as per your "first" logic
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
if (!firstStage) return null;
|
|
77
|
+
|
|
78
|
+
// Return comprehensive result
|
|
79
|
+
return {
|
|
80
|
+
mappingUsed: workflowLevelMapping,
|
|
81
|
+
stageGroup,
|
|
82
|
+
firstStage,
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// async getNextStage(
|
|
87
|
+
// stageGroupId: number,
|
|
88
|
+
// currentStageId: number,
|
|
89
|
+
// ): Promise<any | null> {
|
|
90
|
+
// // 1. Get current stage to find its sequence number
|
|
91
|
+
// const currentStage = await this.stageRepo.findOne({
|
|
92
|
+
// where: { id: currentStageId, stage_group_id: stageGroupId },
|
|
93
|
+
// });
|
|
94
|
+
// if (!currentStage) return null;
|
|
95
|
+
|
|
96
|
+
// // 2. Find the next stage with sequence just after the current one
|
|
97
|
+
// const nextStage = await this.stageRepo.findOne({
|
|
98
|
+
// where: {
|
|
99
|
+
// stage_group_id: stageGroupId,
|
|
100
|
+
// sequence: MoreThan(currentStage.sequence),
|
|
101
|
+
// },
|
|
102
|
+
// order: { sequence: 'ASC' },
|
|
103
|
+
// });
|
|
104
|
+
|
|
105
|
+
// return nextStage || null;
|
|
106
|
+
// }
|
|
107
|
+
|
|
108
|
+
// async getNextStageGroup(
|
|
109
|
+
// currentStageGroupId: number,
|
|
110
|
+
// ): Promise<StageGroup | null> {
|
|
111
|
+
// // 1. Get current stage group
|
|
112
|
+
// const currentStageGroup = await this.stageGroupRepo.findOne({
|
|
113
|
+
// where: { id: currentStageGroupId },
|
|
114
|
+
// });
|
|
115
|
+
// if (!currentStageGroup) return null;
|
|
116
|
+
// // 2. Find the next stage group with a higher sequence
|
|
117
|
+
// const nextStageGroup = await this.stageGroupRepo.findOne({
|
|
118
|
+
// where: {
|
|
119
|
+
// sequence: MoreThan(currentStageGroup.sequence),
|
|
120
|
+
// },
|
|
121
|
+
// order: { sequence: 'ASC' }, // Get the immediate next
|
|
122
|
+
// });
|
|
123
|
+
// return nextStageGroup || null;
|
|
124
|
+
// }
|
|
125
|
+
|
|
126
|
+
async getNextStage(
|
|
127
|
+
stageGroupId: number,
|
|
128
|
+
currentStageId: number,
|
|
129
|
+
): Promise<any | null> {
|
|
130
|
+
const allStages = await this.stageRepo.find({
|
|
131
|
+
where: { stage_group_id: stageGroupId },
|
|
132
|
+
order: { sequence: 'ASC' },
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
if (currentStageId === 0) return allStages.length > 0 ? allStages[0] : null;
|
|
136
|
+
|
|
137
|
+
const currentStage = allStages.find((s) => s.id == currentStageId);
|
|
138
|
+
if (!currentStage) return null;
|
|
139
|
+
|
|
140
|
+
// Filter for stages with a greater sequence, then pick the smallest one
|
|
141
|
+
const higherStages = allStages
|
|
142
|
+
.filter((s) => s.sequence > currentStage.sequence)
|
|
143
|
+
.sort((a, b) => a.sequence - b.sequence);
|
|
144
|
+
|
|
145
|
+
return higherStages.length > 0 ? higherStages[0] : null;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
async getNextStageGroup(currentStageGroupId: number): Promise<any | null> {
|
|
149
|
+
const currentStageGroup = await this.stageGroupRepo.findOne({
|
|
150
|
+
where: { id: currentStageGroupId },
|
|
151
|
+
});
|
|
152
|
+
if (!currentStageGroup) return null;
|
|
153
|
+
|
|
154
|
+
//get workflow id of current stage group
|
|
155
|
+
const workflowId = currentStageGroup.workflow_id;
|
|
156
|
+
|
|
157
|
+
// Find the next stage group with a higher sequence
|
|
158
|
+
const nextStageGroup = await this.stageGroupRepo.findOne({
|
|
159
|
+
where: {
|
|
160
|
+
workflow_id: workflowId,
|
|
161
|
+
sequence: MoreThan(currentStageGroup.sequence),
|
|
162
|
+
},
|
|
163
|
+
order: { sequence: 'ASC' }, // Get the immediate next
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
return nextStageGroup || null;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
async getNextStageOrFirstOfNextGroup(
|
|
170
|
+
stageGroupId: number,
|
|
171
|
+
currentStageId: number,
|
|
172
|
+
): Promise<any | null> {
|
|
173
|
+
// 1. Try to get the next stage in same group
|
|
174
|
+
const nextStage = await this.getNextStage(stageGroupId, currentStageId);
|
|
175
|
+
if (nextStage) return nextStage;
|
|
176
|
+
|
|
177
|
+
// 2. No next stage. Try to get next stage group
|
|
178
|
+
const nextStageGroup = await this.getNextStageGroup(stageGroupId);
|
|
179
|
+
if (!nextStageGroup) return null;
|
|
180
|
+
|
|
181
|
+
const nextStageGroupFirstStage = await this.getNextStage(
|
|
182
|
+
nextStageGroup.id,
|
|
183
|
+
0,
|
|
184
|
+
);
|
|
185
|
+
return nextStageGroupFirstStage || null;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
async getAllActionByStageId(stageId: number): Promise<any> {
|
|
189
|
+
const actionRepo = this.reflectionHelper.getRepoService('ActionEntity');
|
|
190
|
+
const result = await actionRepo
|
|
191
|
+
.createQueryBuilder('a')
|
|
192
|
+
.innerJoin(
|
|
193
|
+
'frm_wf_stage_action_mapping',
|
|
194
|
+
'm',
|
|
195
|
+
'a.id = m.action_id::bigint',
|
|
196
|
+
)
|
|
197
|
+
.leftJoin(
|
|
198
|
+
'frm_wf_action_category',
|
|
199
|
+
'ac',
|
|
200
|
+
'a.action_category::bigint = ac.id',
|
|
201
|
+
)
|
|
202
|
+
.leftJoin(
|
|
203
|
+
'frm_wf_action_resources_mapping',
|
|
204
|
+
'arm',
|
|
205
|
+
'm.id = arm.stg_act_mapping_id::bigint',
|
|
206
|
+
)
|
|
207
|
+
.where('m.stage_id::bigint = :stageId', { stageId: Number(stageId) })
|
|
208
|
+
.select([
|
|
209
|
+
'a.*',
|
|
210
|
+
'm.id AS mapping_id',
|
|
211
|
+
'm.stage_id AS stage_id',
|
|
212
|
+
'ac.code AS action_category_code',
|
|
213
|
+
'arm.form_id AS form_id',
|
|
214
|
+
])
|
|
215
|
+
.orderBy('a.sequence', 'ASC')
|
|
216
|
+
.getRawMany();
|
|
217
|
+
|
|
218
|
+
// Use for..of with await instead of map
|
|
219
|
+
const actionResourceMappingRepo = this.reflectionHelper.getRepoService(
|
|
220
|
+
'ActionResourcesMapping',
|
|
221
|
+
);
|
|
222
|
+
for (const item of result) {
|
|
223
|
+
if (item.action_category_code === 'SDFM') {
|
|
224
|
+
const actionData = await actionResourceMappingRepo.findOne({
|
|
225
|
+
where: {
|
|
226
|
+
stg_act_mapping_id: item.mapping_id,
|
|
227
|
+
},
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
item.form_id = actionData?.form_id || null;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
return result;
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
async saveActionData(action: any, loggedInUser: UserData): Promise<any> {
|
|
238
|
+
// Implement the logic to save action data
|
|
239
|
+
|
|
240
|
+
if (action.length > 0) {
|
|
241
|
+
for (const act of action) {
|
|
242
|
+
await this.actionDataEntityRepository.save({
|
|
243
|
+
stage_id: act.stage_id,
|
|
244
|
+
user_id: loggedInUser.id,
|
|
245
|
+
action_id: act.id,
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
async saveTaskData(actionData: any, loggedInUser: UserData): Promise<any> {
|
|
252
|
+
// Implement the logic to save task data
|
|
253
|
+
if (actionData.length > 0) {
|
|
254
|
+
for (const action of actionData) {
|
|
255
|
+
await this.taskDataEntityRepository.save({
|
|
256
|
+
action_id: action.id,
|
|
257
|
+
user_id: String(loggedInUser.id),
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
}
|