rez_core 6.1.5 → 6.1.7

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.
Files changed (426) hide show
  1. package/.prettierrc +3 -3
  2. package/README.md +99 -99
  3. package/dist/migrations/1732612800000-AddEntityJsonGinIndex.js +10 -10
  4. package/dist/module/auth/guards/role.guard.js +3 -3
  5. package/dist/module/enterprise/service/organization.service.d.ts +1 -1
  6. package/dist/module/enterprise/service/organization.service.js +3 -4
  7. package/dist/module/enterprise/service/organization.service.js.map +1 -1
  8. package/dist/module/filter/repository/saved-filter.repository.js +2 -0
  9. package/dist/module/filter/repository/saved-filter.repository.js.map +1 -1
  10. package/dist/module/filter/service/filter.service.js +25 -21
  11. package/dist/module/filter/service/filter.service.js.map +1 -1
  12. package/dist/module/integration/examples/usage.example.js +9 -9
  13. package/dist/module/integration/service/integration.service.d.ts +5 -1
  14. package/dist/module/integration/service/integration.service.js +11 -1
  15. package/dist/module/integration/service/integration.service.js.map +1 -1
  16. package/dist/module/integration/service/oauth.service.js +2 -0
  17. package/dist/module/integration/service/oauth.service.js.map +1 -1
  18. package/dist/module/integration/strategies/email/gmail-api.strategy.js +23 -7
  19. package/dist/module/integration/strategies/email/gmail-api.strategy.js.map +1 -1
  20. package/dist/module/integration/strategies/email/sendgrid-api.strategy.js +8 -5
  21. package/dist/module/integration/strategies/email/sendgrid-api.strategy.js.map +1 -1
  22. package/dist/module/meta/controller/media.controller.d.ts +6 -0
  23. package/dist/module/meta/controller/media.controller.js +27 -0
  24. package/dist/module/meta/controller/media.controller.js.map +1 -1
  25. package/dist/module/meta/entity/media-data.entity.d.ts +2 -0
  26. package/dist/module/meta/entity/media-data.entity.js +8 -0
  27. package/dist/module/meta/entity/media-data.entity.js.map +1 -1
  28. package/dist/module/meta/repository/attribute-master.repository.js +8 -8
  29. package/dist/module/meta/service/entity-dynamic.service.js +18 -18
  30. package/dist/module/meta/service/entity-dynamic.service.js.map +1 -1
  31. package/dist/module/meta/service/media-data.service.d.ts +3 -0
  32. package/dist/module/meta/service/media-data.service.js +16 -6
  33. package/dist/module/meta/service/media-data.service.js.map +1 -1
  34. package/dist/module/meta/service/populate-meta.service.js +8 -2
  35. package/dist/module/meta/service/populate-meta.service.js.map +1 -1
  36. package/dist/module/meta/service/resolver.service.js +43 -17
  37. package/dist/module/meta/service/resolver.service.js.map +1 -1
  38. package/dist/module/module/repository/menu.repository.js +4 -4
  39. package/dist/module/user/controller/login.controller.js +19 -19
  40. package/dist/module/user/controller/login.controller.js.map +1 -1
  41. package/dist/module/user/service/user-session.service.js +1 -0
  42. package/dist/module/user/service/user-session.service.js.map +1 -1
  43. package/dist/module/workflow/repository/action.repository.js +2 -2
  44. package/dist/module/workflow/repository/stage.repository.js +8 -8
  45. package/dist/module/workflow/service/action-template-mapping.service.js +2 -2
  46. package/dist/module/workflow/service/action.service.js +5 -5
  47. package/dist/module/workflow/service/entity-modification.service.js +2 -2
  48. package/dist/module/workflow/service/populate-workflow.service.js +5 -0
  49. package/dist/module/workflow/service/populate-workflow.service.js.map +1 -1
  50. package/dist/module/workflow/service/task.service.js +8 -8
  51. package/dist/module/workflow-automation/service/schedule-handler.service.js +9 -9
  52. package/dist/tsconfig.build.tsbuildinfo +1 -1
  53. package/dist/utils/service/reflection-helper.service.js +2 -2
  54. package/docs/modules/event-driven-integration-design.md +91 -91
  55. package/docs/modules/integration.md +250 -250
  56. package/eslint.config.mjs +34 -34
  57. package/nest-cli.json +14 -14
  58. package/package.json +125 -125
  59. package/src/app.controller.ts +13 -13
  60. package/src/app.module.ts +68 -68
  61. package/src/app.service.ts +8 -8
  62. package/src/config/bull.config.ts +69 -69
  63. package/src/config/config.module.ts +17 -17
  64. package/src/config/database.config.ts +48 -48
  65. package/src/constant/global.constant.ts +67 -67
  66. package/src/core.module.ts +94 -94
  67. package/src/decorators/roles.decorator.ts +7 -7
  68. package/src/dtos/response.dto.ts +6 -6
  69. package/src/dtos/response.ts +5 -5
  70. package/src/index.ts +1 -1
  71. package/src/migrations/1732612800000-AddEntityJsonGinIndex.ts +41 -41
  72. package/src/module/auth/auth.module.ts +49 -49
  73. package/src/module/auth/controller/auth.controller.ts +28 -28
  74. package/src/module/auth/guards/google-auth.guard.ts +9 -9
  75. package/src/module/auth/guards/jwt.guard.ts +22 -22
  76. package/src/module/auth/guards/role.guard.ts +68 -68
  77. package/src/module/auth/services/auth.service.ts +56 -56
  78. package/src/module/auth/services/jwt.service.ts +11 -11
  79. package/src/module/auth/strategies/google.strategy.ts +54 -54
  80. package/src/module/auth/strategies/jwt.strategy.ts +58 -58
  81. package/src/module/auth/strategies/local.strategy.ts +13 -13
  82. package/src/module/dashboard/controller/dashboard.controller.ts +38 -38
  83. package/src/module/dashboard/dashboard.module.ts +21 -21
  84. package/src/module/dashboard/entity/dashboard_page_data.entity.ts +27 -27
  85. package/src/module/dashboard/entity/widget_master.entity.ts +18 -18
  86. package/src/module/dashboard/repository/dashboard.repository.ts +49 -49
  87. package/src/module/dashboard/service/dashboard.service.ts +72 -72
  88. package/src/module/enterprise/controller/organization.controller.ts +36 -36
  89. package/src/module/enterprise/enterprise.module.ts +45 -45
  90. package/src/module/enterprise/entity/enterprise.entity.ts +37 -37
  91. package/src/module/enterprise/entity/organization-app-mapping.entity.ts +13 -13
  92. package/src/module/enterprise/entity/organization.entity.ts +92 -92
  93. package/src/module/enterprise/repository/enterprise.repository.ts +31 -31
  94. package/src/module/enterprise/repository/organization.repository.ts +26 -26
  95. package/src/module/enterprise/repository/school.repository.ts +289 -289
  96. package/src/module/enterprise/service/brand.service.ts +5 -5
  97. package/src/module/enterprise/service/enterprise.service.ts +16 -16
  98. package/src/module/enterprise/service/organization-app-mapping.service.ts +4 -4
  99. package/src/module/enterprise/service/organization.service.ts +146 -145
  100. package/src/module/entity_json/controller/entity_json.controller.ts +60 -60
  101. package/src/module/entity_json/docs/FlatJson_Filterin_System.md +2803 -2803
  102. package/src/module/entity_json/entity/entityJson.entity.ts +42 -42
  103. package/src/module/entity_json/entity_json.module.ts +22 -22
  104. package/src/module/entity_json/service/entityJson.repository.ts +37 -37
  105. package/src/module/entity_json/service/entity_json.service.ts +486 -486
  106. package/src/module/export/controller/export.controller.ts +83 -83
  107. package/src/module/export/export.module.ts +14 -14
  108. package/src/module/export/service/export.service.ts +105 -105
  109. package/src/module/filter/controller/filter.controller.ts +87 -87
  110. package/src/module/filter/dto/filter-request.dto.ts +39 -39
  111. package/src/module/filter/entity/saved-filter-detail.entity.ts +41 -41
  112. package/src/module/filter/entity/saved-filter-master.entity.ts +35 -35
  113. package/src/module/filter/filter.module.ts +41 -41
  114. package/src/module/filter/repository/saved-filter.repository.ts +249 -247
  115. package/src/module/filter/repository/saved.filter-detail.repository.ts +19 -19
  116. package/src/module/filter/service/filter-evaluator.service.ts +82 -82
  117. package/src/module/filter/service/filter.service.ts +1406 -1370
  118. package/src/module/filter/service/flatjson-filter.service.ts +903 -903
  119. package/src/module/filter/service/saved-filter.service.ts +154 -154
  120. package/src/module/filter/test/flatjson-filter.service.spec.ts +415 -415
  121. package/src/module/ics/controller/ics.controller.ts +21 -21
  122. package/src/module/ics/dto/ics.dto.ts +55 -55
  123. package/src/module/ics/ics.module.ts +13 -13
  124. package/src/module/ics/service/ics.service.ts +57 -57
  125. package/src/module/integration/controller/calender-event.controller.ts +31 -31
  126. package/src/module/integration/controller/integration.controller.ts +662 -662
  127. package/src/module/integration/controller/wrapper.controller.ts +37 -37
  128. package/src/module/integration/dto/create-config.dto.ts +526 -526
  129. package/src/module/integration/entity/integration-config.entity.ts +112 -112
  130. package/src/module/integration/entity/integration-entity-mapper.entity.ts +14 -14
  131. package/src/module/integration/entity/integration-source.entity.ts +17 -17
  132. package/src/module/integration/entity/user-integration.entity.ts +71 -71
  133. package/src/module/integration/examples/usage.example.ts +338 -338
  134. package/src/module/integration/factories/base.factory.ts +7 -7
  135. package/src/module/integration/factories/email.factory.ts +49 -49
  136. package/src/module/integration/factories/integration.factory.ts +121 -121
  137. package/src/module/integration/factories/sms.factory.ts +51 -51
  138. package/src/module/integration/factories/telephone.factory.ts +41 -41
  139. package/src/module/integration/factories/whatsapp.factory.ts +56 -56
  140. package/src/module/integration/integration.module.ts +110 -110
  141. package/src/module/integration/service/calendar-event.service.ts +118 -118
  142. package/src/module/integration/service/integration-entity-mapper.service.ts +17 -17
  143. package/src/module/integration/service/integration-queue.service.ts +229 -229
  144. package/src/module/integration/service/integration.service.ts +2653 -2639
  145. package/src/module/integration/service/oauth.service.ts +226 -224
  146. package/src/module/integration/service/wrapper.service.ts +754 -754
  147. package/src/module/integration/strategies/email/gmail-api.strategy.ts +307 -281
  148. package/src/module/integration/strategies/email/outlook-api.strategy.ts +44 -44
  149. package/src/module/integration/strategies/email/outlook.strategy.ts +64 -64
  150. package/src/module/integration/strategies/email/sendgrid-api.strategy.ts +263 -260
  151. package/src/module/integration/strategies/integration.strategy.ts +97 -97
  152. package/src/module/integration/strategies/sms/gupshup-sms.strategy.ts +146 -146
  153. package/src/module/integration/strategies/sms/msg91-sms.strategy.ts +164 -164
  154. package/src/module/integration/strategies/sms/tubelight-sms.strategy.ts +163 -163
  155. package/src/module/integration/strategies/telephone/ozonetel-voice.strategy.ts +238 -238
  156. package/src/module/integration/strategies/telephone/tubelight-voice.strategy.ts +210 -210
  157. package/src/module/integration/strategies/whatsapp/gupshup-whatsapp.strategy.ts +359 -359
  158. package/src/module/integration/strategies/whatsapp/tubelight-whatsapp.strategy.ts +372 -372
  159. package/src/module/integration/strategies/whatsapp/whatsapp-cloud.strategy.ts +403 -403
  160. package/src/module/integration/strategies/whatsapp/whatsapp.strategy.ts +57 -57
  161. package/src/module/layout/controller/layout.controller.ts +47 -47
  162. package/src/module/layout/entity/header-items.entity.ts +28 -28
  163. package/src/module/layout/entity/header-section.entity.ts +19 -19
  164. package/src/module/layout/layout.module.ts +21 -21
  165. package/src/module/layout/repository/header-items.repository.ts +18 -18
  166. package/src/module/layout/repository/header-section.repository.ts +22 -22
  167. package/src/module/layout/service/header-section.service.ts +25 -25
  168. package/src/module/layout_preference/controller/layout_preference.controller.ts +76 -76
  169. package/src/module/layout_preference/entity/layout_preference.entity.ts +28 -28
  170. package/src/module/layout_preference/layout_preference.module.ts +22 -22
  171. package/src/module/layout_preference/repository/layout_preference.repository.ts +65 -65
  172. package/src/module/layout_preference/service/layout_preference.service.ts +191 -191
  173. package/src/module/lead/controller/lead.controller.ts +30 -30
  174. package/src/module/lead/lead.module.ts +14 -14
  175. package/src/module/lead/repository/lead.repository.ts +41 -41
  176. package/src/module/lead/service/lead.service.ts +54 -54
  177. package/src/module/linked_attributes/controller/linked_attributes.controller.ts +137 -137
  178. package/src/module/linked_attributes/dto/create-linked-attribute-smart.dto.ts +54 -54
  179. package/src/module/linked_attributes/entity/linked_attribute.entity.ts +51 -51
  180. package/src/module/linked_attributes/linked_attributes.module.ts +23 -23
  181. package/src/module/linked_attributes/repository/linked_attribute.repository.ts +12 -12
  182. package/src/module/linked_attributes/service/linked_attributes.service.ts +648 -648
  183. package/src/module/linked_attributes/test/linked-attributes.service.spec.ts +244 -244
  184. package/src/module/listmaster/controller/list-master.controller.ts +230 -230
  185. package/src/module/listmaster/entity/list-master-items.entity.ts +43 -43
  186. package/src/module/listmaster/entity/list-master.entity.ts +33 -33
  187. package/src/module/listmaster/listmaster.module.ts +46 -46
  188. package/src/module/listmaster/repository/list-master-items.repository.ts +173 -173
  189. package/src/module/listmaster/repository/list-master.repository.ts +56 -56
  190. package/src/module/listmaster/service/list-master-engine.ts +19 -19
  191. package/src/module/listmaster/service/list-master-extension.interface.ts +4 -4
  192. package/src/module/listmaster/service/list-master-item.service.ts +280 -280
  193. package/src/module/listmaster/service/list-master-registry.ts +15 -15
  194. package/src/module/listmaster/service/list-master.service.ts +527 -527
  195. package/src/module/mapper/controller/field-mapper.controller.ts +76 -76
  196. package/src/module/mapper/controller/mapper.controller.ts +20 -20
  197. package/src/module/mapper/dto/field-mapper.dto.ts +14 -14
  198. package/src/module/mapper/entity/field-lovs.entity.ts +19 -19
  199. package/src/module/mapper/entity/field-mapper.entity.ts +53 -53
  200. package/src/module/mapper/entity/mapper.entity.ts +16 -16
  201. package/src/module/mapper/mapper.module.ts +35 -35
  202. package/src/module/mapper/repository/field-lovs.repository.ts +35 -35
  203. package/src/module/mapper/repository/field-mapper.repository.ts +42 -42
  204. package/src/module/mapper/repository/mapper.repository.ts +32 -32
  205. package/src/module/mapper/service/field-mapper.service.ts +269 -269
  206. package/src/module/mapper/service/mapper.service.ts +80 -80
  207. package/src/module/master/controller/master.controller.ts +74 -74
  208. package/src/module/master/service/master.service.ts +484 -484
  209. package/src/module/meta/controller/app-master.controller.ts +38 -38
  210. package/src/module/meta/controller/attribute-master.controller.ts +96 -96
  211. package/src/module/meta/controller/entity-dynamic.controller.ts +125 -125
  212. package/src/module/meta/controller/entity-master.controller.ts +41 -41
  213. package/src/module/meta/controller/entity-relation.controller.ts +36 -36
  214. package/src/module/meta/controller/entity.controller.ts +308 -308
  215. package/src/module/meta/controller/entity.public.controller.ts +75 -75
  216. package/src/module/meta/controller/media.controller.ts +167 -135
  217. package/src/module/meta/controller/meta.controller.ts +101 -101
  218. package/src/module/meta/controller/view-master.controller.ts +79 -79
  219. package/src/module/meta/dto/entity-list-data.dto.ts +6 -6
  220. package/src/module/meta/dto/entity-tab.dto.ts +4 -4
  221. package/src/module/meta/dto/entity-table.dto.ts +12 -12
  222. package/src/module/meta/entity/app-master.entity.ts +37 -37
  223. package/src/module/meta/entity/attribute-master.entity.ts +92 -92
  224. package/src/module/meta/entity/base-entity.entity.ts +75 -75
  225. package/src/module/meta/entity/entity-master.entity.ts +91 -91
  226. package/src/module/meta/entity/entity-relation-data.entity.ts +29 -29
  227. package/src/module/meta/entity/entity-relation.entity.ts +23 -23
  228. package/src/module/meta/entity/entity-table-column.entity.ts +61 -61
  229. package/src/module/meta/entity/entity-table.entity.ts +50 -50
  230. package/src/module/meta/entity/media-data.entity.ts +38 -32
  231. package/src/module/meta/entity/preference.entity.ts +62 -62
  232. package/src/module/meta/entity/view-master.entity.ts +41 -41
  233. package/src/module/meta/entity.module.ts +165 -165
  234. package/src/module/meta/repository/app-master.repository.ts +20 -20
  235. package/src/module/meta/repository/attribute-master.repository.ts +164 -164
  236. package/src/module/meta/repository/entity-attribute-update.repository.ts +48 -48
  237. package/src/module/meta/repository/entity-master.repository.ts +120 -120
  238. package/src/module/meta/repository/entity-relation.repository.ts +22 -22
  239. package/src/module/meta/repository/entity-table-column.repository.ts +39 -39
  240. package/src/module/meta/repository/entity-table.repository.ts +53 -53
  241. package/src/module/meta/repository/media-data.repository.ts +50 -50
  242. package/src/module/meta/repository/preference.repository.ts +20 -20
  243. package/src/module/meta/repository/user-app-mapping.repository.ts +28 -28
  244. package/src/module/meta/repository/view-master.repository.ts +42 -42
  245. package/src/module/meta/service/app-master.service.ts +37 -37
  246. package/src/module/meta/service/attribute-master.service.ts +160 -160
  247. package/src/module/meta/service/common.service.ts +9 -9
  248. package/src/module/meta/service/entity-attribute-update.service.ts +26 -26
  249. package/src/module/meta/service/entity-dynamic.service.ts +835 -824
  250. package/src/module/meta/service/entity-master.service.ts +172 -172
  251. package/src/module/meta/service/entity-realation-data.service.ts +9 -9
  252. package/src/module/meta/service/entity-relation.service.ts +78 -78
  253. package/src/module/meta/service/entity-service-impl.service.ts +389 -389
  254. package/src/module/meta/service/entity-table-column.service.ts +26 -26
  255. package/src/module/meta/service/entity-table.service.ts +171 -171
  256. package/src/module/meta/service/entity-validation.service.ts +188 -188
  257. package/src/module/meta/service/entity.service.ts +48 -48
  258. package/src/module/meta/service/field-group.service.ts +103 -103
  259. package/src/module/meta/service/media-data.service.ts +610 -591
  260. package/src/module/meta/service/populate-meta.service.ts +228 -222
  261. package/src/module/meta/service/preference.service.ts +16 -16
  262. package/src/module/meta/service/resolver.service.ts +355 -319
  263. package/src/module/meta/service/section-master.service.ts +104 -104
  264. package/src/module/meta/service/update-form-json.service.ts +22 -22
  265. package/src/module/meta/service/user-app-mapping.service.ts +17 -17
  266. package/src/module/meta/service/view-master.service.ts +127 -127
  267. package/src/module/microservice-client/microservice-clients.module.ts +13 -13
  268. package/src/module/microservice-client/service/microservice-client-factory.ts +37 -37
  269. package/src/module/microservice-client/service/microservice-clients.ts +4 -4
  270. package/src/module/module/controller/menu.controller.ts +15 -15
  271. package/src/module/module/controller/module-access.controller.ts +133 -133
  272. package/src/module/module/entity/menu.entity.ts +43 -43
  273. package/src/module/module/entity/module-access.entity.ts +25 -25
  274. package/src/module/module/entity/module-action.entity.ts +17 -17
  275. package/src/module/module/entity/module.entity.ts +52 -52
  276. package/src/module/module/module.module.ts +42 -42
  277. package/src/module/module/repository/menu.repository.ts +186 -186
  278. package/src/module/module/repository/module-access.repository.ts +344 -344
  279. package/src/module/module/service/menu.service.ts +82 -82
  280. package/src/module/module/service/module-access.service.ts +189 -189
  281. package/src/module/notification/controller/notification.controller.ts +58 -58
  282. package/src/module/notification/controller/otp.controller.ts +117 -117
  283. package/src/module/notification/entity/notification.entity.ts +26 -26
  284. package/src/module/notification/entity/otp.entity.ts +28 -28
  285. package/src/module/notification/firebase-admin.config.ts +22 -22
  286. package/src/module/notification/notification.module.ts +71 -71
  287. package/src/module/notification/repository/notification.repository.ts +33 -33
  288. package/src/module/notification/repository/otp.repository.ts +27 -27
  289. package/src/module/notification/service/email.service.ts +127 -127
  290. package/src/module/notification/service/notification.service.ts +146 -146
  291. package/src/module/notification/service/otp.service.ts +133 -133
  292. package/src/module/third-party-module/entity/third-party-api-registry.entity.ts +52 -52
  293. package/src/module/third-party-module/repository/third-party-api-registry.repository.ts +20 -20
  294. package/src/module/third-party-module/service/api-registry.service.ts +13 -13
  295. package/src/module/third-party-module/third-party.module.ts +12 -12
  296. package/src/module/user/controller/login.controller.ts +199 -198
  297. package/src/module/user/controller/user.controller.ts +40 -40
  298. package/src/module/user/dto/create-user.dto.ts +62 -62
  299. package/src/module/user/dto/update-user.dto.ts +4 -4
  300. package/src/module/user/entity/role.entity.ts +33 -33
  301. package/src/module/user/entity/user-role-mapping.entity.ts +38 -38
  302. package/src/module/user/entity/user-session.entity.ts +73 -73
  303. package/src/module/user/entity/user.entity.ts +62 -62
  304. package/src/module/user/repository/role.repository.ts +96 -96
  305. package/src/module/user/repository/user-role-mapping.repository.ts +126 -126
  306. package/src/module/user/repository/user.repository.ts +50 -50
  307. package/src/module/user/repository/userSession.repository.ts +33 -33
  308. package/src/module/user/service/login.service.ts +326 -326
  309. package/src/module/user/service/role.service.ts +197 -197
  310. package/src/module/user/service/user-role-mapping.service.ts +98 -98
  311. package/src/module/user/service/user-session.service.ts +201 -200
  312. package/src/module/user/service/user.service.ts +368 -368
  313. package/src/module/user/user.module.ts +65 -65
  314. package/src/module/workflow/controller/action-category.controller.ts +54 -54
  315. package/src/module/workflow/controller/action-resource-mapping.controller.ts +23 -23
  316. package/src/module/workflow/controller/action-template-mapping.controller.ts +35 -35
  317. package/src/module/workflow/controller/action.controller.ts +111 -111
  318. package/src/module/workflow/controller/activity-log.controller.ts +55 -55
  319. package/src/module/workflow/controller/comm-template.controller.ts +43 -43
  320. package/src/module/workflow/controller/entity-modification.controller.ts +35 -35
  321. package/src/module/workflow/controller/form-master.controller.ts +43 -43
  322. package/src/module/workflow/controller/stage-group.controller.ts +49 -49
  323. package/src/module/workflow/controller/stage.controller.ts +51 -51
  324. package/src/module/workflow/controller/task.controller.ts +77 -77
  325. package/src/module/workflow/controller/workflow-list-master.controller.ts +44 -44
  326. package/src/module/workflow/controller/workflow-meta.controller.ts +80 -80
  327. package/src/module/workflow/controller/workflow.controller.ts +67 -67
  328. package/src/module/workflow/entity/action-category.entity.ts +38 -38
  329. package/src/module/workflow/entity/action-data.entity.ts +55 -55
  330. package/src/module/workflow/entity/action-resources-mapping.entity.ts +29 -29
  331. package/src/module/workflow/entity/action-template-mapping.entity.ts +17 -17
  332. package/src/module/workflow/entity/action.entity.ts +53 -53
  333. package/src/module/workflow/entity/activity-log.entity.ts +43 -43
  334. package/src/module/workflow/entity/comm-template.entity.ts +43 -43
  335. package/src/module/workflow/entity/entity-modification.entity.ts +38 -38
  336. package/src/module/workflow/entity/form.entity.ts +25 -25
  337. package/src/module/workflow/entity/stage-action-mapping.entity.ts +17 -17
  338. package/src/module/workflow/entity/stage-group.entity.ts +23 -23
  339. package/src/module/workflow/entity/stage-movement-data.entity.ts +38 -38
  340. package/src/module/workflow/entity/stage.entity.ts +20 -20
  341. package/src/module/workflow/entity/task-data.entity.ts +88 -88
  342. package/src/module/workflow/entity/template-attach-mapper.entity.ts +30 -30
  343. package/src/module/workflow/entity/workflow-data.entity.ts +11 -11
  344. package/src/module/workflow/entity/workflow-level-mapping.entity.ts +18 -18
  345. package/src/module/workflow/entity/workflow.entity.ts +20 -20
  346. package/src/module/workflow/repository/action-category.repository.ts +79 -79
  347. package/src/module/workflow/repository/action-data.repository.ts +354 -354
  348. package/src/module/workflow/repository/action.repository.ts +339 -339
  349. package/src/module/workflow/repository/activity-log.repository.ts +148 -148
  350. package/src/module/workflow/repository/comm-template.repository.ts +157 -157
  351. package/src/module/workflow/repository/form-master.repository.ts +50 -50
  352. package/src/module/workflow/repository/stage-group.repository.ts +186 -186
  353. package/src/module/workflow/repository/stage-movement.repository.ts +217 -217
  354. package/src/module/workflow/repository/stage.repository.ts +160 -160
  355. package/src/module/workflow/repository/task.repository.ts +156 -156
  356. package/src/module/workflow/repository/workflow.repository.ts +42 -42
  357. package/src/module/workflow/service/action-category.service.ts +33 -33
  358. package/src/module/workflow/service/action-data.service.ts +62 -62
  359. package/src/module/workflow/service/action-resources-mapping.service.ts +10 -10
  360. package/src/module/workflow/service/action-template-mapping.service.ts +137 -137
  361. package/src/module/workflow/service/action.service.ts +302 -302
  362. package/src/module/workflow/service/activity-log.service.ts +107 -107
  363. package/src/module/workflow/service/comm-template.service.ts +181 -181
  364. package/src/module/workflow/service/entity-modification.service.ts +61 -61
  365. package/src/module/workflow/service/form-master.service.ts +35 -35
  366. package/src/module/workflow/service/populate-workflow.service.ts +325 -320
  367. package/src/module/workflow/service/stage-action-mapping.service.ts +5 -5
  368. package/src/module/workflow/service/stage-group.service.ts +325 -325
  369. package/src/module/workflow/service/stage.service.ts +197 -197
  370. package/src/module/workflow/service/task.service.ts +551 -551
  371. package/src/module/workflow/service/workflow-list-master.service.ts +68 -68
  372. package/src/module/workflow/service/workflow-meta.service.ts +640 -640
  373. package/src/module/workflow/service/workflow.service.ts +213 -213
  374. package/src/module/workflow/workflow.module.ts +180 -180
  375. package/src/module/workflow-automation/SCHEDULING_GUIDE.md +145 -145
  376. package/src/module/workflow-automation/controller/workflow-automation.controller.ts +43 -43
  377. package/src/module/workflow-automation/entity/workflow-automation-action.entity.ts +26 -26
  378. package/src/module/workflow-automation/entity/workflow-automation.entity.ts +40 -40
  379. package/src/module/workflow-automation/interface/action.decorator.ts +7 -7
  380. package/src/module/workflow-automation/interface/action.interface.ts +5 -5
  381. package/src/module/workflow-automation/service/action-registery.service.ts +35 -35
  382. package/src/module/workflow-automation/service/schedule-handler.service.ts +168 -168
  383. package/src/module/workflow-automation/service/workflow-automation-engine.service.ts +219 -219
  384. package/src/module/workflow-automation/service/workflow-automation.service.ts +474 -474
  385. package/src/module/workflow-automation/workflow-automation.module.ts +54 -54
  386. package/src/module/workflow-schedule/INSTALLATION.md +244 -244
  387. package/src/module/workflow-schedule/MULTI_PROJECT_GUIDE.md +196 -196
  388. package/src/module/workflow-schedule/README.md +422 -422
  389. package/src/module/workflow-schedule/constants/schedule.constants.ts +48 -48
  390. package/src/module/workflow-schedule/controller/workflow-schedule.controller.ts +253 -253
  391. package/src/module/workflow-schedule/docs/CLAUDE_CODE_GUIDE.md +510 -510
  392. package/src/module/workflow-schedule/docs/CLAUDE_CODE_PROMPT.md +362 -362
  393. package/src/module/workflow-schedule/docs/RUN_CLAUDE_CODE.sh +68 -68
  394. package/src/module/workflow-schedule/dto/create-schedule.dto.ts +147 -147
  395. package/src/module/workflow-schedule/dto/get-execution-logs.dto.ts +119 -119
  396. package/src/module/workflow-schedule/dto/update-schedule.dto.ts +96 -96
  397. package/src/module/workflow-schedule/entities/scheduled-workflow.entity.ts +148 -148
  398. package/src/module/workflow-schedule/entities/workflow-execution-log.entity.ts +154 -154
  399. package/src/module/workflow-schedule/interfaces/schedule-job-data.interface.ts +53 -53
  400. package/src/module/workflow-schedule/interfaces/workflow-schedule-options.interface.ts +12 -12
  401. package/src/module/workflow-schedule/processors/schedule.processor.ts +620 -620
  402. package/src/module/workflow-schedule/service/workflow-schedule.service.ts +597 -597
  403. package/src/module/workflow-schedule/workflow-schedule.module.ts +67 -67
  404. package/src/resources/dev.properties.yaml +31 -31
  405. package/src/resources/local.properties.yaml +27 -27
  406. package/src/resources/properties.module.ts +12 -12
  407. package/src/resources/properties.yaml.ts +11 -11
  408. package/src/resources/uat.properties.yaml +31 -31
  409. package/src/table.config.ts +135 -135
  410. package/src/utils/dto/excel-data.dto.ts +14 -14
  411. package/src/utils/dto/excelsheet-data.dto.ts +5 -5
  412. package/src/utils/service/base64util.service.ts +18 -18
  413. package/src/utils/service/clockIDGenUtil.service.ts +21 -21
  414. package/src/utils/service/codeGenerator.service.ts +22 -22
  415. package/src/utils/service/dateUtil.service.ts +17 -17
  416. package/src/utils/service/encryptUtil.service.ts +97 -97
  417. package/src/utils/service/excel-helper.service.ts +72 -72
  418. package/src/utils/service/excelUtil.service.ts +15 -15
  419. package/src/utils/service/file-util.service.ts +11 -11
  420. package/src/utils/service/json-util.service.ts +23 -23
  421. package/src/utils/service/loggingUtil.service.ts +88 -88
  422. package/src/utils/service/reflection-helper.service.ts +62 -62
  423. package/src/utils/service/wbsCodeGen.service.ts +8 -8
  424. package/src/utils/utils.module.ts +27 -27
  425. package/tsconfig.build.json +4 -4
  426. package/tsconfig.json +24 -24
