@open-mercato/core 0.4.2-canary-ed15f2e753 → 0.4.2-canary-e2aeb1a7bf

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 (711) hide show
  1. package/dist/generated/entities/notification/index.js +57 -0
  2. package/dist/generated/entities/notification/index.js.map +7 -0
  3. package/dist/generated/entities.ids.generated.js +5 -2
  4. package/dist/generated/entities.ids.generated.js.map +2 -2
  5. package/dist/generated/entity-fields-registry.js +2 -2
  6. package/dist/generated/entity-fields-registry.js.map +2 -2
  7. package/dist/modules/api_docs/frontend/docs/api/page.js +3 -2
  8. package/dist/modules/api_docs/frontend/docs/api/page.js.map +2 -2
  9. package/dist/modules/api_keys/backend/api-keys/page.js +1 -1
  10. package/dist/modules/api_keys/backend/api-keys/page.js.map +2 -2
  11. package/dist/modules/api_keys/setup.js +11 -0
  12. package/dist/modules/api_keys/setup.js.map +7 -0
  13. package/dist/modules/attachments/components/AttachmentLibrary.js +5 -1
  14. package/dist/modules/attachments/components/AttachmentLibrary.js.map +2 -2
  15. package/dist/modules/attachments/components/AttachmentPartitionSettings.js +2 -0
  16. package/dist/modules/attachments/components/AttachmentPartitionSettings.js.map +2 -2
  17. package/dist/modules/attachments/lib/assignmentDetails.js +31 -17
  18. package/dist/modules/attachments/lib/assignmentDetails.js.map +2 -2
  19. package/dist/modules/attachments/lib/partitions.js +3 -3
  20. package/dist/modules/attachments/lib/partitions.js.map +2 -2
  21. package/dist/modules/attachments/setup.js +11 -0
  22. package/dist/modules/attachments/setup.js.map +7 -0
  23. package/dist/modules/audit_logs/setup.js +12 -0
  24. package/dist/modules/audit_logs/setup.js.map +7 -0
  25. package/dist/modules/auth/api/admin/nav.js +4 -3
  26. package/dist/modules/auth/api/admin/nav.js.map +2 -2
  27. package/dist/modules/auth/api/login.js +25 -6
  28. package/dist/modules/auth/api/login.js.map +2 -2
  29. package/dist/modules/auth/api/profile/route.js +157 -0
  30. package/dist/modules/auth/api/profile/route.js.map +7 -0
  31. package/dist/modules/auth/api/reset/confirm.js +25 -2
  32. package/dist/modules/auth/api/reset/confirm.js.map +2 -2
  33. package/dist/modules/auth/api/reset.js +23 -0
  34. package/dist/modules/auth/api/reset.js.map +2 -2
  35. package/dist/modules/auth/api/sidebar/preferences/route.js +14 -9
  36. package/dist/modules/auth/api/sidebar/preferences/route.js.map +2 -2
  37. package/dist/modules/auth/api/users/route.js +4 -2
  38. package/dist/modules/auth/api/users/route.js.map +2 -2
  39. package/dist/modules/auth/backend/auth/profile/page.js +141 -0
  40. package/dist/modules/auth/backend/auth/profile/page.js.map +7 -0
  41. package/dist/modules/auth/backend/auth/profile/page.meta.js +13 -0
  42. package/dist/modules/auth/backend/auth/profile/page.meta.js.map +7 -0
  43. package/dist/modules/auth/backend/roles/[id]/edit/page.js +4 -1
  44. package/dist/modules/auth/backend/roles/[id]/edit/page.js.map +2 -2
  45. package/dist/modules/auth/backend/roles/page.js +3 -3
  46. package/dist/modules/auth/backend/roles/page.js.map +2 -2
  47. package/dist/modules/auth/backend/users/[id]/edit/page.js +18 -3
  48. package/dist/modules/auth/backend/users/[id]/edit/page.js.map +2 -2
  49. package/dist/modules/auth/backend/users/create/page.js +15 -2
  50. package/dist/modules/auth/backend/users/create/page.js.map +2 -2
  51. package/dist/modules/auth/backend/users/page.js +3 -3
  52. package/dist/modules/auth/backend/users/page.js.map +2 -2
  53. package/dist/modules/auth/cli.js +25 -11
  54. package/dist/modules/auth/cli.js.map +2 -2
  55. package/dist/modules/auth/commands/users.js +59 -2
  56. package/dist/modules/auth/commands/users.js.map +2 -2
  57. package/dist/modules/auth/data/validators.js +6 -3
  58. package/dist/modules/auth/data/validators.js.map +2 -2
  59. package/dist/modules/auth/frontend/login.js +112 -3
  60. package/dist/modules/auth/frontend/login.js.map +2 -2
  61. package/dist/modules/auth/frontend/reset/[token]/page.js +20 -10
  62. package/dist/modules/auth/frontend/reset/[token]/page.js.map +2 -2
  63. package/dist/modules/auth/lib/setup-app.js +70 -167
  64. package/dist/modules/auth/lib/setup-app.js.map +2 -2
  65. package/dist/modules/auth/notifications.js +112 -0
  66. package/dist/modules/auth/notifications.js.map +7 -0
  67. package/dist/modules/auth/services/authService.js +24 -3
  68. package/dist/modules/auth/services/authService.js.map +2 -2
  69. package/dist/modules/auth/setup.js +11 -0
  70. package/dist/modules/auth/setup.js.map +7 -0
  71. package/dist/modules/business_rules/api/execute/route.js +7 -1
  72. package/dist/modules/business_rules/api/execute/route.js.map +2 -2
  73. package/dist/modules/business_rules/backend/rules/page.js +4 -0
  74. package/dist/modules/business_rules/backend/rules/page.js.map +2 -2
  75. package/dist/modules/business_rules/backend/sets/page.js +3 -0
  76. package/dist/modules/business_rules/backend/sets/page.js.map +2 -2
  77. package/dist/modules/business_rules/cli.js +2 -1
  78. package/dist/modules/business_rules/cli.js.map +2 -2
  79. package/dist/modules/business_rules/data/validators.js +0 -34
  80. package/dist/modules/business_rules/data/validators.js.map +2 -2
  81. package/dist/modules/business_rules/index.js +1 -21
  82. package/dist/modules/business_rules/index.js.map +2 -2
  83. package/dist/modules/business_rules/lib/rule-engine.js +34 -185
  84. package/dist/modules/business_rules/lib/rule-engine.js.map +2 -2
  85. package/dist/modules/business_rules/notifications.js +28 -0
  86. package/dist/modules/business_rules/notifications.js.map +7 -0
  87. package/dist/modules/business_rules/setup.js +11 -0
  88. package/dist/modules/business_rules/setup.js.map +7 -0
  89. package/dist/modules/business_rules/subscribers/rule-execution-failed-notification.js +37 -0
  90. package/dist/modules/business_rules/subscribers/rule-execution-failed-notification.js.map +7 -0
  91. package/dist/modules/catalog/components/PriceKindSettings.js +2 -0
  92. package/dist/modules/catalog/components/PriceKindSettings.js.map +2 -2
  93. package/dist/modules/catalog/components/categories/CategoriesDataTable.js +2 -2
  94. package/dist/modules/catalog/components/categories/CategoriesDataTable.js.map +2 -2
  95. package/dist/modules/catalog/components/products/ProductsDataTable.js +2 -0
  96. package/dist/modules/catalog/components/products/ProductsDataTable.js.map +2 -2
  97. package/dist/modules/catalog/notifications.js +28 -0
  98. package/dist/modules/catalog/notifications.js.map +7 -0
  99. package/dist/modules/catalog/setup.js +22 -0
  100. package/dist/modules/catalog/setup.js.map +7 -0
  101. package/dist/modules/catalog/subscribers/low-stock-notification.js +38 -0
  102. package/dist/modules/catalog/subscribers/low-stock-notification.js.map +7 -0
  103. package/dist/modules/configs/cli.js +6 -0
  104. package/dist/modules/configs/cli.js.map +2 -2
  105. package/dist/modules/configs/components/CachePanel.js +4 -4
  106. package/dist/modules/configs/components/CachePanel.js.map +2 -2
  107. package/dist/modules/configs/lib/system-status.js +48 -1
  108. package/dist/modules/configs/lib/system-status.js.map +2 -2
  109. package/dist/modules/configs/lib/upgrade-actions.js +1 -302
  110. package/dist/modules/configs/lib/upgrade-actions.js.map +2 -2
  111. package/dist/modules/configs/setup.js +16 -0
  112. package/dist/modules/configs/setup.js.map +7 -0
  113. package/dist/modules/currencies/backend/currencies/page.js +3 -0
  114. package/dist/modules/currencies/backend/currencies/page.js.map +2 -2
  115. package/dist/modules/currencies/backend/exchange-rates/page.js +2 -0
  116. package/dist/modules/currencies/backend/exchange-rates/page.js.map +2 -2
  117. package/dist/modules/currencies/setup.js +16 -0
  118. package/dist/modules/currencies/setup.js.map +7 -0
  119. package/dist/modules/customers/backend/customers/companies/page.js +3 -0
  120. package/dist/modules/customers/backend/customers/companies/page.js.map +2 -2
  121. package/dist/modules/customers/backend/customers/deals/page.js +3 -0
  122. package/dist/modules/customers/backend/customers/deals/page.js.map +2 -2
  123. package/dist/modules/customers/backend/customers/people/page.js +3 -0
  124. package/dist/modules/customers/backend/customers/people/page.js.map +2 -2
  125. package/dist/modules/customers/commands/deals.js +31 -0
  126. package/dist/modules/customers/commands/deals.js.map +2 -2
  127. package/dist/modules/customers/components/CustomerTodosTable.js +1 -0
  128. package/dist/modules/customers/components/CustomerTodosTable.js.map +2 -2
  129. package/dist/modules/customers/notifications.js +48 -0
  130. package/dist/modules/customers/notifications.js.map +7 -0
  131. package/dist/modules/customers/setup.js +36 -0
  132. package/dist/modules/customers/setup.js.map +7 -0
  133. package/dist/modules/customers/widgets/dashboard/customer-todos/widget.js +2 -1
  134. package/dist/modules/customers/widgets/dashboard/customer-todos/widget.js.map +2 -2
  135. package/dist/modules/customers/widgets/dashboard/new-customers/widget.js +2 -1
  136. package/dist/modules/customers/widgets/dashboard/new-customers/widget.js.map +2 -2
  137. package/dist/modules/customers/widgets/dashboard/new-deals/widget.js +2 -1
  138. package/dist/modules/customers/widgets/dashboard/new-deals/widget.js.map +2 -2
  139. package/dist/modules/customers/widgets/dashboard/next-interactions/widget.js +2 -1
  140. package/dist/modules/customers/widgets/dashboard/next-interactions/widget.js.map +2 -2
  141. package/dist/modules/dashboards/cli.js +44 -5
  142. package/dist/modules/dashboards/cli.js.map +2 -2
  143. package/dist/modules/dashboards/components/WidgetVisibilityEditor.js +16 -11
  144. package/dist/modules/dashboards/components/WidgetVisibilityEditor.js.map +3 -3
  145. package/dist/modules/dashboards/lib/role-widgets.js +58 -0
  146. package/dist/modules/dashboards/lib/role-widgets.js.map +7 -0
  147. package/dist/modules/dashboards/services/widgetDataService.js +139 -3
  148. package/dist/modules/dashboards/services/widgetDataService.js.map +2 -2
  149. package/dist/modules/dashboards/setup.js +27 -0
  150. package/dist/modules/dashboards/setup.js.map +7 -0
  151. package/dist/modules/dashboards/widgets/dashboard/aov-kpi/widget.js +2 -1
  152. package/dist/modules/dashboards/widgets/dashboard/aov-kpi/widget.js.map +2 -2
  153. package/dist/modules/dashboards/widgets/dashboard/new-customers-kpi/widget.js +2 -1
  154. package/dist/modules/dashboards/widgets/dashboard/new-customers-kpi/widget.js.map +2 -2
  155. package/dist/modules/dashboards/widgets/dashboard/orders-by-status/widget.js +2 -1
  156. package/dist/modules/dashboards/widgets/dashboard/orders-by-status/widget.js.map +2 -2
  157. package/dist/modules/dashboards/widgets/dashboard/orders-kpi/widget.js +2 -1
  158. package/dist/modules/dashboards/widgets/dashboard/orders-kpi/widget.js.map +2 -2
  159. package/dist/modules/dashboards/widgets/dashboard/pipeline-summary/widget.js +2 -1
  160. package/dist/modules/dashboards/widgets/dashboard/pipeline-summary/widget.js.map +2 -2
  161. package/dist/modules/dashboards/widgets/dashboard/revenue-kpi/widget.js +2 -1
  162. package/dist/modules/dashboards/widgets/dashboard/revenue-kpi/widget.js.map +2 -2
  163. package/dist/modules/dashboards/widgets/dashboard/revenue-trend/widget.js +2 -1
  164. package/dist/modules/dashboards/widgets/dashboard/revenue-trend/widget.js.map +2 -2
  165. package/dist/modules/dashboards/widgets/dashboard/sales-by-region/widget.js +2 -1
  166. package/dist/modules/dashboards/widgets/dashboard/sales-by-region/widget.js.map +2 -2
  167. package/dist/modules/dashboards/widgets/dashboard/top-customers/widget.js +2 -1
  168. package/dist/modules/dashboards/widgets/dashboard/top-customers/widget.js.map +2 -2
  169. package/dist/modules/dashboards/widgets/dashboard/top-products/widget.js +2 -1
  170. package/dist/modules/dashboards/widgets/dashboard/top-products/widget.js.map +2 -2
  171. package/dist/modules/dictionaries/components/DictionaryTable.js +2 -0
  172. package/dist/modules/dictionaries/components/DictionaryTable.js.map +2 -2
  173. package/dist/modules/dictionaries/setup.js +12 -0
  174. package/dist/modules/dictionaries/setup.js.map +7 -0
  175. package/dist/modules/directory/api/get/tenants/lookup.js +70 -0
  176. package/dist/modules/directory/api/get/tenants/lookup.js.map +7 -0
  177. package/dist/modules/directory/backend/directory/organizations/page.js +2 -2
  178. package/dist/modules/directory/backend/directory/organizations/page.js.map +2 -2
  179. package/dist/modules/directory/backend/directory/tenants/page.js +2 -2
  180. package/dist/modules/directory/backend/directory/tenants/page.js.map +2 -2
  181. package/dist/modules/directory/setup.js +12 -0
  182. package/dist/modules/directory/setup.js.map +7 -0
  183. package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js +2 -2
  184. package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js.map +2 -2
  185. package/dist/modules/entities/components/SystemEntitiesTable.js +1 -1
  186. package/dist/modules/entities/components/SystemEntitiesTable.js.map +2 -2
  187. package/dist/modules/entities/components/UserEntitiesTable.js +2 -2
  188. package/dist/modules/entities/components/UserEntitiesTable.js.map +2 -2
  189. package/dist/modules/entities/setup.js +11 -0
  190. package/dist/modules/entities/setup.js.map +7 -0
  191. package/dist/modules/feature_toggles/components/FeatureTogglesTable.js +3 -3
  192. package/dist/modules/feature_toggles/components/FeatureTogglesTable.js.map +2 -2
  193. package/dist/modules/feature_toggles/components/OverridesTable.js +1 -1
  194. package/dist/modules/feature_toggles/components/OverridesTable.js.map +2 -2
  195. package/dist/modules/feature_toggles/setup.js +11 -0
  196. package/dist/modules/feature_toggles/setup.js.map +7 -0
  197. package/dist/modules/notifications/acl.js +11 -0
  198. package/dist/modules/notifications/acl.js.map +7 -0
  199. package/dist/modules/notifications/api/[id]/action/route.js +74 -0
  200. package/dist/modules/notifications/api/[id]/action/route.js.map +7 -0
  201. package/dist/modules/notifications/api/[id]/dismiss/route.js +15 -0
  202. package/dist/modules/notifications/api/[id]/dismiss/route.js.map +7 -0
  203. package/dist/modules/notifications/api/[id]/read/route.js +15 -0
  204. package/dist/modules/notifications/api/[id]/read/route.js.map +7 -0
  205. package/dist/modules/notifications/api/[id]/restore/route.js +53 -0
  206. package/dist/modules/notifications/api/[id]/restore/route.js.map +7 -0
  207. package/dist/modules/notifications/api/batch/route.js +17 -0
  208. package/dist/modules/notifications/api/batch/route.js.map +7 -0
  209. package/dist/modules/notifications/api/feature/route.js +17 -0
  210. package/dist/modules/notifications/api/feature/route.js.map +7 -0
  211. package/dist/modules/notifications/api/mark-all-read/route.js +35 -0
  212. package/dist/modules/notifications/api/mark-all-read/route.js.map +7 -0
  213. package/dist/modules/notifications/api/openapi.js +76 -0
  214. package/dist/modules/notifications/api/openapi.js.map +7 -0
  215. package/dist/modules/notifications/api/role/route.js +17 -0
  216. package/dist/modules/notifications/api/role/route.js.map +7 -0
  217. package/dist/modules/notifications/api/route.js +85 -0
  218. package/dist/modules/notifications/api/route.js.map +7 -0
  219. package/dist/modules/notifications/api/settings/route.js +155 -0
  220. package/dist/modules/notifications/api/settings/route.js.map +7 -0
  221. package/dist/modules/notifications/api/unread-count/route.js +38 -0
  222. package/dist/modules/notifications/api/unread-count/route.js.map +7 -0
  223. package/dist/modules/notifications/backend/config/notifications/page.js +10 -0
  224. package/dist/modules/notifications/backend/config/notifications/page.js.map +7 -0
  225. package/dist/modules/notifications/backend/config/notifications/page.meta.js +24 -0
  226. package/dist/modules/notifications/backend/config/notifications/page.meta.js.map +7 -0
  227. package/dist/modules/notifications/cli.js +16 -0
  228. package/dist/modules/notifications/cli.js.map +7 -0
  229. package/dist/modules/notifications/data/entities.js +112 -0
  230. package/dist/modules/notifications/data/entities.js.map +7 -0
  231. package/dist/modules/notifications/data/validators.js +98 -0
  232. package/dist/modules/notifications/data/validators.js.map +7 -0
  233. package/dist/modules/notifications/di.js +13 -0
  234. package/dist/modules/notifications/di.js.map +7 -0
  235. package/dist/modules/notifications/emails/NotificationEmail.js +58 -0
  236. package/dist/modules/notifications/emails/NotificationEmail.js.map +7 -0
  237. package/dist/modules/notifications/frontend/NotificationInboxPageClient.js +44 -0
  238. package/dist/modules/notifications/frontend/NotificationInboxPageClient.js.map +7 -0
  239. package/dist/modules/notifications/frontend/NotificationSettingsPageClient.js +220 -0
  240. package/dist/modules/notifications/frontend/NotificationSettingsPageClient.js.map +7 -0
  241. package/dist/modules/notifications/index.js +14 -0
  242. package/dist/modules/notifications/index.js.map +7 -0
  243. package/dist/modules/notifications/lib/deliveryConfig.js +107 -0
  244. package/dist/modules/notifications/lib/deliveryConfig.js.map +7 -0
  245. package/dist/modules/notifications/lib/deliveryStrategies.js +14 -0
  246. package/dist/modules/notifications/lib/deliveryStrategies.js.map +7 -0
  247. package/dist/modules/notifications/lib/events.js +12 -0
  248. package/dist/modules/notifications/lib/events.js.map +7 -0
  249. package/dist/modules/notifications/lib/notificationBuilder.js +66 -0
  250. package/dist/modules/notifications/lib/notificationBuilder.js.map +7 -0
  251. package/dist/modules/notifications/lib/notificationFactory.js +54 -0
  252. package/dist/modules/notifications/lib/notificationFactory.js.map +7 -0
  253. package/dist/modules/notifications/lib/notificationMapper.js +34 -0
  254. package/dist/modules/notifications/lib/notificationMapper.js.map +7 -0
  255. package/dist/modules/notifications/lib/notificationRecipients.js +35 -0
  256. package/dist/modules/notifications/lib/notificationRecipients.js.map +7 -0
  257. package/dist/modules/notifications/lib/notificationService.js +279 -0
  258. package/dist/modules/notifications/lib/notificationService.js.map +7 -0
  259. package/dist/modules/notifications/lib/routeHelpers.js +101 -0
  260. package/dist/modules/notifications/lib/routeHelpers.js.map +7 -0
  261. package/dist/modules/notifications/lib/safeHref.js +24 -0
  262. package/dist/modules/notifications/lib/safeHref.js.map +7 -0
  263. package/dist/modules/notifications/migrations/Migration20260123000001.js +70 -0
  264. package/dist/modules/notifications/migrations/Migration20260123000001.js.map +7 -0
  265. package/dist/modules/notifications/migrations/Migration20260126150000.js +37 -0
  266. package/dist/modules/notifications/migrations/Migration20260126150000.js.map +7 -0
  267. package/dist/modules/notifications/migrations/Migration20260129082610.js +13 -0
  268. package/dist/modules/notifications/migrations/Migration20260129082610.js.map +7 -0
  269. package/dist/modules/notifications/subscribers/deliver-notification.js +165 -0
  270. package/dist/modules/notifications/subscribers/deliver-notification.js.map +7 -0
  271. package/dist/modules/notifications/workers/create-notification.worker.js +70 -0
  272. package/dist/modules/notifications/workers/create-notification.worker.js.map +7 -0
  273. package/dist/modules/perspectives/setup.js +12 -0
  274. package/dist/modules/perspectives/setup.js.map +7 -0
  275. package/dist/modules/planner/backend/planner/availability-rulesets/page.js +2 -2
  276. package/dist/modules/planner/backend/planner/availability-rulesets/page.js.map +2 -2
  277. package/dist/modules/planner/setup.js +21 -0
  278. package/dist/modules/planner/setup.js.map +7 -0
  279. package/dist/modules/query_index/cli.js +63 -7
  280. package/dist/modules/query_index/cli.js.map +2 -2
  281. package/dist/modules/query_index/components/QueryIndexesTable.js +7 -1
  282. package/dist/modules/query_index/components/QueryIndexesTable.js.map +2 -2
  283. package/dist/modules/query_index/setup.js +11 -0
  284. package/dist/modules/query_index/setup.js.map +7 -0
  285. package/dist/modules/resources/backend/resources/resource-types/page.js +2 -2
  286. package/dist/modules/resources/backend/resources/resource-types/page.js.map +2 -2
  287. package/dist/modules/resources/backend/resources/resources/page.js +2 -2
  288. package/dist/modules/resources/backend/resources/resources/page.js.map +2 -2
  289. package/dist/modules/resources/setup.js +21 -0
  290. package/dist/modules/resources/setup.js.map +7 -0
  291. package/dist/modules/sales/acl.js +0 -1
  292. package/dist/modules/sales/acl.js.map +2 -2
  293. package/dist/modules/sales/backend/sales/channels/offers/page.js +2 -0
  294. package/dist/modules/sales/backend/sales/channels/offers/page.js.map +2 -2
  295. package/dist/modules/sales/backend/sales/channels/page.js +2 -0
  296. package/dist/modules/sales/backend/sales/channels/page.js.map +2 -2
  297. package/dist/modules/sales/backend/sales/documents/[id]/page.js +0 -12
  298. package/dist/modules/sales/backend/sales/documents/[id]/page.js.map +2 -2
  299. package/dist/modules/sales/cli.js +2 -42
  300. package/dist/modules/sales/cli.js.map +2 -2
  301. package/dist/modules/sales/commands/documents.js +53 -62
  302. package/dist/modules/sales/commands/documents.js.map +2 -2
  303. package/dist/modules/sales/commands/payments.js +26 -0
  304. package/dist/modules/sales/commands/payments.js.map +2 -2
  305. package/dist/modules/sales/components/AdjustmentKindSettings.js +2 -2
  306. package/dist/modules/sales/components/AdjustmentKindSettings.js.map +2 -2
  307. package/dist/modules/sales/components/PaymentMethodsSettings.js +2 -2
  308. package/dist/modules/sales/components/PaymentMethodsSettings.js.map +2 -2
  309. package/dist/modules/sales/components/ShippingMethodsSettings.js +2 -2
  310. package/dist/modules/sales/components/ShippingMethodsSettings.js.map +2 -2
  311. package/dist/modules/sales/components/TaxRatesSettings.js +2 -2
  312. package/dist/modules/sales/components/TaxRatesSettings.js.map +2 -2
  313. package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js +2 -0
  314. package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js.map +2 -2
  315. package/dist/modules/sales/components/documents/AdjustmentsSection.js +2 -0
  316. package/dist/modules/sales/components/documents/AdjustmentsSection.js.map +2 -2
  317. package/dist/modules/sales/components/documents/PaymentsSection.js +2 -1
  318. package/dist/modules/sales/components/documents/PaymentsSection.js.map +2 -2
  319. package/dist/modules/sales/components/documents/SalesDocumentsTable.js +2 -0
  320. package/dist/modules/sales/components/documents/SalesDocumentsTable.js.map +2 -2
  321. package/dist/modules/sales/lib/dictionaries.js +0 -3
  322. package/dist/modules/sales/lib/dictionaries.js.map +2 -2
  323. package/dist/modules/sales/lib/seeds.js +48 -0
  324. package/dist/modules/sales/lib/seeds.js.map +7 -0
  325. package/dist/modules/sales/notifications.client.js +51 -0
  326. package/dist/modules/sales/notifications.client.js.map +7 -0
  327. package/dist/modules/sales/notifications.js +88 -0
  328. package/dist/modules/sales/notifications.js.map +7 -0
  329. package/dist/modules/sales/setup.js +99 -0
  330. package/dist/modules/sales/setup.js.map +7 -0
  331. package/dist/modules/sales/subscribers/quote-expiring-notification.js +38 -0
  332. package/dist/modules/sales/subscribers/quote-expiring-notification.js.map +7 -0
  333. package/dist/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.js +137 -0
  334. package/dist/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.js.map +7 -0
  335. package/dist/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.js +137 -0
  336. package/dist/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.js.map +7 -0
  337. package/dist/modules/sales/widgets/notifications/index.js +7 -0
  338. package/dist/modules/sales/widgets/notifications/index.js.map +7 -0
  339. package/dist/modules/sales/widgets/notifications/useSalesDocumentTotals.js +60 -0
  340. package/dist/modules/sales/widgets/notifications/useSalesDocumentTotals.js.map +7 -0
  341. package/dist/modules/staff/backend/staff/team-members/page.js +1 -1
  342. package/dist/modules/staff/backend/staff/team-members/page.js.map +2 -2
  343. package/dist/modules/staff/backend/staff/team-roles/page.js +2 -2
  344. package/dist/modules/staff/backend/staff/team-roles/page.js.map +2 -2
  345. package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js +2 -2
  346. package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js.map +2 -2
  347. package/dist/modules/staff/backend/staff/teams/page.js +2 -2
  348. package/dist/modules/staff/backend/staff/teams/page.js.map +2 -2
  349. package/dist/modules/staff/commands/leave-requests.js +79 -0
  350. package/dist/modules/staff/commands/leave-requests.js.map +2 -2
  351. package/dist/modules/staff/notifications.js +75 -0
  352. package/dist/modules/staff/notifications.js.map +7 -0
  353. package/dist/modules/staff/setup.js +27 -0
  354. package/dist/modules/staff/setup.js.map +7 -0
  355. package/dist/modules/workflows/acl.js +0 -2
  356. package/dist/modules/workflows/acl.js.map +2 -2
  357. package/dist/modules/workflows/api/instances/route.js +6 -18
  358. package/dist/modules/workflows/api/instances/route.js.map +2 -2
  359. package/dist/modules/workflows/api/tasks/route.js +1 -6
  360. package/dist/modules/workflows/api/tasks/route.js.map +2 -2
  361. package/dist/modules/workflows/backend/definitions/[id]/page.js +1 -9
  362. package/dist/modules/workflows/backend/definitions/[id]/page.js.map +2 -2
  363. package/dist/modules/workflows/backend/definitions/[id]/page.meta.js +1 -1
  364. package/dist/modules/workflows/backend/definitions/[id]/page.meta.js.map +2 -2
  365. package/dist/modules/workflows/backend/definitions/create/page.js +15 -24
  366. package/dist/modules/workflows/backend/definitions/create/page.js.map +2 -2
  367. package/dist/modules/workflows/backend/definitions/create/page.meta.js +1 -1
  368. package/dist/modules/workflows/backend/definitions/create/page.meta.js.map +2 -2
  369. package/dist/modules/workflows/backend/definitions/page.js +5 -0
  370. package/dist/modules/workflows/backend/definitions/page.js.map +2 -2
  371. package/dist/modules/workflows/backend/definitions/visual-editor/page.js +132 -150
  372. package/dist/modules/workflows/backend/definitions/visual-editor/page.js.map +2 -2
  373. package/dist/modules/workflows/backend/definitions/visual-editor/page.meta.js +1 -1
  374. package/dist/modules/workflows/backend/definitions/visual-editor/page.meta.js.map +2 -2
  375. package/dist/modules/workflows/backend/events/[id]/page.js +1 -1
  376. package/dist/modules/workflows/backend/events/[id]/page.js.map +2 -2
  377. package/dist/modules/workflows/backend/events/[id]/page.meta.js +2 -2
  378. package/dist/modules/workflows/backend/events/[id]/page.meta.js.map +2 -2
  379. package/dist/modules/workflows/backend/instances/[id]/page.meta.js +2 -2
  380. package/dist/modules/workflows/backend/instances/[id]/page.meta.js.map +2 -2
  381. package/dist/modules/workflows/backend/instances/page.js +3 -0
  382. package/dist/modules/workflows/backend/instances/page.js.map +2 -2
  383. package/dist/modules/workflows/backend/tasks/[id]/page.js +1 -1
  384. package/dist/modules/workflows/backend/tasks/[id]/page.js.map +2 -2
  385. package/dist/modules/workflows/backend/tasks/[id]/page.meta.js +2 -2
  386. package/dist/modules/workflows/backend/tasks/[id]/page.meta.js.map +2 -2
  387. package/dist/modules/workflows/backend/tasks/page.js +9 -5
  388. package/dist/modules/workflows/backend/tasks/page.js.map +2 -2
  389. package/dist/modules/workflows/cli.js +15 -93
  390. package/dist/modules/workflows/cli.js.map +3 -3
  391. package/dist/modules/workflows/data/entities.js +1 -64
  392. package/dist/modules/workflows/data/entities.js.map +2 -2
  393. package/dist/modules/workflows/data/validators.js +0 -115
  394. package/dist/modules/workflows/data/validators.js.map +2 -2
  395. package/dist/modules/workflows/examples/checkout-demo-definition.json +5 -1
  396. package/dist/modules/workflows/lib/activity-executor.js +13 -75
  397. package/dist/modules/workflows/lib/activity-executor.js.map +2 -2
  398. package/dist/modules/workflows/lib/graph-utils.js +2 -71
  399. package/dist/modules/workflows/lib/graph-utils.js.map +2 -2
  400. package/dist/modules/workflows/lib/seeds.js +7 -36
  401. package/dist/modules/workflows/lib/seeds.js.map +2 -2
  402. package/dist/modules/workflows/lib/start-validator.js +23 -33
  403. package/dist/modules/workflows/lib/start-validator.js.map +2 -2
  404. package/dist/modules/workflows/lib/transition-handler.js +57 -161
  405. package/dist/modules/workflows/lib/transition-handler.js.map +3 -3
  406. package/dist/modules/workflows/migrations/Migration20251207131955.js +76 -72
  407. package/dist/modules/workflows/migrations/Migration20251207131955.js.map +2 -2
  408. package/dist/modules/workflows/notifications.js +28 -0
  409. package/dist/modules/workflows/notifications.js.map +7 -0
  410. package/dist/modules/workflows/setup.js +16 -0
  411. package/dist/modules/workflows/setup.js.map +7 -0
  412. package/dist/modules/workflows/subscribers/task-assigned-notification.js +38 -0
  413. package/dist/modules/workflows/subscribers/task-assigned-notification.js.map +7 -0
  414. package/generated/entities/notification/index.ts +27 -0
  415. package/generated/entities.ids.generated.ts +5 -2
  416. package/generated/entity-fields-registry.ts +2 -2
  417. package/package.json +2 -2
  418. package/src/__tests__/module-decoupling.test.ts +356 -0
  419. package/src/modules/api_docs/frontend/docs/api/page.tsx +3 -2
  420. package/src/modules/api_keys/backend/api-keys/page.tsx +1 -1
  421. package/src/modules/api_keys/setup.ts +9 -0
  422. package/src/modules/attachments/components/AttachmentLibrary.tsx +6 -2
  423. package/src/modules/attachments/components/AttachmentPartitionSettings.tsx +2 -0
  424. package/src/modules/attachments/lib/assignmentDetails.ts +32 -16
  425. package/src/modules/attachments/lib/partitions.ts +3 -3
  426. package/src/modules/attachments/setup.ts +9 -0
  427. package/src/modules/audit_logs/setup.ts +10 -0
  428. package/src/modules/auth/README.md +1 -1
  429. package/src/modules/auth/__tests__/cli-setup-acl.test.ts +31 -1
  430. package/src/modules/auth/api/__tests__/login.test.ts +2 -0
  431. package/src/modules/auth/api/admin/nav.ts +10 -6
  432. package/src/modules/auth/api/login.ts +26 -7
  433. package/src/modules/auth/api/profile/route.ts +163 -0
  434. package/src/modules/auth/api/reset/confirm.ts +25 -2
  435. package/src/modules/auth/api/reset.ts +23 -0
  436. package/src/modules/auth/api/sidebar/preferences/route.ts +21 -12
  437. package/src/modules/auth/api/users/route.ts +5 -2
  438. package/src/modules/auth/backend/auth/profile/page.meta.ts +9 -0
  439. package/src/modules/auth/backend/auth/profile/page.tsx +174 -0
  440. package/src/modules/auth/backend/roles/[id]/edit/page.tsx +4 -1
  441. package/src/modules/auth/backend/roles/page.tsx +3 -3
  442. package/src/modules/auth/backend/users/[id]/edit/page.tsx +22 -3
  443. package/src/modules/auth/backend/users/create/page.tsx +19 -2
  444. package/src/modules/auth/backend/users/page.tsx +3 -3
  445. package/src/modules/auth/cli.ts +38 -11
  446. package/src/modules/auth/commands/users.ts +73 -2
  447. package/src/modules/auth/data/validators.ts +6 -2
  448. package/src/modules/auth/frontend/login.tsx +134 -5
  449. package/src/modules/auth/frontend/reset/[token]/page.tsx +24 -11
  450. package/src/modules/auth/i18n/de.json +48 -1
  451. package/src/modules/auth/i18n/en.json +48 -1
  452. package/src/modules/auth/i18n/es.json +48 -1
  453. package/src/modules/auth/i18n/pl.json +48 -1
  454. package/src/modules/auth/lib/setup-app.ts +97 -186
  455. package/src/modules/auth/notifications.ts +109 -0
  456. package/src/modules/auth/services/authService.ts +27 -4
  457. package/src/modules/auth/setup.ts +9 -0
  458. package/src/modules/business_rules/api/execute/route.ts +8 -1
  459. package/src/modules/business_rules/backend/rules/page.tsx +4 -0
  460. package/src/modules/business_rules/backend/sets/page.tsx +3 -0
  461. package/src/modules/business_rules/cli.ts +2 -1
  462. package/src/modules/business_rules/data/validators.ts +0 -40
  463. package/src/modules/business_rules/i18n/en.json +3 -1
  464. package/src/modules/business_rules/index.ts +0 -25
  465. package/src/modules/business_rules/lib/__tests__/rule-engine.test.ts +51 -0
  466. package/src/modules/business_rules/lib/rule-engine.ts +51 -277
  467. package/src/modules/business_rules/notifications.ts +25 -0
  468. package/src/modules/business_rules/setup.ts +9 -0
  469. package/src/modules/business_rules/subscribers/rule-execution-failed-notification.ts +50 -0
  470. package/src/modules/catalog/components/PriceKindSettings.tsx +2 -0
  471. package/src/modules/catalog/components/categories/CategoriesDataTable.tsx +2 -2
  472. package/src/modules/catalog/components/products/ProductsDataTable.tsx +2 -0
  473. package/src/modules/catalog/i18n/en.json +3 -1
  474. package/src/modules/catalog/notifications.ts +25 -0
  475. package/src/modules/catalog/setup.ts +22 -0
  476. package/src/modules/catalog/subscribers/low-stock-notification.ts +52 -0
  477. package/src/modules/configs/cli.ts +6 -0
  478. package/src/modules/configs/components/CachePanel.tsx +4 -4
  479. package/src/modules/configs/i18n/en.json +12 -2
  480. package/src/modules/configs/i18n/pl.json +12 -2
  481. package/src/modules/configs/lib/system-status.ts +48 -1
  482. package/src/modules/configs/lib/system-status.types.ts +1 -0
  483. package/src/modules/configs/lib/upgrade-actions.ts +5 -338
  484. package/src/modules/configs/setup.ts +14 -0
  485. package/src/modules/currencies/backend/currencies/page.tsx +3 -0
  486. package/src/modules/currencies/backend/exchange-rates/page.tsx +2 -0
  487. package/src/modules/currencies/setup.ts +15 -0
  488. package/src/modules/customers/backend/customers/companies/page.tsx +3 -0
  489. package/src/modules/customers/backend/customers/deals/page.tsx +3 -0
  490. package/src/modules/customers/backend/customers/people/page.tsx +3 -0
  491. package/src/modules/customers/commands/deals.ts +39 -0
  492. package/src/modules/customers/components/CustomerTodosTable.tsx +1 -0
  493. package/src/modules/customers/i18n/en.json +5 -1
  494. package/src/modules/customers/notifications.ts +44 -0
  495. package/src/modules/customers/setup.ts +36 -0
  496. package/src/modules/customers/widgets/dashboard/customer-todos/widget.ts +2 -2
  497. package/src/modules/customers/widgets/dashboard/new-customers/widget.ts +2 -2
  498. package/src/modules/customers/widgets/dashboard/new-deals/widget.ts +2 -2
  499. package/src/modules/customers/widgets/dashboard/next-interactions/widget.ts +2 -2
  500. package/src/modules/dashboards/cli.ts +55 -5
  501. package/src/modules/dashboards/components/WidgetVisibilityEditor.tsx +22 -11
  502. package/src/modules/dashboards/lib/role-widgets.ts +80 -0
  503. package/src/modules/dashboards/services/widgetDataService.ts +164 -4
  504. package/src/modules/dashboards/setup.ts +26 -0
  505. package/src/modules/dashboards/widgets/dashboard/aov-kpi/widget.ts +2 -2
  506. package/src/modules/dashboards/widgets/dashboard/new-customers-kpi/widget.ts +2 -2
  507. package/src/modules/dashboards/widgets/dashboard/orders-by-status/widget.ts +2 -2
  508. package/src/modules/dashboards/widgets/dashboard/orders-kpi/widget.ts +2 -2
  509. package/src/modules/dashboards/widgets/dashboard/pipeline-summary/widget.ts +2 -2
  510. package/src/modules/dashboards/widgets/dashboard/revenue-kpi/widget.ts +2 -2
  511. package/src/modules/dashboards/widgets/dashboard/revenue-trend/widget.ts +2 -2
  512. package/src/modules/dashboards/widgets/dashboard/sales-by-region/widget.ts +2 -2
  513. package/src/modules/dashboards/widgets/dashboard/top-customers/widget.ts +2 -2
  514. package/src/modules/dashboards/widgets/dashboard/top-products/widget.ts +2 -2
  515. package/src/modules/dictionaries/components/DictionaryTable.tsx +2 -0
  516. package/src/modules/dictionaries/setup.ts +10 -0
  517. package/src/modules/directory/api/get/tenants/lookup.ts +75 -0
  518. package/src/modules/directory/backend/directory/organizations/page.tsx +2 -2
  519. package/src/modules/directory/backend/directory/tenants/page.tsx +2 -2
  520. package/src/modules/directory/setup.ts +10 -0
  521. package/src/modules/entities/backend/entities/user/[entityId]/records/page.tsx +2 -2
  522. package/src/modules/entities/components/SystemEntitiesTable.tsx +1 -1
  523. package/src/modules/entities/components/UserEntitiesTable.tsx +2 -2
  524. package/src/modules/entities/setup.ts +9 -0
  525. package/src/modules/feature_toggles/components/FeatureTogglesTable.tsx +3 -4
  526. package/src/modules/feature_toggles/components/OverridesTable.tsx +1 -1
  527. package/src/modules/feature_toggles/setup.ts +9 -0
  528. package/src/modules/notifications/__tests__/deliver-notification.test.ts +195 -0
  529. package/src/modules/notifications/__tests__/deliveryStrategies.test.ts +19 -0
  530. package/src/modules/notifications/__tests__/notificationService.test.ts +208 -0
  531. package/src/modules/notifications/acl.ts +7 -0
  532. package/src/modules/notifications/api/[id]/action/route.ts +75 -0
  533. package/src/modules/notifications/api/[id]/dismiss/route.ts +12 -0
  534. package/src/modules/notifications/api/[id]/read/route.ts +12 -0
  535. package/src/modules/notifications/api/[id]/restore/route.ts +53 -0
  536. package/src/modules/notifications/api/batch/route.ts +14 -0
  537. package/src/modules/notifications/api/feature/route.ts +14 -0
  538. package/src/modules/notifications/api/mark-all-read/route.ts +34 -0
  539. package/src/modules/notifications/api/openapi.ts +76 -0
  540. package/src/modules/notifications/api/role/route.ts +14 -0
  541. package/src/modules/notifications/api/route.ts +92 -0
  542. package/src/modules/notifications/api/settings/route.ts +157 -0
  543. package/src/modules/notifications/api/unread-count/route.ts +38 -0
  544. package/src/modules/notifications/backend/config/notifications/page.meta.ts +22 -0
  545. package/src/modules/notifications/backend/config/notifications/page.tsx +12 -0
  546. package/src/modules/notifications/cli.ts +18 -0
  547. package/src/modules/notifications/data/entities.ts +99 -0
  548. package/src/modules/notifications/data/validators.ts +115 -0
  549. package/src/modules/notifications/di.ts +11 -0
  550. package/src/modules/notifications/emails/NotificationEmail.tsx +98 -0
  551. package/src/modules/notifications/frontend/NotificationInboxPageClient.tsx +42 -0
  552. package/src/modules/notifications/frontend/NotificationSettingsPageClient.tsx +233 -0
  553. package/src/modules/notifications/i18n/de.json +50 -0
  554. package/src/modules/notifications/i18n/en.json +50 -0
  555. package/src/modules/notifications/i18n/es.json +50 -0
  556. package/src/modules/notifications/i18n/pl.json +50 -0
  557. package/src/modules/notifications/index.ts +12 -0
  558. package/src/modules/notifications/lib/deliveryConfig.ts +153 -0
  559. package/src/modules/notifications/lib/deliveryStrategies.ts +50 -0
  560. package/src/modules/notifications/lib/events.ts +48 -0
  561. package/src/modules/notifications/lib/notificationBuilder.ts +121 -0
  562. package/src/modules/notifications/lib/notificationFactory.ts +76 -0
  563. package/src/modules/notifications/lib/notificationMapper.ts +33 -0
  564. package/src/modules/notifications/lib/notificationRecipients.ts +83 -0
  565. package/src/modules/notifications/lib/notificationService.ts +414 -0
  566. package/src/modules/notifications/lib/routeHelpers.ts +151 -0
  567. package/src/modules/notifications/lib/safeHref.ts +29 -0
  568. package/src/modules/notifications/migrations/.snapshot-open-mercato.json +336 -0
  569. package/src/modules/notifications/migrations/Migration20260123000001.ts +73 -0
  570. package/src/modules/notifications/migrations/Migration20260126150000.ts +39 -0
  571. package/src/modules/notifications/migrations/Migration20260129082610.ts +13 -0
  572. package/src/modules/notifications/subscribers/deliver-notification.ts +204 -0
  573. package/src/modules/notifications/workers/create-notification.worker.ts +122 -0
  574. package/src/modules/perspectives/setup.ts +10 -0
  575. package/src/modules/planner/backend/planner/availability-rulesets/page.tsx +2 -2
  576. package/src/modules/planner/setup.ts +21 -0
  577. package/src/modules/query_index/cli.ts +82 -13
  578. package/src/modules/query_index/components/QueryIndexesTable.tsx +8 -2
  579. package/src/modules/query_index/setup.ts +9 -0
  580. package/src/modules/resources/backend/resources/resource-types/page.tsx +2 -2
  581. package/src/modules/resources/backend/resources/resources/page.tsx +2 -2
  582. package/src/modules/resources/setup.ts +21 -0
  583. package/src/modules/sales/acl.ts +0 -1
  584. package/src/modules/sales/backend/sales/channels/offers/page.tsx +2 -0
  585. package/src/modules/sales/backend/sales/channels/page.tsx +2 -0
  586. package/src/modules/sales/backend/sales/documents/[id]/page.tsx +0 -16
  587. package/src/modules/sales/cli.ts +2 -43
  588. package/src/modules/sales/commands/documents.ts +62 -70
  589. package/src/modules/sales/commands/payments.ts +33 -0
  590. package/src/modules/sales/components/AdjustmentKindSettings.tsx +2 -2
  591. package/src/modules/sales/components/PaymentMethodsSettings.tsx +2 -2
  592. package/src/modules/sales/components/ShippingMethodsSettings.tsx +2 -2
  593. package/src/modules/sales/components/TaxRatesSettings.tsx +2 -2
  594. package/src/modules/sales/components/channels/SalesChannelOffersPanel.tsx +2 -0
  595. package/src/modules/sales/components/documents/AdjustmentsSection.tsx +2 -0
  596. package/src/modules/sales/components/documents/PaymentsSection.tsx +2 -1
  597. package/src/modules/sales/components/documents/SalesDocumentsTable.tsx +2 -0
  598. package/src/modules/sales/i18n/de.json +20 -0
  599. package/src/modules/sales/i18n/en.json +25 -1
  600. package/src/modules/sales/i18n/es.json +20 -0
  601. package/src/modules/sales/i18n/pl.json +20 -0
  602. package/src/modules/sales/lib/dictionaries.ts +0 -3
  603. package/src/modules/sales/lib/seeds.ts +53 -0
  604. package/src/modules/sales/notifications.client.ts +65 -0
  605. package/src/modules/sales/notifications.ts +82 -0
  606. package/src/modules/sales/setup.ts +108 -0
  607. package/src/modules/sales/subscribers/quote-expiring-notification.ts +53 -0
  608. package/src/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.tsx +156 -0
  609. package/src/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.tsx +156 -0
  610. package/src/modules/sales/widgets/notifications/index.ts +2 -0
  611. package/src/modules/sales/widgets/notifications/useSalesDocumentTotals.ts +81 -0
  612. package/src/modules/staff/backend/staff/team-members/page.tsx +1 -1
  613. package/src/modules/staff/backend/staff/team-roles/page.tsx +2 -2
  614. package/src/modules/staff/backend/staff/teams/[id]/edit/page.tsx +2 -2
  615. package/src/modules/staff/backend/staff/teams/page.tsx +2 -2
  616. package/src/modules/staff/commands/leave-requests.ts +94 -0
  617. package/src/modules/staff/i18n/de.json +4 -0
  618. package/src/modules/staff/i18n/en.json +9 -1
  619. package/src/modules/staff/i18n/es.json +4 -0
  620. package/src/modules/staff/i18n/pl.json +4 -0
  621. package/src/modules/staff/notifications.ts +71 -0
  622. package/src/modules/staff/setup.ts +27 -0
  623. package/src/modules/workflows/acl.ts +0 -2
  624. package/src/modules/workflows/api/__tests__/instances.route.test.ts +2 -5
  625. package/src/modules/workflows/api/instances/route.ts +7 -21
  626. package/src/modules/workflows/api/tasks/route.ts +1 -7
  627. package/src/modules/workflows/backend/definitions/[id]/page.meta.ts +1 -1
  628. package/src/modules/workflows/backend/definitions/[id]/page.tsx +0 -9
  629. package/src/modules/workflows/backend/definitions/create/page.meta.ts +1 -1
  630. package/src/modules/workflows/backend/definitions/create/page.tsx +0 -9
  631. package/src/modules/workflows/backend/definitions/page.tsx +5 -0
  632. package/src/modules/workflows/backend/definitions/visual-editor/page.meta.ts +1 -1
  633. package/src/modules/workflows/backend/definitions/visual-editor/page.tsx +3 -21
  634. package/src/modules/workflows/backend/events/[id]/page.meta.ts +2 -2
  635. package/src/modules/workflows/backend/events/[id]/page.tsx +1 -1
  636. package/src/modules/workflows/backend/instances/[id]/page.meta.ts +2 -2
  637. package/src/modules/workflows/backend/instances/page.tsx +4 -1
  638. package/src/modules/workflows/backend/tasks/[id]/page.meta.ts +2 -2
  639. package/src/modules/workflows/backend/tasks/[id]/page.tsx +1 -1
  640. package/src/modules/workflows/backend/tasks/page.tsx +10 -6
  641. package/src/modules/workflows/cli.ts +12 -123
  642. package/src/modules/workflows/data/entities.ts +0 -124
  643. package/src/modules/workflows/data/validators.ts +0 -138
  644. package/src/modules/workflows/examples/checkout-demo-definition.json +5 -1
  645. package/src/modules/workflows/i18n/en.json +3 -72
  646. package/src/modules/workflows/lib/__tests__/activity-executor.test.ts +36 -43
  647. package/src/modules/workflows/lib/__tests__/transition-handler.test.ts +90 -170
  648. package/src/modules/workflows/lib/activity-executor.ts +16 -129
  649. package/src/modules/workflows/lib/graph-utils.ts +2 -117
  650. package/src/modules/workflows/lib/seeds.ts +12 -50
  651. package/src/modules/workflows/lib/start-validator.ts +28 -38
  652. package/src/modules/workflows/lib/transition-handler.ts +71 -212
  653. package/src/modules/workflows/migrations/Migration20251207131955.ts +77 -143
  654. package/src/modules/workflows/notifications.ts +25 -0
  655. package/src/modules/workflows/setup.ts +15 -0
  656. package/src/modules/workflows/subscribers/task-assigned-notification.ts +53 -0
  657. package/dist/generated/entities/workflow_event_trigger/index.js +0 -33
  658. package/dist/generated/entities/workflow_event_trigger/index.js.map +0 -7
  659. package/dist/modules/auth/events.js +0 -30
  660. package/dist/modules/auth/events.js.map +0 -7
  661. package/dist/modules/business_rules/api/execute/[ruleId]/route.js +0 -145
  662. package/dist/modules/business_rules/api/execute/[ruleId]/route.js.map +0 -7
  663. package/dist/modules/catalog/events.js +0 -34
  664. package/dist/modules/catalog/events.js.map +0 -7
  665. package/dist/modules/customers/events.js +0 -49
  666. package/dist/modules/customers/events.js.map +0 -7
  667. package/dist/modules/directory/events.js +0 -23
  668. package/dist/modules/directory/events.js.map +0 -7
  669. package/dist/modules/sales/events.js +0 -63
  670. package/dist/modules/sales/events.js.map +0 -7
  671. package/dist/modules/sales/lib/frontend/documentDataEvents.js +0 -25
  672. package/dist/modules/sales/lib/frontend/documentDataEvents.js.map +0 -7
  673. package/dist/modules/workflows/components/DefinitionTriggersEditor.js +0 -481
  674. package/dist/modules/workflows/components/DefinitionTriggersEditor.js.map +0 -7
  675. package/dist/modules/workflows/components/EventTriggersEditor.js +0 -553
  676. package/dist/modules/workflows/components/EventTriggersEditor.js.map +0 -7
  677. package/dist/modules/workflows/events.js +0 -38
  678. package/dist/modules/workflows/events.js.map +0 -7
  679. package/dist/modules/workflows/examples/order-approval-definition.json +0 -257
  680. package/dist/modules/workflows/examples/order-approval-guard-rules.json +0 -32
  681. package/dist/modules/workflows/lib/event-trigger-service.js +0 -308
  682. package/dist/modules/workflows/lib/event-trigger-service.js.map +0 -7
  683. package/dist/modules/workflows/migrations/Migration20260123143500.js +0 -36
  684. package/dist/modules/workflows/migrations/Migration20260123143500.js.map +0 -7
  685. package/dist/modules/workflows/subscribers/event-trigger.js +0 -78
  686. package/dist/modules/workflows/subscribers/event-trigger.js.map +0 -7
  687. package/dist/modules/workflows/widgets/injection/order-approval/widget.client.js +0 -323
  688. package/dist/modules/workflows/widgets/injection/order-approval/widget.client.js.map +0 -7
  689. package/dist/modules/workflows/widgets/injection/order-approval/widget.js +0 -17
  690. package/dist/modules/workflows/widgets/injection/order-approval/widget.js.map +0 -7
  691. package/dist/modules/workflows/widgets/injection-table.js +0 -19
  692. package/dist/modules/workflows/widgets/injection-table.js.map +0 -7
  693. package/generated/entities/workflow_event_trigger/index.ts +0 -15
  694. package/src/modules/auth/events.ts +0 -39
  695. package/src/modules/business_rules/api/execute/[ruleId]/route.ts +0 -163
  696. package/src/modules/catalog/events.ts +0 -45
  697. package/src/modules/customers/events.ts +0 -63
  698. package/src/modules/directory/events.ts +0 -31
  699. package/src/modules/sales/events.ts +0 -82
  700. package/src/modules/sales/lib/frontend/documentDataEvents.ts +0 -28
  701. package/src/modules/workflows/components/DefinitionTriggersEditor.tsx +0 -581
  702. package/src/modules/workflows/components/EventTriggersEditor.tsx +0 -664
  703. package/src/modules/workflows/events.ts +0 -49
  704. package/src/modules/workflows/examples/order-approval-definition.json +0 -257
  705. package/src/modules/workflows/examples/order-approval-guard-rules.json +0 -32
  706. package/src/modules/workflows/lib/event-trigger-service.ts +0 -557
  707. package/src/modules/workflows/migrations/Migration20260123143500.ts +0 -38
  708. package/src/modules/workflows/subscribers/event-trigger.ts +0 -109
  709. package/src/modules/workflows/widgets/injection/order-approval/widget.client.tsx +0 -446
  710. package/src/modules/workflows/widgets/injection/order-approval/widget.ts +0 -16
  711. package/src/modules/workflows/widgets/injection-table.ts +0 -21