@@ -1,281 +1,307 @@
1
- import { Injectable } from '@nestjs/common';
2
- import { ConfigService } from '@nestjs/config';
3
- import { google } from 'googleapis';
4
- import {
5
- IntegrationStrategy,
6
- IntegrationResult,
7
- EmailAttachment,
8
- EmailAttachmentValidator,
9
- } from '../integration.strategy';
10
-
11
- @Injectable()
12
- export class GmailApiStrategy implements IntegrationStrategy {
13
- constructor(private readonly configService: ConfigService) {
14
- }
15
-
16
- async sendMessage(
17
- to: string | string[],
18
- message: string,
19
- config: any,
20
- ): Promise<IntegrationResult> {
21
- try {
22
- if (!config || !config.refreshToken) {
23
- throw new Error(
24
- 'Invalid Gmail API configuration - missing refresh token',
25
- );
26
- }
27
-
28
- const { subject, cc, bcc, attachments } = config;
29
-
30
- console.log('---- Using Google SDK Gmail API ----');
31
-
32
- const oauth2Client = await this.setupOAuth2Client(config);
33
-
34
- const gmail = google.gmail({ version: 'v1', auth: oauth2Client });
35
-
36
- const toRecipients = Array.isArray(to) ? to.join(', ') : to;
37
- const ccRecipients = cc
38
- ? Array.isArray(cc)
39
- ? cc.join(', ')
40
- : cc
41
- : undefined;
42
- const bccRecipients = bcc
43
- ? Array.isArray(bcc)
44
- ? bcc.join(', ')
45
- : bcc
46
- : undefined;
47
-
48
- const emailContent =
49
- attachments && attachments.length > 0
50
- ? this.buildMultipartEmail(
51
- toRecipients,
52
- ccRecipients,
53
- bccRecipients,
54
- subject,
55
- config.richText || message,
56
- attachments,
57
- )
58
- : this.buildSimpleEmail(
59
- toRecipients,
60
- ccRecipients,
61
- bccRecipients,
62
- subject,
63
- config.richText || message,
64
- );
65
-
66
- const encodedMessage = Buffer.from(emailContent)
67
- .toString('base64')
68
- .replace(/\+/g, '-')
69
- .replace(/\//g, '_')
70
- .replace(/=+$/, '');
71
-
72
- const result = await gmail.users.messages.send({
73
- userId: 'me',
74
- requestBody: {
75
- raw: encodedMessage,
76
- },
77
- });
78
-
79
- const credentials = oauth2Client.credentials;
80
- const freshAccessToken = credentials.access_token;
81
-
82
- return {
83
- success: true,
84
- messageId: result.data.id || undefined,
85
- provider: 'gmail',
86
- service: 'API',
87
- timestamp: new Date(),
88
- message: "Email sent successfully"
89
- };
90
- } catch (error) {
91
- console.error('---- Gmail SDK API Error ----');
92
- console.error('Error message:', error.message);
93
- console.error('Error details:', error.response?.data || error.errors);
94
-
95
- return {
96
- success: false,
97
- provider: 'gmail',
98
- service: 'API',
99
- error:
100
- error.response?.data?.error?.message ||
101
- error.message ||
102
- 'Gmail API error',
103
- timestamp: new Date(),
104
- };
105
- }
106
- }
107
-
108
- validateConfig(config: any): boolean {
109
- if (!config) return false;
110
-
111
- // For Google SDK strategy, we need a refresh token
112
- return config.refreshToken && typeof config.refreshToken === 'string';
113
- }
114
-
115
- private async setupOAuth2Client(config: any): Promise<any> {
116
- try {
117
- const { refreshToken } = config;
118
-
119
- if (!refreshToken) {
120
- throw new Error('Missing refresh token for OAuth2 setup');
121
- }
122
-
123
- // Get system OAuth credentials
124
- const clientId = this.configService.get<string>('CLIENT_ID');
125
- const clientSecret = this.configService.get<string>('CLIENT_SECRET');
126
- const callbackurl = this.configService.get<string>('CALLBACK_URL');
127
-
128
- if (!clientId || !clientSecret) {
129
- throw new Error('Gmail OAuth system credentials not configured');
130
- }
131
-
132
- console.log('---- Setting up OAuth2 client with Google SDK ----');
133
-
134
- // Create OAuth2 client using Google SDK
135
- const oauth2Client = new google.auth.OAuth2(
136
- clientId,
137
- clientSecret,
138
- callbackurl, // For server-to-server
139
- );
140
-
141
- // Set the refresh token
142
- oauth2Client.setCredentials({
143
- refresh_token: refreshToken,
144
- });
145
-
146
- // Refresh access token automatically
147
- await oauth2Client.getAccessToken();
148
-
149
- console.log('---- OAuth2 client setup completed ----');
150
- return oauth2Client;
151
- } catch (error) {
152
- console.error('Failed to setup OAuth2 client:', error.message);
153
- throw new Error(`Failed to setup Gmail OAuth2 client: ${error.message}`);
154
- }
155
- }
156
-
157
- async refreshAccessToken(config: any): Promise<string> {
158
- try {
159
- const oauth2Client = await this.setupOAuth2Client(config);
160
- const { token } = await oauth2Client.getAccessToken();
161
-
162
- if (!token) {
163
- throw new Error('No access token received from OAuth2 client');
164
- }
165
-
166
- console.log('---- Token refreshed successfully via Google SDK ----');
167
- return token;
168
- } catch (error) {
169
- console.error(
170
- 'Failed to refresh access token via Google SDK:',
171
- error.message,
172
- );
173
- throw new Error(`Failed to refresh Gmail access token: ${error.message}`);
174
- }
175
- }
176
-
177
- async validateConnection(config: any): Promise<boolean> {
178
- try {
179
- if (!this.validateConfig(config)) {
180
- return false;
181
- }
182
-
183
- // Setup OAuth2 client and test the connection
184
- const oauth2Client = await this.setupOAuth2Client(config);
185
- const gmail = google.gmail({ version: 'v1', auth: oauth2Client });
186
-
187
- // Test the connection by getting user profile
188
- const profile = await gmail.users.getProfile({
189
- userId: 'me',
190
- });
191
-
192
- return !!(profile.data && profile.data.emailAddress);
193
- } catch (error) {
194
- console.error('Gmail connection validation failed:', error.message);
195
- return false;
196
- }
197
- }
198
-
199
- private buildSimpleEmail(
200
- to: string,
201
- cc?: string,
202
- bcc?: string,
203
- subject?: string,
204
- message?: string,
205
- ): string {
206
- const emailLines = [`To: ${to}`, `Subject: ${subject || 'Notification'}`];
207
-
208
- if (cc) {
209
- emailLines.push(`Cc: ${cc}`);
210
- }
211
-
212
- if (bcc) {
213
- emailLines.push(`Bcc: ${bcc}`);
214
- }
215
-
216
- emailLines.push('Content-Type: text/html; charset=utf-8');
217
- emailLines.push('');
218
-
219
- emailLines.push(message || '');
220
-
221
- return emailLines.join('\n');
222
- }
223
-
224
- private buildMultipartEmail(
225
- to: string,
226
- cc?: string,
227
- bcc?: string,
228
- subject?: string,
229
- message?: string,
230
- attachments?: EmailAttachment[],
231
- ): string {
232
- const boundary = `----GmailBoundary${Date.now()}${Math.random().toString(36).substr(2, 9)}`;
233
-
234
- const emailLines = [`To: ${to}`, `Subject: ${subject || 'Notification'}`];
235
-
236
- if (cc) {
237
- emailLines.push(`Cc: ${cc}`);
238
- }
239
-
240
- if (bcc) {
241
- emailLines.push(`Bcc: ${bcc}`);
242
- }
243
-
244
- emailLines.push(`Content-Type: multipart/mixed; boundary="${boundary}"`);
245
- emailLines.push('');
246
-
247
- // Add main content part
248
- emailLines.push(`--${boundary}`);
249
- emailLines.push('Content-Type: text/html; charset=utf-8');
250
- emailLines.push('');
251
-
252
- emailLines.push(message || '');
253
-
254
- // Add attachment parts
255
- if (attachments) {
256
- for (const attachment of attachments) {
257
- emailLines.push(`--${boundary}`);
258
- emailLines.push(`Content-Type: ${attachment.contentType}`);
259
- emailLines.push(
260
- `Content-Disposition: ${attachment.disposition || 'attachment'}; filename="${attachment.filename}"`,
261
- );
262
- emailLines.push('Content-Transfer-Encoding: base64');
263
-
264
- if (attachment.contentId) {
265
- emailLines.push(`Content-ID: <${attachment.contentId}>`);
266
- }
267
-
268
- emailLines.push('');
269
-
270
- // Add base64 content in chunks of 76 characters (RFC 2045)
271
- const base64Content = attachment.content;
272
- const chunks = base64Content.match(/.{1,76}/g) || [];
273
- emailLines.push(...chunks);
274
- }
275
- }
276
-
277
- emailLines.push(`--${boundary}--`);
278
-
279
- return emailLines.join('\n');
280
- }
281
- }
1
+ import { Injectable } from '@nestjs/common';
2
+ import { ConfigService } from '@nestjs/config';
3
+ import { google } from 'googleapis';
4
+ import {
5
+ IntegrationStrategy,
6
+ IntegrationResult,
7
+ EmailAttachment,
8
+ EmailAttachmentValidator,
9
+ } from '../integration.strategy';
10
+
11
+ @Injectable()
12
+ export class GmailApiStrategy implements IntegrationStrategy {
13
+ constructor(private readonly configService: ConfigService) {}
14
+
15
+ async sendMessage(
16
+ to: string | string[],
17
+ message: string,
18
+ config: any,
19
+ ): Promise<IntegrationResult> {
20
+ try {
21
+ if (!config || !config.refreshToken) {
22
+ throw new Error(
23
+ 'Invalid Gmail API configuration - missing refresh token',
24
+ );
25
+ }
26
+
27
+ const { subject, cc, bcc, attachments } = config;
28
+
29
+ console.log('---- Using Google SDK Gmail API ----');
30
+
31
+ const oauth2Client = await this.setupOAuth2Client(config);
32
+
33
+ const gmail = google.gmail({ version: 'v1', auth: oauth2Client });
34
+
35
+ const toRecipients = Array.isArray(to) ? to.join(', ') : to;
36
+ const ccRecipients = cc
37
+ ? Array.isArray(cc)
38
+ ? cc.join(', ')
39
+ : cc
40
+ : undefined;
41
+ const bccRecipients = bcc
42
+ ? Array.isArray(bcc)
43
+ ? bcc.join(', ')
44
+ : bcc
45
+ : undefined;
46
+
47
+ const fromEmail = config.email;
48
+ const fromName = config.fromName;
49
+
50
+ const emailContent =
51
+ attachments && attachments.length > 0
52
+ ? this.buildMultipartEmail(
53
+ toRecipients,
54
+ ccRecipients,
55
+ bccRecipients,
56
+ subject,
57
+ config.richText || message,
58
+ attachments,
59
+ fromEmail,
60
+ fromName,
61
+ )
62
+ : this.buildSimpleEmail(
63
+ toRecipients,
64
+ ccRecipients,
65
+ bccRecipients,
66
+ subject,
67
+ config.richText || message,
68
+ fromEmail,
69
+ fromName,
70
+ );
71
+
72
+ const encodedMessage = Buffer.from(emailContent)
73
+ .toString('base64')
74
+ .replace(/\+/g, '-')
75
+ .replace(/\//g, '_')
76
+ .replace(/=+$/, '');
77
+
78
+ const result = await gmail.users.messages.send({
79
+ userId: 'me',
80
+ requestBody: {
81
+ raw: encodedMessage,
82
+ },
83
+ });
84
+
85
+ const credentials = oauth2Client.credentials;
86
+ const freshAccessToken = credentials.access_token;
87
+
88
+ return {
89
+ success: true,
90
+ messageId: result.data.id || undefined,
91
+ provider: 'gmail',
92
+ service: 'API',
93
+ timestamp: new Date(),
94
+ message: 'Email sent successfully',
95
+ };
96
+ } catch (error) {
97
+ console.error('---- Gmail SDK API Error ----');
98
+ console.error('Error message:', error.message);
99
+ console.error('Error details:', error.response?.data || error.errors);
100
+
101
+ return {
102
+ success: false,
103
+ provider: 'gmail',
104
+ service: 'API',
105
+ error:
106
+ error.response?.data?.error?.message ||
107
+ error.message ||
108
+ 'Gmail API error',
109
+ timestamp: new Date(),
110
+ };
111
+ }
112
+ }
113
+
114
+ validateConfig(config: any): boolean {
115
+ if (!config) return false;
116
+
117
+ // For Google SDK strategy, we need a refresh token
118
+ return config.refreshToken && typeof config.refreshToken === 'string';
119
+ }
120
+
121
+ private async setupOAuth2Client(config: any): Promise<any> {
122
+ try {
123
+ const { refreshToken } = config;
124
+
125
+ if (!refreshToken) {
126
+ throw new Error('Missing refresh token for OAuth2 setup');
127
+ }
128
+
129
+ // Get system OAuth credentials
130
+ const clientId = this.configService.get<string>('CLIENT_ID');
131
+ const clientSecret = this.configService.get<string>('CLIENT_SECRET');
132
+ const callbackurl = this.configService.get<string>('CALLBACK_URL');
133
+
134
+ if (!clientId || !clientSecret) {
135
+ throw new Error('Gmail OAuth system credentials not configured');
136
+ }
137
+
138
+ console.log('---- Setting up OAuth2 client with Google SDK ----');
139
+
140
+ // Create OAuth2 client using Google SDK
141
+ const oauth2Client = new google.auth.OAuth2(
142
+ clientId,
143
+ clientSecret,
144
+ callbackurl, // For server-to-server
145
+ );
146
+
147
+ // Set the refresh token
148
+ oauth2Client.setCredentials({
149
+ refresh_token: refreshToken,
150
+ });
151
+
152
+ // Refresh access token automatically
153
+ await oauth2Client.getAccessToken();
154
+
155
+ console.log('---- OAuth2 client setup completed ----');
156
+ return oauth2Client;
157
+ } catch (error) {
158
+ console.error('Failed to setup OAuth2 client:', error.message);
159
+ throw new Error(`Failed to setup Gmail OAuth2 client: ${error.message}`);
160
+ }
161
+ }
162
+
163
+ async refreshAccessToken(config: any): Promise<string> {
164
+ try {
165
+ const oauth2Client = await this.setupOAuth2Client(config);
166
+ const { token } = await oauth2Client.getAccessToken();
167
+
168
+ if (!token) {
169
+ throw new Error('No access token received from OAuth2 client');
170
+ }
171
+
172
+ console.log('---- Token refreshed successfully via Google SDK ----');
173
+ return token;
174
+ } catch (error) {
175
+ console.error(
176
+ 'Failed to refresh access token via Google SDK:',
177
+ error.message,
178
+ );
179
+ throw new Error(`Failed to refresh Gmail access token: ${error.message}`);
180
+ }
181
+ }
182
+
183
+ async validateConnection(config: any): Promise<boolean> {
184
+ try {
185
+ if (!this.validateConfig(config)) {
186
+ return false;
187
+ }
188
+
189
+ // Setup OAuth2 client and test the connection
190
+ const oauth2Client = await this.setupOAuth2Client(config);
191
+ const gmail = google.gmail({ version: 'v1', auth: oauth2Client });
192
+
193
+ // Test the connection by getting user profile
194
+ const profile = await gmail.users.getProfile({
195
+ userId: 'me',
196
+ });
197
+
198
+ return !!(profile.data && profile.data.emailAddress);
199
+ } catch (error) {
200
+ console.error('Gmail connection validation failed:', error.message);
201
+ return false;
202
+ }
203
+ }
204
+
205
+ private buildSimpleEmail(
206
+ to: string,
207
+ cc?: string,
208
+ bcc?: string,
209
+ subject?: string,
210
+ message?: string,
211
+ fromEmail?: string,
212
+ fromName?: string,
213
+ ): string {
214
+ const fromHeader = fromEmail
215
+ ? `From: "${fromName || fromEmail}" <${fromEmail}>`
216
+ : undefined;
217
+
218
+ const emailLines = [
219
+ ...(fromHeader ? [fromHeader] : []),
220
+ `To: ${to}`,
221
+ `Subject: ${subject || 'Notification'}`,
222
+ ];
223
+
224
+ if (cc) {
225
+ emailLines.push(`Cc: ${cc}`);
226
+ }
227
+
228
+ if (bcc) {
229
+ emailLines.push(`Bcc: ${bcc}`);
230
+ }
231
+
232
+ emailLines.push('Content-Type: text/html; charset=utf-8');
233
+ emailLines.push('');
234
+
235
+ emailLines.push(message || '');
236
+
237
+ return emailLines.join('\n');
238
+ }
239
+
240
+ private buildMultipartEmail(
241
+ to: string,
242
+ cc?: string,
243
+ bcc?: string,
244
+ subject?: string,
245
+ message?: string,
246
+ attachments?: EmailAttachment[],
247
+ fromEmail?: string,
248
+ fromName?: string,
249
+ ): string {
250
+ const boundary = `----GmailBoundary${Date.now()}${Math.random().toString(36).substr(2, 9)}`;
251
+
252
+ const fromHeader = fromEmail
253
+ ? `From: "${fromName || fromEmail}" <${fromEmail}>`
254
+ : undefined;
255
+
256
+ const emailLines = [
257
+ ...(fromHeader ? [fromHeader] : []),
258
+ `To: ${to}`,
259
+ `Subject: ${subject || 'Notification'}`,
260
+ ];
261
+
262
+ if (cc) {
263
+ emailLines.push(`Cc: ${cc}`);
264
+ }
265
+
266
+ if (bcc) {
267
+ emailLines.push(`Bcc: ${bcc}`);
268
+ }
269
+
270
+ emailLines.push(`Content-Type: multipart/mixed; boundary="${boundary}"`);
271
+ emailLines.push('');
272
+
273
+ // Add main content part
274
+ emailLines.push(`--${boundary}`);
275
+ emailLines.push('Content-Type: text/html; charset=utf-8');
276
+ emailLines.push('');
277
+
278
+ emailLines.push(message || '');
279
+
280
+ // Add attachment parts
281
+ if (attachments) {
282
+ for (const attachment of attachments) {
283
+ emailLines.push(`--${boundary}`);
284
+ emailLines.push(`Content-Type: ${attachment.contentType}`);
285
+ emailLines.push(
286
+ `Content-Disposition: ${attachment.disposition || 'attachment'}; filename="${attachment.filename}"`,
287
+ );
288
+ emailLines.push('Content-Transfer-Encoding: base64');
289
+
290
+ if (attachment.contentId) {
291
+ emailLines.push(`Content-ID: <${attachment.contentId}>`);
292
+ }
293
+
294
+ emailLines.push('');
295
+
296
+ // Add base64 content in chunks of 76 characters (RFC 2045)
297
+ const base64Content = attachment.content;
298
+ const chunks = base64Content.match(/.{1,76}/g) || [];
299
+ emailLines.push(...chunks);
300
+ }
301
+ }
302
+
303
+ emailLines.push(`--${boundary}--`);
304
+
305
+ return emailLines.join('\n');
306
+ }
307
+ }