@@ -0,0 +1,174 @@
1
+ "use client"
2
+ import * as React from 'react'
3
+ import { useRouter } from 'next/navigation'
4
+ import { z } from 'zod'
5
+ import { Save } from 'lucide-react'
6
+ import { Page, PageBody } from '@open-mercato/ui/backend/Page'
7
+ import { CrudForm, type CrudField } from '@open-mercato/ui/backend/CrudForm'
8
+ import { apiCall, readApiResultOrThrow } from '@open-mercato/ui/backend/utils/apiCall'
9
+ import { createCrudFormError } from '@open-mercato/ui/backend/utils/serverErrors'
10
+ import { flash } from '@open-mercato/ui/backend/FlashMessages'
11
+ import { LoadingMessage, ErrorMessage } from '@open-mercato/ui/backend/detail'
12
+ import { Button } from '@open-mercato/ui/primitives/button'
13
+ import { useT } from '@open-mercato/shared/lib/i18n/context'
14
+ import { buildPasswordSchema, formatPasswordRequirements, getPasswordPolicy } from '@open-mercato/shared/lib/auth/passwordPolicy'
15
+
16
+ type ProfileResponse = {
17
+ email?: string | null
18
+ }
19
+
20
+ type ProfileUpdateResponse = {
21
+ ok?: boolean
22
+ email?: string | null
23
+ }
24
+
25
+ type ProfileFormValues = {
26
+ email: string
27
+ password?: string
28
+ confirmPassword?: string
29
+ }
30
+
31
+ export default function AuthProfilePage() {
32
+ const t = useT()
33
+ const router = useRouter()
34
+ const [loading, setLoading] = React.useState(true)
35
+ const [error, setError] = React.useState<string | null>(null)
36
+ const [email, setEmail] = React.useState('')
37
+ const [formKey, setFormKey] = React.useState(0)
38
+ const formId = React.useId()
39
+ const passwordPolicy = React.useMemo(() => getPasswordPolicy(), [])
40
+ const passwordRequirements = React.useMemo(
41
+ () => formatPasswordRequirements(passwordPolicy, t),
42
+ [passwordPolicy, t],
43
+ )
44
+ const passwordDescription = React.useMemo(() => (
45
+ passwordRequirements
46
+ ? t('auth.password.requirements.help', 'Password requirements: {requirements}', { requirements: passwordRequirements })
47
+ : undefined
48
+ ), [passwordRequirements, t])
49
+
50
+ React.useEffect(() => {
51
+ let cancelled = false
52
+ async function load() {
53
+ setLoading(true)
54
+ setError(null)
55
+ try {
56
+ const { ok, result } = await apiCall<ProfileResponse>('/api/auth/profile')
57
+ if (!ok) throw new Error('load_failed')
58
+ const resolvedEmail = typeof result?.email === 'string' ? result.email : ''
59
+ if (!cancelled) setEmail(resolvedEmail)
60
+ } catch (err) {
61
+ console.error('Failed to load auth profile', err)
62
+ if (!cancelled) setError(t('auth.profile.form.errors.load', 'Failed to load profile.'))
63
+ } finally {
64
+ if (!cancelled) setLoading(false)
65
+ }
66
+ }
67
+ load()
68
+ return () => { cancelled = true }
69
+ }, [t])
70
+
71
+ const fields = React.useMemo<CrudField[]>(() => [
72
+ { id: 'email', label: t('auth.profile.form.email', 'Email'), type: 'text', required: true },
73
+ {
74
+ id: 'password',
75
+ label: t('auth.profile.form.password', 'New password'),
76
+ type: 'text',
77
+ description: passwordDescription,
78
+ },
79
+ { id: 'confirmPassword', label: t('auth.profile.form.confirmPassword', 'Confirm new password'), type: 'text' },
80
+ ], [passwordDescription, t])
81
+
82
+ const schema = React.useMemo(() => {
83
+ const passwordSchema = buildPasswordSchema({
84
+ policy: passwordPolicy,
85
+ message: t('auth.profile.form.errors.passwordRequirements', 'Password must meet the requirements.'),
86
+ })
87
+ const optionalPasswordSchema = z.union([z.literal(''), passwordSchema]).optional()
88
+ return z.object({
89
+ email: z.string().trim().min(1, t('auth.profile.form.errors.emailRequired', 'Email is required.')),
90
+ password: optionalPasswordSchema,
91
+ confirmPassword: z.string().optional(),
92
+ }).superRefine((values, ctx) => {
93
+ const password = values.password?.trim() ?? ''
94
+ const confirmPassword = values.confirmPassword?.trim() ?? ''
95
+ if ((password || confirmPassword) && password !== confirmPassword) {
96
+ ctx.addIssue({
97
+ code: z.ZodIssueCode.custom,
98
+ message: t('auth.profile.form.errors.passwordMismatch', 'Passwords do not match.'),
99
+ path: ['confirmPassword'],
100
+ })
101
+ }
102
+ })
103
+ }, [passwordPolicy, t])
104
+
105
+ const handleSubmit = React.useCallback(async (values: ProfileFormValues) => {
106
+ const nextEmail = values.email?.trim() ?? ''
107
+ const password = values.password?.trim() ?? ''
108
+
109
+ if (!password && nextEmail === email) {
110
+ throw createCrudFormError(t('auth.profile.form.errors.noChanges', 'No changes to save.'))
111
+ }
112
+
113
+ const payload: { email: string; password?: string } = { email: nextEmail }
114
+ if (password) payload.password = password
115
+
116
+ const result = await readApiResultOrThrow<ProfileUpdateResponse>(
117
+ '/api/auth/profile',
118
+ {
119
+ method: 'PUT',
120
+ headers: { 'content-type': 'application/json' },
121
+ body: JSON.stringify(payload),
122
+ },
123
+ { errorMessage: t('auth.profile.form.errors.save', 'Failed to update profile.') },
124
+ )
125
+
126
+ const resolvedEmail = typeof result?.email === 'string' ? result.email : nextEmail
127
+ setEmail(resolvedEmail)
128
+ setFormKey((prev) => prev + 1)
129
+ flash(t('auth.profile.form.success', 'Profile updated.'), 'success')
130
+ router.refresh()
131
+ }, [email, router, t])
132
+
133
+ return (
134
+ <Page>
135
+ <PageBody>
136
+ {loading ? (
137
+ <LoadingMessage label={t('auth.profile.form.loading', 'Loading profile...')} />
138
+ ) : error ? (
139
+ <ErrorMessage label={error} />
140
+ ) : (
141
+ <section className="space-y-6 rounded-lg border bg-background p-6">
142
+ <header className="flex flex-col gap-4 sm:flex-row sm:items-start sm:justify-between">
143
+ <div className="space-y-1">
144
+ <h2 className="text-lg font-semibold">{t('auth.profile.title', 'Profile')}</h2>
145
+ <p className="text-sm text-muted-foreground">
146
+ {t('auth.profile.subtitle', 'Change password')}
147
+ </p>
148
+ </div>
149
+ <Button type="submit" form={formId}>
150
+ <Save className="size-4 mr-2" />
151
+ {t('auth.profile.form.save', 'Save changes')}
152
+ </Button>
153
+ </header>
154
+ <CrudForm<ProfileFormValues>
155
+ key={formKey}
156
+ formId={formId}
157
+ schema={schema}
158
+ fields={fields}
159
+ initialValues={{
160
+ email,
161
+ password: '',
162
+ confirmPassword: '',
163
+ }}
164
+ submitLabel={t('auth.profile.form.save', 'Save changes')}
165
+ onSubmit={handleSubmit}
166
+ embedded
167
+ hideFooterActions
168
+ />
169
+ </section>
170
+ )}
171
+ </PageBody>
172
+ </Page>
173
+ )
174
+ }
@@ -6,7 +6,7 @@ import { apiCall } from '@open-mercato/ui/backend/utils/apiCall'
6
6
  import { deleteCrud, updateCrud } from '@open-mercato/ui/backend/utils/crud'
7
7
  import { collectCustomFieldValues } from '@open-mercato/ui/backend/utils/customFieldValues'
8
8
  import { AclEditor, type AclData } from '@open-mercato/core/modules/auth/components/AclEditor'
9
- import { WidgetVisibilityEditor } from '@open-mercato/core/modules/dashboards/components/WidgetVisibilityEditor'
9
+ import { WidgetVisibilityEditor, type WidgetVisibilityEditorHandle } from '@open-mercato/core/modules/dashboards/components/WidgetVisibilityEditor'
10
10
  import { E } from '#generated/entities.ids.generated'
11
11
  import { TenantSelect } from '@open-mercato/core/modules/directory/components/TenantSelect'
12
12
  import { useT } from '@open-mercato/shared/lib/i18n/context'
@@ -37,6 +37,7 @@ export default function EditRolePage({ params }: { params?: { id?: string } }) {
37
37
  const [aclData, setAclData] = React.useState<AclData>({ isSuperAdmin: false, features: [], organizations: null })
38
38
  const [actorIsSuperAdmin, setActorIsSuperAdmin] = React.useState(false)
39
39
  const [selectedTenantId, setSelectedTenantId] = React.useState<string | null>(null)
40
+ const widgetEditorRef = React.useRef<WidgetVisibilityEditorHandle | null>(null)
40
41
 
41
42
  React.useEffect(() => {
42
43
  if (!id) return
@@ -153,6 +154,7 @@ export default function EditRolePage({ params }: { params?: { id?: string } }) {
153
154
  kind="role"
154
155
  targetId={String(id)}
155
156
  tenantId={selectedTenantId ?? (initial?.tenantId ?? null)}
157
+ ref={widgetEditorRef}
156
158
  />
157
159
  )
158
160
  : null),
@@ -191,6 +193,7 @@ export default function EditRolePage({ params }: { params?: { id?: string } }) {
191
193
  await updateCrud('auth/roles/acl', { roleId: id, tenantId: effectiveTenantId, ...aclData }, {
192
194
  errorMessage: t('auth.roles.form.errors.aclUpdate', 'Failed to update role access control'),
193
195
  })
196
+ await widgetEditorRef.current?.save()
194
197
  try { window.dispatchEvent(new Event('om:refresh-sidebar')) } catch {}
195
198
  }}
196
199
  onDelete={async () => {
@@ -117,9 +117,9 @@ export default function RolesListPage() {
117
117
  onSearchChange={(v) => { setSearch(v); setPage(1) }}
118
118
  rowActions={(row) => (
119
119
  <RowActions items={[
120
- { label: t('common.edit', 'Edit'), href: `/backend/roles/${row.id}/edit` },
121
- { label: t('auth.roles.list.actions.showUsers', 'Show users'), href: `/backend/users?roleId=${encodeURIComponent(row.id)}` },
122
- { label: t('common.delete', 'Delete'), destructive: true, onSelect: () => { void handleDelete(row) } },
120
+ { id: 'edit', label: t('common.edit', 'Edit'), href: `/backend/roles/${row.id}/edit` },
121
+ { id: 'show-users', label: t('auth.roles.list.actions.showUsers', 'Show users'), href: `/backend/users?roleId=${encodeURIComponent(row.id)}` },
122
+ { id: 'delete', label: t('common.delete', 'Delete'), destructive: true, onSelect: () => { void handleDelete(row) } },
123
123
  ]} />
124
124
  )}
125
125
  sortable
@@ -10,8 +10,9 @@ import { AclEditor, type AclData } from '@open-mercato/core/modules/auth/compone
10
10
  import { OrganizationSelect } from '@open-mercato/core/modules/directory/components/OrganizationSelect'
11
11
  import { TenantSelect } from '@open-mercato/core/modules/directory/components/TenantSelect'
12
12
  import { fetchRoleOptions } from '@open-mercato/core/modules/auth/backend/users/roleOptions'
13
- import { WidgetVisibilityEditor } from '@open-mercato/core/modules/dashboards/components/WidgetVisibilityEditor'
13
+ import { WidgetVisibilityEditor, type WidgetVisibilityEditorHandle } from '@open-mercato/core/modules/dashboards/components/WidgetVisibilityEditor'
14
14
  import { useT } from '@open-mercato/shared/lib/i18n/context'
15
+ import { formatPasswordRequirements, getPasswordPolicy } from '@open-mercato/shared/lib/auth/passwordPolicy'
15
16
 
16
17
  type EditUserFormValues = {
17
18
  email: string
@@ -108,6 +109,17 @@ export default function EditUserPage({ params }: { params?: { id?: string } }) {
108
109
  const [aclData, setAclData] = React.useState<AclData>({ isSuperAdmin: false, features: [], organizations: null })
109
110
  const [customFieldValues, setCustomFieldValues] = React.useState<Record<string, unknown>>({})
110
111
  const [actorIsSuperAdmin, setActorIsSuperAdmin] = React.useState(false)
112
+ const widgetEditorRef = React.useRef<WidgetVisibilityEditorHandle | null>(null)
113
+ const passwordPolicy = React.useMemo(() => getPasswordPolicy(), [])
114
+ const passwordRequirements = React.useMemo(
115
+ () => formatPasswordRequirements(passwordPolicy, t),
116
+ [passwordPolicy, t],
117
+ )
118
+ const passwordDescription = React.useMemo(() => (
119
+ passwordRequirements
120
+ ? t('auth.password.requirements.help', 'Password requirements: {requirements}', { requirements: passwordRequirements })
121
+ : undefined
122
+ ), [passwordRequirements, t])
111
123
 
112
124
  React.useEffect(() => {
113
125
  if (!id) {
@@ -201,7 +213,12 @@ export default function EditUserPage({ params }: { params?: { id?: string } }) {
201
213
  const fields: CrudField[] = React.useMemo(() => {
202
214
  const items: CrudField[] = [
203
215
  { id: 'email', label: t('auth.users.form.field.email', 'Email'), type: 'text', required: true },
204
- { id: 'password', label: t('auth.users.form.field.password', 'Password'), type: 'text' },
216
+ {
217
+ id: 'password',
218
+ label: t('auth.users.form.field.password', 'Password'),
219
+ type: 'text',
220
+ description: passwordDescription,
221
+ },
205
222
  ]
206
223
  if (actorIsSuperAdmin) {
207
224
  items.push({
@@ -251,7 +268,7 @@ export default function EditUserPage({ params }: { params?: { id?: string } }) {
251
268
  })
252
269
  items.push({ id: 'roles', label: t('auth.users.form.field.roles', 'Roles'), type: 'tags', loadOptions: loadRoleOptions })
253
270
  return items
254
- }, [actorIsSuperAdmin, loadRoleOptions, preloadedTenants, selectedOrgId, selectedTenantId, t])
271
+ }, [actorIsSuperAdmin, loadRoleOptions, passwordDescription, preloadedTenants, selectedOrgId, selectedTenantId, t])
255
272
 
256
273
  const detailFieldIds = React.useMemo(() => {
257
274
  const base: string[] = ['email', 'password', 'organizationId', 'roles']
@@ -292,6 +309,7 @@ export default function EditUserPage({ params }: { params?: { id?: string } }) {
292
309
  targetId={String(id)}
293
310
  tenantId={selectedTenantId ?? null}
294
311
  organizationId={initialUser?.organizationId ?? null}
312
+ ref={widgetEditorRef}
295
313
  />
296
314
  ) : null
297
315
  ),
@@ -354,6 +372,7 @@ export default function EditUserPage({ params }: { params?: { id?: string } }) {
354
372
  await updateCrud('auth/users/acl', { userId: id, ...aclData }, {
355
373
  errorMessage: t('auth.users.form.errors.aclUpdate', 'Failed to update user access control'),
356
374
  })
375
+ await widgetEditorRef.current?.save()
357
376
  try { window.dispatchEvent(new Event('om:refresh-sidebar')) } catch {}
358
377
  }}
359
378
  onDelete={async () => {
@@ -11,6 +11,7 @@ import { TenantSelect } from '@open-mercato/core/modules/directory/components/Te
11
11
  import { fetchRoleOptions } from '@open-mercato/core/modules/auth/backend/users/roleOptions'
12
12
  import { Spinner } from '@open-mercato/ui/primitives/spinner'
13
13
  import { useT } from '@open-mercato/shared/lib/i18n/context'
14
+ import { formatPasswordRequirements, getPasswordPolicy } from '@open-mercato/shared/lib/auth/passwordPolicy'
14
15
 
15
16
  type CreateUserFormValues = {
16
17
  email: string
@@ -84,6 +85,16 @@ export default function CreateUserPage() {
84
85
  const [selectedWidgets, setSelectedWidgets] = React.useState<string[]>([])
85
86
  const [selectedTenantId, setSelectedTenantId] = React.useState<string | null>(null)
86
87
  const [actorIsSuperAdmin, setActorIsSuperAdmin] = React.useState(false)
88
+ const passwordPolicy = React.useMemo(() => getPasswordPolicy(), [])
89
+ const passwordRequirements = React.useMemo(
90
+ () => formatPasswordRequirements(passwordPolicy, t),
91
+ [passwordPolicy, t],
92
+ )
93
+ const passwordDescription = React.useMemo(() => (
94
+ passwordRequirements
95
+ ? t('auth.password.requirements.help', 'Password requirements: {requirements}', { requirements: passwordRequirements })
96
+ : undefined
97
+ ), [passwordRequirements, t])
87
98
 
88
99
  React.useEffect(() => {
89
100
  let cancelled = false
@@ -156,7 +167,13 @@ export default function CreateUserPage() {
156
167
  const fields: CrudField[] = React.useMemo(() => {
157
168
  const items: CrudField[] = [
158
169
  { id: 'email', label: t('auth.users.form.field.email', 'Email'), type: 'text', required: true },
159
- { id: 'password', label: t('auth.users.form.field.password', 'Password'), type: 'text', required: true },
170
+ {
171
+ id: 'password',
172
+ label: t('auth.users.form.field.password', 'Password'),
173
+ type: 'text',
174
+ required: true,
175
+ description: passwordDescription,
176
+ },
160
177
  ]
161
178
  if (actorIsSuperAdmin) {
162
179
  items.push({
@@ -203,7 +220,7 @@ export default function CreateUserPage() {
203
220
  })
204
221
  items.push({ id: 'roles', label: t('auth.users.form.field.roles', 'Roles'), type: 'tags', loadOptions: loadRoleOptions })
205
222
  return items
206
- }, [actorIsSuperAdmin, loadRoleOptions, selectedTenantId, t])
223
+ }, [actorIsSuperAdmin, loadRoleOptions, passwordDescription, selectedTenantId, t])
207
224
 
208
225
  const detailFieldIds = React.useMemo(() => {
209
226
  const base: string[] = ['email', 'password', 'organizationId', 'roles']
@@ -383,9 +383,9 @@ export default function UsersListPage() {
383
383
  perspective={{ tableId: 'auth.users.list' }}
384
384
  rowActions={(row) => (
385
385
  <RowActions items={[
386
- { label: t('common.edit', 'Edit'), href: `/backend/users/${row.id}/edit` },
387
- { label: t('auth.users.list.actions.showRoles', 'Show roles'), href: `/backend/roles?userId=${encodeURIComponent(row.id)}` },
388
- { label: t('common.delete', 'Delete'), destructive: true, onSelect: () => { void handleDelete(row) } },
386
+ { id: 'edit', label: t('common.edit', 'Edit'), href: `/backend/users/${row.id}/edit` },
387
+ { id: 'show-roles', label: t('auth.users.list.actions.showRoles', 'Show roles'), href: `/backend/roles?userId=${encodeURIComponent(row.id)}` },
388
+ { id: 'delete', label: t('common.delete', 'Delete'), destructive: true, onSelect: () => { void handleDelete(row) } },
389
389
  ]} />
390
390
  )}
391
391
  pagination={{ page, pageSize: 50, total, totalPages, onPageChange: setPage }}
@@ -16,6 +16,8 @@ import { decryptWithAesGcm } from '@open-mercato/shared/lib/encryption/aes'
16
16
  import { env } from 'process'
17
17
  import type { KmsService, TenantDek } from '@open-mercato/shared/lib/encryption/kms'
18
18
  import crypto from 'node:crypto'
19
+ import { formatPasswordRequirements, getPasswordPolicy, validatePassword } from '@open-mercato/shared/lib/auth/passwordPolicy'
20
+ import { parseBooleanToken } from '@open-mercato/shared/lib/boolean'
19
21
 
20
22
  const addUser: ModuleCli = {
21
23
  command: 'add-user',
@@ -34,6 +36,7 @@ const addUser: ModuleCli = {
34
36
  console.error('Usage: mercato auth add-user --email <email> --password <password> --organizationId <id> [--roles customer,employee]')
35
37
  return
36
38
  }
39
+ if (!ensurePasswordPolicy(password)) return
37
40
  const { resolve } = await createRequestContainer()
38
41
  const em = resolve('em') as any
39
42
  const org =
@@ -102,6 +105,16 @@ function hashSecret(value: string | null | undefined): string | null {
102
105
  return crypto.createHash('sha256').update(normalizeKeyInput(value)).digest('hex').slice(0, 12)
103
106
  }
104
107
 
108
+ function ensurePasswordPolicy(password: string): boolean {
109
+ const policy = getPasswordPolicy()
110
+ const result = validatePassword(password, policy)
111
+ if (result.ok) return true
112
+ const requirements = formatPasswordRequirements(policy, (_key, fallback) => fallback)
113
+ const suffix = requirements ? `: ${requirements}` : ''
114
+ console.error(`Password does not meet the requirements${suffix}.`)
115
+ return false
116
+ }
117
+
105
118
  async function withEncryptionDebugDisabled<T>(fn: () => Promise<T>): Promise<T> {
106
119
  const previous = process.env.TENANT_DATA_ENCRYPTION_DEBUG
107
120
  process.env.TENANT_DATA_ENCRYPTION_DEBUG = 'no'
@@ -392,20 +405,33 @@ const addOrganization: ModuleCli = {
392
405
  const setupApp: ModuleCli = {
393
406
  command: 'setup',
394
407
  async run(rest) {
395
- const args: Record<string, string> = {}
396
- for (let i = 0; i < rest.length; i += 2) {
397
- const k = rest[i]?.replace(/^--/, '')
398
- const v = rest[i + 1]
399
- if (k) args[k] = v
400
- }
401
- const orgName = args.orgName || args.name
402
- const email = args.email
403
- const password = args.password
404
- const rolesCsv = (args.roles ?? 'superadmin,admin,employee').trim()
408
+ const args = parseArgs(rest)
409
+ const orgName = typeof args.orgName === 'string'
410
+ ? args.orgName
411
+ : typeof args.name === 'string'
412
+ ? args.name
413
+ : undefined
414
+ const email = typeof args.email === 'string' ? args.email : undefined
415
+ const password = typeof args.password === 'string' ? args.password : undefined
416
+ const rolesCsv = typeof args.roles === 'string'
417
+ ? args.roles.trim()
418
+ : 'superadmin,admin,employee'
419
+ const skipPasswordPolicyRaw =
420
+ args['skip-password-policy'] ??
421
+ args.skipPasswordPolicy ??
422
+ args['allow-weak-password'] ??
423
+ args.allowWeakPassword
424
+ const skipPasswordPolicy = typeof skipPasswordPolicyRaw === 'boolean'
425
+ ? skipPasswordPolicyRaw
426
+ : parseBooleanToken(typeof skipPasswordPolicyRaw === 'string' ? skipPasswordPolicyRaw : null) ?? false
405
427
  if (!orgName || !email || !password) {
406
- console.error('Usage: mercato auth setup --orgName <name> --email <email> --password <password> [--roles superadmin,admin,employee]')
428
+ console.error('Usage: mercato auth setup --orgName <name> --email <email> --password <password> [--roles superadmin,admin,employee] [--skip-password-policy]')
407
429
  return
408
430
  }
431
+ if (!skipPasswordPolicy && !ensurePasswordPolicy(password)) return
432
+ if (skipPasswordPolicy) {
433
+ console.warn('⚠️ Password policy validation skipped for setup.')
434
+ }
409
435
  const { resolve } = await createRequestContainer()
410
436
  const em = resolve<EntityManager>('em')
411
437
  const roleNames = rolesCsv
@@ -595,6 +621,7 @@ const setPassword: ModuleCli = {
595
621
  console.error('Usage: mercato auth set-password --email <email> --password <newPassword>')
596
622
  return
597
623
  }
624
+ if (!ensurePasswordPolicy(password)) return
598
625
 
599
626
  const { resolve } = await createRequestContainer()
600
627
  const em = resolve('em') as any
@@ -27,6 +27,10 @@ import {
27
27
  import { normalizeTenantId } from '@open-mercato/core/modules/auth/lib/tenantAccess'
28
28
  import { computeEmailHash } from '@open-mercato/core/modules/auth/lib/emailHash'
29
29
  import { findOneWithDecryption, findWithDecryption } from '@open-mercato/shared/lib/encryption/find'
30
+ import { buildNotificationFromType } from '@open-mercato/core/modules/notifications/lib/notificationBuilder'
31
+ import { resolveNotificationService } from '@open-mercato/core/modules/notifications/lib/notificationService'
32
+ import notificationTypes from '@open-mercato/core/modules/auth/notifications'
33
+ import { buildPasswordSchema } from '@open-mercato/shared/lib/auth/passwordPolicy'
30
34
 
31
35
  type SerializedUser = {
32
36
  email: string
@@ -63,9 +67,11 @@ type UserSnapshots = {
63
67
  undo: UserUndoSnapshot
64
68
  }
65
69
 
70
+ const passwordSchema = buildPasswordSchema()
71
+
66
72
  const createSchema = z.object({
67
73
  email: z.string().email(),
68
- password: z.string().min(6),
74
+ password: passwordSchema,
69
75
  organizationId: z.string().uuid(),
70
76
  roles: z.array(z.string()).optional(),
71
77
  })
@@ -73,7 +79,7 @@ const createSchema = z.object({
73
79
  const updateSchema = z.object({
74
80
  id: z.string().uuid(),
75
81
  email: z.string().email().optional(),
76
- password: z.string().min(6).optional(),
82
+ password: passwordSchema.optional(),
77
83
  organizationId: z.string().uuid().optional(),
78
84
  roles: z.array(z.string()).optional(),
79
85
  })
@@ -105,6 +111,46 @@ export const userCrudIndexer: CrudIndexerConfig = {
105
111
  }),
106
112
  }
107
113
 
114
+ async function notifyRoleChanges(
115
+ ctx: CommandRuntimeContext,
116
+ user: User,
117
+ assignedRoles: string[],
118
+ revokedRoles: string[],
119
+ ): Promise<void> {
120
+ const tenantId = user.tenantId ? String(user.tenantId) : null
121
+ if (!tenantId) return
122
+ const organizationId = user.organizationId ? String(user.organizationId) : null
123
+
124
+ try {
125
+ const notificationService = resolveNotificationService(ctx.container)
126
+ if (assignedRoles.length) {
127
+ const assignedType = notificationTypes.find((type) => type.type === 'auth.role.assigned')
128
+ if (assignedType) {
129
+ const notificationInput = buildNotificationFromType(assignedType, {
130
+ recipientUserId: String(user.id),
131
+ sourceEntityType: 'auth:user',
132
+ sourceEntityId: String(user.id),
133
+ })
134
+ await notificationService.create(notificationInput, { tenantId, organizationId })
135
+ }
136
+ }
137
+
138
+ if (revokedRoles.length) {
139
+ const revokedType = notificationTypes.find((type) => type.type === 'auth.role.revoked')
140
+ if (revokedType) {
141
+ const notificationInput = buildNotificationFromType(revokedType, {
142
+ recipientUserId: String(user.id),
143
+ sourceEntityType: 'auth:user',
144
+ sourceEntityId: String(user.id),
145
+ })
146
+ await notificationService.create(notificationInput, { tenantId, organizationId })
147
+ }
148
+ }
149
+ } catch (err) {
150
+ console.error('[auth.users.roles] Failed to create notification:', err)
151
+ }
152
+ }
153
+
108
154
  const createUserCommand: CommandHandler<Record<string, unknown>, User> = {
109
155
  id: 'auth.users.create',
110
156
  async execute(rawInput, ctx) {
@@ -147,8 +193,10 @@ const createUserCommand: CommandHandler<Record<string, unknown>, User> = {
147
193
  throw error
148
194
  }
149
195
 
196
+ let assignedRoles: string[] = []
150
197
  if (Array.isArray(parsed.roles) && parsed.roles.length) {
151
198
  await syncUserRoles(em, user, parsed.roles, tenantId)
199
+ assignedRoles = await loadUserRoleNames(em, String(user.id))
152
200
  }
153
201
 
154
202
  await setCustomFieldsIfAny({
@@ -173,6 +221,10 @@ const createUserCommand: CommandHandler<Record<string, unknown>, User> = {
173
221
  indexer: userCrudIndexer,
174
222
  })
175
223
 
224
+ if (assignedRoles.length) {
225
+ await notifyRoleChanges(ctx, user, assignedRoles, [])
226
+ }
227
+
176
228
  return user
177
229
  },
178
230
  captureAfter: async (_input, result, ctx) => {
@@ -288,6 +340,9 @@ const updateUserCommand: CommandHandler<Record<string, unknown>, User> = {
288
340
  async execute(rawInput, ctx) {
289
341
  const { parsed, custom } = parseWithCustomFields(updateSchema, rawInput)
290
342
  const em = (ctx.container.resolve('em') as EntityManager)
343
+ const rolesBefore = Array.isArray(parsed.roles)
344
+ ? await loadUserRoleNames(em, parsed.id)
345
+ : null
291
346
 
292
347
  if (parsed.email !== undefined) {
293
348
  const emailHash = computeEmailHash(parsed.email)
@@ -377,6 +432,14 @@ const updateUserCommand: CommandHandler<Record<string, unknown>, User> = {
377
432
  indexer: userCrudIndexer,
378
433
  })
379
434
 
435
+ if (Array.isArray(parsed.roles) && rolesBefore) {
436
+ const rolesAfter = await loadUserRoleNames(em, String(user.id))
437
+ const { assigned, revoked } = diffRoleChanges(rolesBefore, rolesAfter)
438
+ if (assigned.length || revoked.length) {
439
+ await notifyRoleChanges(ctx, user, assigned, revoked)
440
+ }
441
+ }
442
+
380
443
  await invalidateUserCache(ctx, parsed.id)
381
444
 
382
445
  return user
@@ -772,6 +835,14 @@ async function invalidateUserCache(ctx: CommandRuntimeContext, userId: string) {
772
835
  }
773
836
  }
774
837
 
838
+ function diffRoleChanges(before: string[], after: string[]) {
839
+ const beforeSet = new Set(before)
840
+ const afterSet = new Set(after)
841
+ const assigned = after.filter((role) => !beforeSet.has(role))
842
+ const revoked = before.filter((role) => !afterSet.has(role))
843
+ return { assigned, revoked }
844
+ }
845
+
775
846
  function arrayEquals(left: string[] | undefined, right: string[]): boolean {
776
847
  if (!left) return false
777
848
  if (left.length !== right.length) return false
@@ -1,10 +1,14 @@
1
1
  import { z } from 'zod'
2
+ import { buildPasswordSchema } from '@open-mercato/shared/lib/auth/passwordPolicy'
3
+
4
+ const passwordSchema = buildPasswordSchema()
2
5
 
3
6
  // Core auth validators
4
7
  export const userLoginSchema = z.object({
5
8
  email: z.string().email(),
6
9
  password: z.string().min(6),
7
10
  requireRole: z.string().optional(),
11
+ tenantId: z.string().uuid().optional(),
8
12
  })
9
13
 
10
14
  export const requestPasswordResetSchema = z.object({
@@ -13,7 +17,7 @@ export const requestPasswordResetSchema = z.object({
13
17
 
14
18
  export const confirmPasswordResetSchema = z.object({
15
19
  token: z.string().min(10),
16
- password: z.string().min(6),
20
+ password: passwordSchema,
17
21
  })
18
22
 
19
23
  export const sidebarPreferencesInputSchema = z.object({
@@ -29,7 +33,7 @@ export const sidebarPreferencesInputSchema = z.object({
29
33
  // Optional helpers for CLI or admin forms
30
34
  export const userCreateSchema = z.object({
31
35
  email: z.string().email(),
32
- password: z.string().min(6),
36
+ password: passwordSchema,
33
37
  tenantId: z.string().uuid().optional(),
34
38
  organizationId: z.string().uuid(),
35
39
  rolesCsv: z.string().optional(),