@open-mercato/core 0.4.2-canary-f821f89ef6 → 0.4.2-canary-3b5064ce72
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/generated/entities/notification/index.js +57 -0
- package/dist/generated/entities/notification/index.js.map +7 -0
- package/dist/generated/entities.ids.generated.js +5 -2
- package/dist/generated/entities.ids.generated.js.map +2 -2
- package/dist/generated/entity-fields-registry.js +2 -2
- package/dist/generated/entity-fields-registry.js.map +2 -2
- package/dist/modules/api_docs/frontend/docs/api/page.js +3 -2
- package/dist/modules/api_docs/frontend/docs/api/page.js.map +2 -2
- package/dist/modules/api_keys/backend/api-keys/page.js +1 -1
- package/dist/modules/api_keys/backend/api-keys/page.js.map +2 -2
- package/dist/modules/attachments/components/AttachmentLibrary.js +4 -0
- package/dist/modules/attachments/components/AttachmentLibrary.js.map +2 -2
- package/dist/modules/attachments/components/AttachmentPartitionSettings.js +2 -0
- package/dist/modules/attachments/components/AttachmentPartitionSettings.js.map +2 -2
- package/dist/modules/auth/api/admin/nav.js +4 -3
- package/dist/modules/auth/api/admin/nav.js.map +2 -2
- package/dist/modules/auth/api/login.js +25 -6
- package/dist/modules/auth/api/login.js.map +2 -2
- package/dist/modules/auth/api/profile/route.js +157 -0
- package/dist/modules/auth/api/profile/route.js.map +7 -0
- package/dist/modules/auth/api/reset/confirm.js +25 -2
- package/dist/modules/auth/api/reset/confirm.js.map +2 -2
- package/dist/modules/auth/api/reset.js +23 -0
- package/dist/modules/auth/api/reset.js.map +2 -2
- package/dist/modules/auth/api/sidebar/preferences/route.js +14 -9
- package/dist/modules/auth/api/sidebar/preferences/route.js.map +2 -2
- package/dist/modules/auth/api/users/route.js +4 -2
- package/dist/modules/auth/api/users/route.js.map +2 -2
- package/dist/modules/auth/backend/auth/profile/page.js +141 -0
- package/dist/modules/auth/backend/auth/profile/page.js.map +7 -0
- package/dist/modules/auth/backend/auth/profile/page.meta.js +13 -0
- package/dist/modules/auth/backend/auth/profile/page.meta.js.map +7 -0
- package/dist/modules/auth/backend/roles/[id]/edit/page.js +4 -1
- package/dist/modules/auth/backend/roles/[id]/edit/page.js.map +2 -2
- package/dist/modules/auth/backend/roles/page.js +3 -3
- package/dist/modules/auth/backend/roles/page.js.map +2 -2
- package/dist/modules/auth/backend/users/[id]/edit/page.js +18 -3
- package/dist/modules/auth/backend/users/[id]/edit/page.js.map +2 -2
- package/dist/modules/auth/backend/users/create/page.js +15 -2
- package/dist/modules/auth/backend/users/create/page.js.map +2 -2
- package/dist/modules/auth/backend/users/page.js +3 -3
- package/dist/modules/auth/backend/users/page.js.map +2 -2
- package/dist/modules/auth/cli.js +25 -11
- package/dist/modules/auth/cli.js.map +2 -2
- package/dist/modules/auth/commands/users.js +59 -2
- package/dist/modules/auth/commands/users.js.map +2 -2
- package/dist/modules/auth/data/validators.js +6 -3
- package/dist/modules/auth/data/validators.js.map +2 -2
- package/dist/modules/auth/frontend/login.js +112 -3
- package/dist/modules/auth/frontend/login.js.map +2 -2
- package/dist/modules/auth/frontend/reset/[token]/page.js +20 -10
- package/dist/modules/auth/frontend/reset/[token]/page.js.map +2 -2
- package/dist/modules/auth/lib/setup-app.js +42 -8
- package/dist/modules/auth/lib/setup-app.js.map +2 -2
- package/dist/modules/auth/notifications.js +112 -0
- package/dist/modules/auth/notifications.js.map +7 -0
- package/dist/modules/auth/services/authService.js +24 -3
- package/dist/modules/auth/services/authService.js.map +2 -2
- package/dist/modules/business_rules/api/execute/route.js +7 -1
- package/dist/modules/business_rules/api/execute/route.js.map +2 -2
- package/dist/modules/business_rules/backend/rules/page.js +4 -0
- package/dist/modules/business_rules/backend/rules/page.js.map +2 -2
- package/dist/modules/business_rules/backend/sets/page.js +3 -0
- package/dist/modules/business_rules/backend/sets/page.js.map +2 -2
- package/dist/modules/business_rules/cli.js +2 -1
- package/dist/modules/business_rules/cli.js.map +2 -2
- package/dist/modules/business_rules/data/validators.js +0 -34
- package/dist/modules/business_rules/data/validators.js.map +2 -2
- package/dist/modules/business_rules/index.js +1 -21
- package/dist/modules/business_rules/index.js.map +2 -2
- package/dist/modules/business_rules/lib/rule-engine.js +34 -185
- package/dist/modules/business_rules/lib/rule-engine.js.map +2 -2
- package/dist/modules/business_rules/notifications.js +28 -0
- package/dist/modules/business_rules/notifications.js.map +7 -0
- package/dist/modules/business_rules/subscribers/rule-execution-failed-notification.js +37 -0
- package/dist/modules/business_rules/subscribers/rule-execution-failed-notification.js.map +7 -0
- package/dist/modules/catalog/components/PriceKindSettings.js +2 -0
- package/dist/modules/catalog/components/PriceKindSettings.js.map +2 -2
- package/dist/modules/catalog/components/categories/CategoriesDataTable.js +2 -2
- package/dist/modules/catalog/components/categories/CategoriesDataTable.js.map +2 -2
- package/dist/modules/catalog/components/products/ProductsDataTable.js +2 -0
- package/dist/modules/catalog/components/products/ProductsDataTable.js.map +2 -2
- package/dist/modules/catalog/notifications.js +28 -0
- package/dist/modules/catalog/notifications.js.map +7 -0
- package/dist/modules/catalog/subscribers/low-stock-notification.js +38 -0
- package/dist/modules/catalog/subscribers/low-stock-notification.js.map +7 -0
- package/dist/modules/configs/cli.js +6 -0
- package/dist/modules/configs/cli.js.map +2 -2
- package/dist/modules/configs/components/CachePanel.js +4 -4
- package/dist/modules/configs/components/CachePanel.js.map +2 -2
- package/dist/modules/configs/lib/system-status.js +48 -1
- package/dist/modules/configs/lib/system-status.js.map +2 -2
- package/dist/modules/configs/lib/upgrade-actions.js +18 -0
- package/dist/modules/configs/lib/upgrade-actions.js.map +2 -2
- package/dist/modules/currencies/backend/currencies/page.js +3 -0
- package/dist/modules/currencies/backend/currencies/page.js.map +2 -2
- package/dist/modules/currencies/backend/exchange-rates/page.js +2 -0
- package/dist/modules/currencies/backend/exchange-rates/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/companies/page.js +3 -0
- package/dist/modules/customers/backend/customers/companies/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/deals/page.js +3 -0
- package/dist/modules/customers/backend/customers/deals/page.js.map +2 -2
- package/dist/modules/customers/backend/customers/people/page.js +3 -0
- package/dist/modules/customers/backend/customers/people/page.js.map +2 -2
- package/dist/modules/customers/commands/deals.js +31 -0
- package/dist/modules/customers/commands/deals.js.map +2 -2
- package/dist/modules/customers/components/CustomerTodosTable.js +1 -0
- package/dist/modules/customers/components/CustomerTodosTable.js.map +2 -2
- package/dist/modules/customers/notifications.js +48 -0
- package/dist/modules/customers/notifications.js.map +7 -0
- package/dist/modules/customers/widgets/dashboard/customer-todos/widget.js +2 -1
- package/dist/modules/customers/widgets/dashboard/customer-todos/widget.js.map +2 -2
- package/dist/modules/customers/widgets/dashboard/new-customers/widget.js +2 -1
- package/dist/modules/customers/widgets/dashboard/new-customers/widget.js.map +2 -2
- package/dist/modules/customers/widgets/dashboard/new-deals/widget.js +2 -1
- package/dist/modules/customers/widgets/dashboard/new-deals/widget.js.map +2 -2
- package/dist/modules/customers/widgets/dashboard/next-interactions/widget.js +2 -1
- package/dist/modules/customers/widgets/dashboard/next-interactions/widget.js.map +2 -2
- package/dist/modules/dashboards/cli.js +44 -5
- package/dist/modules/dashboards/cli.js.map +2 -2
- package/dist/modules/dashboards/components/WidgetVisibilityEditor.js +16 -11
- package/dist/modules/dashboards/components/WidgetVisibilityEditor.js.map +3 -3
- package/dist/modules/dashboards/lib/role-widgets.js +58 -0
- package/dist/modules/dashboards/lib/role-widgets.js.map +7 -0
- package/dist/modules/dashboards/services/widgetDataService.js +139 -3
- package/dist/modules/dashboards/services/widgetDataService.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/aov-kpi/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/aov-kpi/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/new-customers-kpi/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/new-customers-kpi/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/orders-by-status/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/orders-by-status/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/orders-kpi/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/orders-kpi/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/pipeline-summary/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/pipeline-summary/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/revenue-kpi/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/revenue-kpi/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/revenue-trend/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/revenue-trend/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/sales-by-region/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/sales-by-region/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/top-customers/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/top-customers/widget.js.map +2 -2
- package/dist/modules/dashboards/widgets/dashboard/top-products/widget.js +2 -1
- package/dist/modules/dashboards/widgets/dashboard/top-products/widget.js.map +2 -2
- package/dist/modules/dictionaries/components/DictionaryTable.js +2 -0
- package/dist/modules/dictionaries/components/DictionaryTable.js.map +2 -2
- package/dist/modules/directory/api/get/tenants/lookup.js +70 -0
- package/dist/modules/directory/api/get/tenants/lookup.js.map +7 -0
- package/dist/modules/directory/backend/directory/organizations/page.js +2 -2
- package/dist/modules/directory/backend/directory/organizations/page.js.map +2 -2
- package/dist/modules/directory/backend/directory/tenants/page.js +2 -2
- package/dist/modules/directory/backend/directory/tenants/page.js.map +2 -2
- package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js +2 -2
- package/dist/modules/entities/backend/entities/user/[entityId]/records/page.js.map +2 -2
- package/dist/modules/entities/components/SystemEntitiesTable.js +1 -1
- package/dist/modules/entities/components/SystemEntitiesTable.js.map +2 -2
- package/dist/modules/entities/components/UserEntitiesTable.js +2 -2
- package/dist/modules/entities/components/UserEntitiesTable.js.map +2 -2
- package/dist/modules/feature_toggles/components/FeatureTogglesTable.js +3 -3
- package/dist/modules/feature_toggles/components/FeatureTogglesTable.js.map +2 -2
- package/dist/modules/feature_toggles/components/OverridesTable.js +1 -1
- package/dist/modules/feature_toggles/components/OverridesTable.js.map +2 -2
- package/dist/modules/notifications/acl.js +11 -0
- package/dist/modules/notifications/acl.js.map +7 -0
- package/dist/modules/notifications/api/[id]/action/route.js +74 -0
- package/dist/modules/notifications/api/[id]/action/route.js.map +7 -0
- package/dist/modules/notifications/api/[id]/dismiss/route.js +15 -0
- package/dist/modules/notifications/api/[id]/dismiss/route.js.map +7 -0
- package/dist/modules/notifications/api/[id]/read/route.js +15 -0
- package/dist/modules/notifications/api/[id]/read/route.js.map +7 -0
- package/dist/modules/notifications/api/[id]/restore/route.js +53 -0
- package/dist/modules/notifications/api/[id]/restore/route.js.map +7 -0
- package/dist/modules/notifications/api/batch/route.js +17 -0
- package/dist/modules/notifications/api/batch/route.js.map +7 -0
- package/dist/modules/notifications/api/feature/route.js +17 -0
- package/dist/modules/notifications/api/feature/route.js.map +7 -0
- package/dist/modules/notifications/api/mark-all-read/route.js +35 -0
- package/dist/modules/notifications/api/mark-all-read/route.js.map +7 -0
- package/dist/modules/notifications/api/openapi.js +76 -0
- package/dist/modules/notifications/api/openapi.js.map +7 -0
- package/dist/modules/notifications/api/role/route.js +17 -0
- package/dist/modules/notifications/api/role/route.js.map +7 -0
- package/dist/modules/notifications/api/route.js +85 -0
- package/dist/modules/notifications/api/route.js.map +7 -0
- package/dist/modules/notifications/api/settings/route.js +155 -0
- package/dist/modules/notifications/api/settings/route.js.map +7 -0
- package/dist/modules/notifications/api/unread-count/route.js +38 -0
- package/dist/modules/notifications/api/unread-count/route.js.map +7 -0
- package/dist/modules/notifications/backend/config/notifications/page.js +10 -0
- package/dist/modules/notifications/backend/config/notifications/page.js.map +7 -0
- package/dist/modules/notifications/backend/config/notifications/page.meta.js +24 -0
- package/dist/modules/notifications/backend/config/notifications/page.meta.js.map +7 -0
- package/dist/modules/notifications/cli.js +16 -0
- package/dist/modules/notifications/cli.js.map +7 -0
- package/dist/modules/notifications/data/entities.js +112 -0
- package/dist/modules/notifications/data/entities.js.map +7 -0
- package/dist/modules/notifications/data/validators.js +98 -0
- package/dist/modules/notifications/data/validators.js.map +7 -0
- package/dist/modules/notifications/di.js +13 -0
- package/dist/modules/notifications/di.js.map +7 -0
- package/dist/modules/notifications/emails/NotificationEmail.js +58 -0
- package/dist/modules/notifications/emails/NotificationEmail.js.map +7 -0
- package/dist/modules/notifications/frontend/NotificationInboxPageClient.js +44 -0
- package/dist/modules/notifications/frontend/NotificationInboxPageClient.js.map +7 -0
- package/dist/modules/notifications/frontend/NotificationSettingsPageClient.js +220 -0
- package/dist/modules/notifications/frontend/NotificationSettingsPageClient.js.map +7 -0
- package/dist/modules/notifications/index.js +14 -0
- package/dist/modules/notifications/index.js.map +7 -0
- package/dist/modules/notifications/lib/deliveryConfig.js +107 -0
- package/dist/modules/notifications/lib/deliveryConfig.js.map +7 -0
- package/dist/modules/notifications/lib/deliveryStrategies.js +14 -0
- package/dist/modules/notifications/lib/deliveryStrategies.js.map +7 -0
- package/dist/modules/notifications/lib/events.js +12 -0
- package/dist/modules/notifications/lib/events.js.map +7 -0
- package/dist/modules/notifications/lib/notificationBuilder.js +66 -0
- package/dist/modules/notifications/lib/notificationBuilder.js.map +7 -0
- package/dist/modules/notifications/lib/notificationFactory.js +54 -0
- package/dist/modules/notifications/lib/notificationFactory.js.map +7 -0
- package/dist/modules/notifications/lib/notificationMapper.js +34 -0
- package/dist/modules/notifications/lib/notificationMapper.js.map +7 -0
- package/dist/modules/notifications/lib/notificationRecipients.js +35 -0
- package/dist/modules/notifications/lib/notificationRecipients.js.map +7 -0
- package/dist/modules/notifications/lib/notificationService.js +279 -0
- package/dist/modules/notifications/lib/notificationService.js.map +7 -0
- package/dist/modules/notifications/lib/routeHelpers.js +101 -0
- package/dist/modules/notifications/lib/routeHelpers.js.map +7 -0
- package/dist/modules/notifications/lib/safeHref.js +24 -0
- package/dist/modules/notifications/lib/safeHref.js.map +7 -0
- package/dist/modules/notifications/migrations/Migration20260123000001.js +70 -0
- package/dist/modules/notifications/migrations/Migration20260123000001.js.map +7 -0
- package/dist/modules/notifications/migrations/Migration20260126150000.js +37 -0
- package/dist/modules/notifications/migrations/Migration20260126150000.js.map +7 -0
- package/dist/modules/notifications/migrations/Migration20260129082610.js +13 -0
- package/dist/modules/notifications/migrations/Migration20260129082610.js.map +7 -0
- package/dist/modules/notifications/subscribers/deliver-notification.js +165 -0
- package/dist/modules/notifications/subscribers/deliver-notification.js.map +7 -0
- package/dist/modules/notifications/workers/create-notification.worker.js +70 -0
- package/dist/modules/notifications/workers/create-notification.worker.js.map +7 -0
- package/dist/modules/planner/backend/planner/availability-rulesets/page.js +2 -2
- package/dist/modules/planner/backend/planner/availability-rulesets/page.js.map +2 -2
- package/dist/modules/query_index/cli.js +63 -7
- package/dist/modules/query_index/cli.js.map +2 -2
- package/dist/modules/query_index/components/QueryIndexesTable.js +7 -1
- package/dist/modules/query_index/components/QueryIndexesTable.js.map +2 -2
- package/dist/modules/resources/backend/resources/resource-types/page.js +2 -2
- package/dist/modules/resources/backend/resources/resource-types/page.js.map +2 -2
- package/dist/modules/resources/backend/resources/resources/page.js +2 -2
- package/dist/modules/resources/backend/resources/resources/page.js.map +2 -2
- package/dist/modules/sales/acl.js +0 -1
- package/dist/modules/sales/acl.js.map +2 -2
- package/dist/modules/sales/backend/sales/channels/offers/page.js +2 -0
- package/dist/modules/sales/backend/sales/channels/offers/page.js.map +2 -2
- package/dist/modules/sales/backend/sales/channels/page.js +2 -0
- package/dist/modules/sales/backend/sales/channels/page.js.map +2 -2
- package/dist/modules/sales/backend/sales/documents/[id]/page.js +0 -12
- package/dist/modules/sales/backend/sales/documents/[id]/page.js.map +2 -2
- package/dist/modules/sales/commands/documents.js +53 -62
- package/dist/modules/sales/commands/documents.js.map +2 -2
- package/dist/modules/sales/commands/payments.js +26 -0
- package/dist/modules/sales/commands/payments.js.map +2 -2
- package/dist/modules/sales/components/AdjustmentKindSettings.js +2 -2
- package/dist/modules/sales/components/AdjustmentKindSettings.js.map +2 -2
- package/dist/modules/sales/components/PaymentMethodsSettings.js +2 -2
- package/dist/modules/sales/components/PaymentMethodsSettings.js.map +2 -2
- package/dist/modules/sales/components/ShippingMethodsSettings.js +2 -2
- package/dist/modules/sales/components/ShippingMethodsSettings.js.map +2 -2
- package/dist/modules/sales/components/TaxRatesSettings.js +2 -2
- package/dist/modules/sales/components/TaxRatesSettings.js.map +2 -2
- package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js +2 -0
- package/dist/modules/sales/components/channels/SalesChannelOffersPanel.js.map +2 -2
- package/dist/modules/sales/components/documents/AdjustmentsSection.js +2 -0
- package/dist/modules/sales/components/documents/AdjustmentsSection.js.map +2 -2
- package/dist/modules/sales/components/documents/PaymentsSection.js +2 -1
- package/dist/modules/sales/components/documents/PaymentsSection.js.map +2 -2
- package/dist/modules/sales/components/documents/SalesDocumentsTable.js +2 -0
- package/dist/modules/sales/components/documents/SalesDocumentsTable.js.map +2 -2
- package/dist/modules/sales/lib/dictionaries.js +0 -3
- package/dist/modules/sales/lib/dictionaries.js.map +2 -2
- package/dist/modules/sales/notifications.client.js +51 -0
- package/dist/modules/sales/notifications.client.js.map +7 -0
- package/dist/modules/sales/notifications.js +88 -0
- package/dist/modules/sales/notifications.js.map +7 -0
- package/dist/modules/sales/subscribers/quote-expiring-notification.js +38 -0
- package/dist/modules/sales/subscribers/quote-expiring-notification.js.map +7 -0
- package/dist/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.js +137 -0
- package/dist/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.js.map +7 -0
- package/dist/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.js +137 -0
- package/dist/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.js.map +7 -0
- package/dist/modules/sales/widgets/notifications/index.js +7 -0
- package/dist/modules/sales/widgets/notifications/index.js.map +7 -0
- package/dist/modules/sales/widgets/notifications/useSalesDocumentTotals.js +60 -0
- package/dist/modules/sales/widgets/notifications/useSalesDocumentTotals.js.map +7 -0
- package/dist/modules/staff/backend/staff/team-members/page.js +1 -1
- package/dist/modules/staff/backend/staff/team-members/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/team-roles/page.js +2 -2
- package/dist/modules/staff/backend/staff/team-roles/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js +2 -2
- package/dist/modules/staff/backend/staff/teams/[id]/edit/page.js.map +2 -2
- package/dist/modules/staff/backend/staff/teams/page.js +2 -2
- package/dist/modules/staff/backend/staff/teams/page.js.map +2 -2
- package/dist/modules/staff/commands/leave-requests.js +79 -0
- package/dist/modules/staff/commands/leave-requests.js.map +2 -2
- package/dist/modules/staff/notifications.js +75 -0
- package/dist/modules/staff/notifications.js.map +7 -0
- package/dist/modules/workflows/acl.js +0 -2
- package/dist/modules/workflows/acl.js.map +2 -2
- package/dist/modules/workflows/api/instances/route.js +6 -18
- package/dist/modules/workflows/api/instances/route.js.map +2 -2
- package/dist/modules/workflows/api/tasks/route.js +1 -6
- package/dist/modules/workflows/api/tasks/route.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/[id]/page.js +1 -9
- package/dist/modules/workflows/backend/definitions/[id]/page.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/[id]/page.meta.js +1 -1
- package/dist/modules/workflows/backend/definitions/[id]/page.meta.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/create/page.js +15 -24
- package/dist/modules/workflows/backend/definitions/create/page.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/create/page.meta.js +1 -1
- package/dist/modules/workflows/backend/definitions/create/page.meta.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/page.js +5 -0
- package/dist/modules/workflows/backend/definitions/page.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/visual-editor/page.js +132 -150
- package/dist/modules/workflows/backend/definitions/visual-editor/page.js.map +2 -2
- package/dist/modules/workflows/backend/definitions/visual-editor/page.meta.js +1 -1
- package/dist/modules/workflows/backend/definitions/visual-editor/page.meta.js.map +2 -2
- package/dist/modules/workflows/backend/events/[id]/page.js +1 -1
- package/dist/modules/workflows/backend/events/[id]/page.js.map +2 -2
- package/dist/modules/workflows/backend/events/[id]/page.meta.js +2 -2
- package/dist/modules/workflows/backend/events/[id]/page.meta.js.map +2 -2
- package/dist/modules/workflows/backend/instances/[id]/page.meta.js +2 -2
- package/dist/modules/workflows/backend/instances/[id]/page.meta.js.map +2 -2
- package/dist/modules/workflows/backend/instances/page.js +3 -0
- package/dist/modules/workflows/backend/instances/page.js.map +2 -2
- package/dist/modules/workflows/backend/tasks/[id]/page.js +1 -1
- package/dist/modules/workflows/backend/tasks/[id]/page.js.map +2 -2
- package/dist/modules/workflows/backend/tasks/[id]/page.meta.js +2 -2
- package/dist/modules/workflows/backend/tasks/[id]/page.meta.js.map +2 -2
- package/dist/modules/workflows/backend/tasks/page.js +9 -5
- package/dist/modules/workflows/backend/tasks/page.js.map +2 -2
- package/dist/modules/workflows/cli.js +15 -93
- package/dist/modules/workflows/cli.js.map +3 -3
- package/dist/modules/workflows/data/entities.js +1 -64
- package/dist/modules/workflows/data/entities.js.map +2 -2
- package/dist/modules/workflows/data/validators.js +0 -115
- package/dist/modules/workflows/data/validators.js.map +2 -2
- package/dist/modules/workflows/examples/checkout-demo-definition.json +5 -1
- package/dist/modules/workflows/lib/activity-executor.js +13 -75
- package/dist/modules/workflows/lib/activity-executor.js.map +2 -2
- package/dist/modules/workflows/lib/graph-utils.js +2 -71
- package/dist/modules/workflows/lib/graph-utils.js.map +2 -2
- package/dist/modules/workflows/lib/seeds.js +5 -22
- package/dist/modules/workflows/lib/seeds.js.map +2 -2
- package/dist/modules/workflows/lib/start-validator.js +23 -33
- package/dist/modules/workflows/lib/start-validator.js.map +2 -2
- package/dist/modules/workflows/lib/transition-handler.js +57 -161
- package/dist/modules/workflows/lib/transition-handler.js.map +3 -3
- package/dist/modules/workflows/notifications.js +28 -0
- package/dist/modules/workflows/notifications.js.map +7 -0
- package/dist/modules/workflows/subscribers/task-assigned-notification.js +38 -0
- package/dist/modules/workflows/subscribers/task-assigned-notification.js.map +7 -0
- package/generated/entities/notification/index.ts +27 -0
- package/generated/entities.ids.generated.ts +5 -2
- package/generated/entity-fields-registry.ts +2 -2
- package/package.json +2 -2
- package/src/modules/api_docs/frontend/docs/api/page.tsx +3 -2
- package/src/modules/api_keys/backend/api-keys/page.tsx +1 -1
- package/src/modules/attachments/components/AttachmentLibrary.tsx +4 -0
- package/src/modules/attachments/components/AttachmentPartitionSettings.tsx +2 -0
- package/src/modules/auth/README.md +1 -1
- package/src/modules/auth/__tests__/cli-setup-acl.test.ts +1 -1
- package/src/modules/auth/api/__tests__/login.test.ts +2 -0
- package/src/modules/auth/api/admin/nav.ts +10 -6
- package/src/modules/auth/api/login.ts +26 -7
- package/src/modules/auth/api/profile/route.ts +163 -0
- package/src/modules/auth/api/reset/confirm.ts +25 -2
- package/src/modules/auth/api/reset.ts +23 -0
- package/src/modules/auth/api/sidebar/preferences/route.ts +21 -12
- package/src/modules/auth/api/users/route.ts +5 -2
- package/src/modules/auth/backend/auth/profile/page.meta.ts +9 -0
- package/src/modules/auth/backend/auth/profile/page.tsx +174 -0
- package/src/modules/auth/backend/roles/[id]/edit/page.tsx +4 -1
- package/src/modules/auth/backend/roles/page.tsx +3 -3
- package/src/modules/auth/backend/users/[id]/edit/page.tsx +22 -3
- package/src/modules/auth/backend/users/create/page.tsx +19 -2
- package/src/modules/auth/backend/users/page.tsx +3 -3
- package/src/modules/auth/cli.ts +38 -11
- package/src/modules/auth/commands/users.ts +73 -2
- package/src/modules/auth/data/validators.ts +6 -2
- package/src/modules/auth/frontend/login.tsx +134 -5
- package/src/modules/auth/frontend/reset/[token]/page.tsx +24 -11
- package/src/modules/auth/i18n/de.json +48 -1
- package/src/modules/auth/i18n/en.json +48 -1
- package/src/modules/auth/i18n/es.json +48 -1
- package/src/modules/auth/i18n/pl.json +48 -1
- package/src/modules/auth/lib/setup-app.ts +58 -9
- package/src/modules/auth/notifications.ts +109 -0
- package/src/modules/auth/services/authService.ts +27 -4
- package/src/modules/business_rules/api/execute/route.ts +8 -1
- package/src/modules/business_rules/backend/rules/page.tsx +4 -0
- package/src/modules/business_rules/backend/sets/page.tsx +3 -0
- package/src/modules/business_rules/cli.ts +2 -1
- package/src/modules/business_rules/data/validators.ts +0 -40
- package/src/modules/business_rules/i18n/en.json +3 -1
- package/src/modules/business_rules/index.ts +0 -25
- package/src/modules/business_rules/lib/__tests__/rule-engine.test.ts +51 -0
- package/src/modules/business_rules/lib/rule-engine.ts +51 -277
- package/src/modules/business_rules/notifications.ts +25 -0
- package/src/modules/business_rules/subscribers/rule-execution-failed-notification.ts +50 -0
- package/src/modules/catalog/components/PriceKindSettings.tsx +2 -0
- package/src/modules/catalog/components/categories/CategoriesDataTable.tsx +2 -2
- package/src/modules/catalog/components/products/ProductsDataTable.tsx +2 -0
- package/src/modules/catalog/i18n/en.json +3 -1
- package/src/modules/catalog/notifications.ts +25 -0
- package/src/modules/catalog/subscribers/low-stock-notification.ts +52 -0
- package/src/modules/configs/cli.ts +6 -0
- package/src/modules/configs/components/CachePanel.tsx +4 -4
- package/src/modules/configs/i18n/en.json +12 -2
- package/src/modules/configs/i18n/pl.json +12 -2
- package/src/modules/configs/lib/system-status.ts +48 -1
- package/src/modules/configs/lib/system-status.types.ts +1 -0
- package/src/modules/configs/lib/upgrade-actions.ts +18 -0
- package/src/modules/currencies/backend/currencies/page.tsx +3 -0
- package/src/modules/currencies/backend/exchange-rates/page.tsx +2 -0
- package/src/modules/customers/backend/customers/companies/page.tsx +3 -0
- package/src/modules/customers/backend/customers/deals/page.tsx +3 -0
- package/src/modules/customers/backend/customers/people/page.tsx +3 -0
- package/src/modules/customers/commands/deals.ts +39 -0
- package/src/modules/customers/components/CustomerTodosTable.tsx +1 -0
- package/src/modules/customers/i18n/en.json +5 -1
- package/src/modules/customers/notifications.ts +44 -0
- package/src/modules/customers/widgets/dashboard/customer-todos/widget.ts +2 -2
- package/src/modules/customers/widgets/dashboard/new-customers/widget.ts +2 -2
- package/src/modules/customers/widgets/dashboard/new-deals/widget.ts +2 -2
- package/src/modules/customers/widgets/dashboard/next-interactions/widget.ts +2 -2
- package/src/modules/dashboards/cli.ts +55 -5
- package/src/modules/dashboards/components/WidgetVisibilityEditor.tsx +22 -11
- package/src/modules/dashboards/lib/role-widgets.ts +80 -0
- package/src/modules/dashboards/services/widgetDataService.ts +164 -4
- package/src/modules/dashboards/widgets/dashboard/aov-kpi/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/new-customers-kpi/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/orders-by-status/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/orders-kpi/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/pipeline-summary/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/revenue-kpi/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/revenue-trend/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/sales-by-region/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/top-customers/widget.ts +2 -2
- package/src/modules/dashboards/widgets/dashboard/top-products/widget.ts +2 -2
- package/src/modules/dictionaries/components/DictionaryTable.tsx +2 -0
- package/src/modules/directory/api/get/tenants/lookup.ts +75 -0
- package/src/modules/directory/backend/directory/organizations/page.tsx +2 -2
- package/src/modules/directory/backend/directory/tenants/page.tsx +2 -2
- package/src/modules/entities/backend/entities/user/[entityId]/records/page.tsx +2 -2
- package/src/modules/entities/components/SystemEntitiesTable.tsx +1 -1
- package/src/modules/entities/components/UserEntitiesTable.tsx +2 -2
- package/src/modules/feature_toggles/components/FeatureTogglesTable.tsx +3 -4
- package/src/modules/feature_toggles/components/OverridesTable.tsx +1 -1
- package/src/modules/notifications/__tests__/deliver-notification.test.ts +195 -0
- package/src/modules/notifications/__tests__/deliveryStrategies.test.ts +19 -0
- package/src/modules/notifications/__tests__/notificationService.test.ts +208 -0
- package/src/modules/notifications/acl.ts +7 -0
- package/src/modules/notifications/api/[id]/action/route.ts +75 -0
- package/src/modules/notifications/api/[id]/dismiss/route.ts +12 -0
- package/src/modules/notifications/api/[id]/read/route.ts +12 -0
- package/src/modules/notifications/api/[id]/restore/route.ts +53 -0
- package/src/modules/notifications/api/batch/route.ts +14 -0
- package/src/modules/notifications/api/feature/route.ts +14 -0
- package/src/modules/notifications/api/mark-all-read/route.ts +34 -0
- package/src/modules/notifications/api/openapi.ts +76 -0
- package/src/modules/notifications/api/role/route.ts +14 -0
- package/src/modules/notifications/api/route.ts +92 -0
- package/src/modules/notifications/api/settings/route.ts +157 -0
- package/src/modules/notifications/api/unread-count/route.ts +38 -0
- package/src/modules/notifications/backend/config/notifications/page.meta.ts +22 -0
- package/src/modules/notifications/backend/config/notifications/page.tsx +12 -0
- package/src/modules/notifications/cli.ts +18 -0
- package/src/modules/notifications/data/entities.ts +99 -0
- package/src/modules/notifications/data/validators.ts +115 -0
- package/src/modules/notifications/di.ts +11 -0
- package/src/modules/notifications/emails/NotificationEmail.tsx +98 -0
- package/src/modules/notifications/frontend/NotificationInboxPageClient.tsx +42 -0
- package/src/modules/notifications/frontend/NotificationSettingsPageClient.tsx +233 -0
- package/src/modules/notifications/i18n/de.json +50 -0
- package/src/modules/notifications/i18n/en.json +50 -0
- package/src/modules/notifications/i18n/es.json +50 -0
- package/src/modules/notifications/i18n/pl.json +50 -0
- package/src/modules/notifications/index.ts +12 -0
- package/src/modules/notifications/lib/deliveryConfig.ts +153 -0
- package/src/modules/notifications/lib/deliveryStrategies.ts +50 -0
- package/src/modules/notifications/lib/events.ts +48 -0
- package/src/modules/notifications/lib/notificationBuilder.ts +121 -0
- package/src/modules/notifications/lib/notificationFactory.ts +76 -0
- package/src/modules/notifications/lib/notificationMapper.ts +33 -0
- package/src/modules/notifications/lib/notificationRecipients.ts +83 -0
- package/src/modules/notifications/lib/notificationService.ts +414 -0
- package/src/modules/notifications/lib/routeHelpers.ts +151 -0
- package/src/modules/notifications/lib/safeHref.ts +29 -0
- package/src/modules/notifications/migrations/.snapshot-open-mercato.json +336 -0
- package/src/modules/notifications/migrations/Migration20260123000001.ts +73 -0
- package/src/modules/notifications/migrations/Migration20260126150000.ts +39 -0
- package/src/modules/notifications/migrations/Migration20260129082610.ts +13 -0
- package/src/modules/notifications/subscribers/deliver-notification.ts +204 -0
- package/src/modules/notifications/workers/create-notification.worker.ts +122 -0
- package/src/modules/planner/backend/planner/availability-rulesets/page.tsx +2 -2
- package/src/modules/query_index/cli.ts +82 -13
- package/src/modules/query_index/components/QueryIndexesTable.tsx +8 -2
- package/src/modules/resources/backend/resources/resource-types/page.tsx +2 -2
- package/src/modules/resources/backend/resources/resources/page.tsx +2 -2
- package/src/modules/sales/acl.ts +0 -1
- package/src/modules/sales/backend/sales/channels/offers/page.tsx +2 -0
- package/src/modules/sales/backend/sales/channels/page.tsx +2 -0
- package/src/modules/sales/backend/sales/documents/[id]/page.tsx +0 -16
- package/src/modules/sales/commands/documents.ts +62 -70
- package/src/modules/sales/commands/payments.ts +33 -0
- package/src/modules/sales/components/AdjustmentKindSettings.tsx +2 -2
- package/src/modules/sales/components/PaymentMethodsSettings.tsx +2 -2
- package/src/modules/sales/components/ShippingMethodsSettings.tsx +2 -2
- package/src/modules/sales/components/TaxRatesSettings.tsx +2 -2
- package/src/modules/sales/components/channels/SalesChannelOffersPanel.tsx +2 -0
- package/src/modules/sales/components/documents/AdjustmentsSection.tsx +2 -0
- package/src/modules/sales/components/documents/PaymentsSection.tsx +2 -1
- package/src/modules/sales/components/documents/SalesDocumentsTable.tsx +2 -0
- package/src/modules/sales/i18n/de.json +20 -0
- package/src/modules/sales/i18n/en.json +25 -1
- package/src/modules/sales/i18n/es.json +20 -0
- package/src/modules/sales/i18n/pl.json +20 -0
- package/src/modules/sales/lib/dictionaries.ts +0 -3
- package/src/modules/sales/notifications.client.ts +65 -0
- package/src/modules/sales/notifications.ts +82 -0
- package/src/modules/sales/subscribers/quote-expiring-notification.ts +53 -0
- package/src/modules/sales/widgets/notifications/SalesOrderCreatedRenderer.tsx +156 -0
- package/src/modules/sales/widgets/notifications/SalesQuoteCreatedRenderer.tsx +156 -0
- package/src/modules/sales/widgets/notifications/index.ts +2 -0
- package/src/modules/sales/widgets/notifications/useSalesDocumentTotals.ts +81 -0
- package/src/modules/staff/backend/staff/team-members/page.tsx +1 -1
- package/src/modules/staff/backend/staff/team-roles/page.tsx +2 -2
- package/src/modules/staff/backend/staff/teams/[id]/edit/page.tsx +2 -2
- package/src/modules/staff/backend/staff/teams/page.tsx +2 -2
- package/src/modules/staff/commands/leave-requests.ts +94 -0
- package/src/modules/staff/i18n/de.json +4 -0
- package/src/modules/staff/i18n/en.json +9 -1
- package/src/modules/staff/i18n/es.json +4 -0
- package/src/modules/staff/i18n/pl.json +4 -0
- package/src/modules/staff/notifications.ts +71 -0
- package/src/modules/workflows/acl.ts +0 -2
- package/src/modules/workflows/api/__tests__/instances.route.test.ts +2 -5
- package/src/modules/workflows/api/instances/route.ts +7 -21
- package/src/modules/workflows/api/tasks/route.ts +1 -7
- package/src/modules/workflows/backend/definitions/[id]/page.meta.ts +1 -1
- package/src/modules/workflows/backend/definitions/[id]/page.tsx +0 -9
- package/src/modules/workflows/backend/definitions/create/page.meta.ts +1 -1
- package/src/modules/workflows/backend/definitions/create/page.tsx +0 -9
- package/src/modules/workflows/backend/definitions/page.tsx +5 -0
- package/src/modules/workflows/backend/definitions/visual-editor/page.meta.ts +1 -1
- package/src/modules/workflows/backend/definitions/visual-editor/page.tsx +3 -21
- package/src/modules/workflows/backend/events/[id]/page.meta.ts +2 -2
- package/src/modules/workflows/backend/events/[id]/page.tsx +1 -1
- package/src/modules/workflows/backend/instances/[id]/page.meta.ts +2 -2
- package/src/modules/workflows/backend/instances/page.tsx +4 -1
- package/src/modules/workflows/backend/tasks/[id]/page.meta.ts +2 -2
- package/src/modules/workflows/backend/tasks/[id]/page.tsx +1 -1
- package/src/modules/workflows/backend/tasks/page.tsx +10 -6
- package/src/modules/workflows/cli.ts +12 -123
- package/src/modules/workflows/data/entities.ts +0 -124
- package/src/modules/workflows/data/validators.ts +0 -138
- package/src/modules/workflows/examples/checkout-demo-definition.json +5 -1
- package/src/modules/workflows/i18n/en.json +3 -72
- package/src/modules/workflows/lib/__tests__/activity-executor.test.ts +36 -43
- package/src/modules/workflows/lib/__tests__/transition-handler.test.ts +90 -170
- package/src/modules/workflows/lib/activity-executor.ts +16 -129
- package/src/modules/workflows/lib/graph-utils.ts +2 -117
- package/src/modules/workflows/lib/seeds.ts +8 -34
- package/src/modules/workflows/lib/start-validator.ts +28 -38
- package/src/modules/workflows/lib/transition-handler.ts +71 -212
- package/src/modules/workflows/notifications.ts +25 -0
- package/src/modules/workflows/subscribers/task-assigned-notification.ts +53 -0
- package/dist/generated/entities/workflow_event_trigger/index.js +0 -33
- package/dist/generated/entities/workflow_event_trigger/index.js.map +0 -7
- package/dist/modules/auth/events.js +0 -30
- package/dist/modules/auth/events.js.map +0 -7
- package/dist/modules/business_rules/api/execute/[ruleId]/route.js +0 -145
- package/dist/modules/business_rules/api/execute/[ruleId]/route.js.map +0 -7
- package/dist/modules/catalog/events.js +0 -34
- package/dist/modules/catalog/events.js.map +0 -7
- package/dist/modules/customers/events.js +0 -49
- package/dist/modules/customers/events.js.map +0 -7
- package/dist/modules/directory/events.js +0 -23
- package/dist/modules/directory/events.js.map +0 -7
- package/dist/modules/sales/events.js +0 -63
- package/dist/modules/sales/events.js.map +0 -7
- package/dist/modules/sales/lib/frontend/documentDataEvents.js +0 -25
- package/dist/modules/sales/lib/frontend/documentDataEvents.js.map +0 -7
- package/dist/modules/workflows/components/DefinitionTriggersEditor.js +0 -481
- package/dist/modules/workflows/components/DefinitionTriggersEditor.js.map +0 -7
- package/dist/modules/workflows/components/EventTriggersEditor.js +0 -553
- package/dist/modules/workflows/components/EventTriggersEditor.js.map +0 -7
- package/dist/modules/workflows/events.js +0 -38
- package/dist/modules/workflows/events.js.map +0 -7
- package/dist/modules/workflows/examples/order-approval-definition.json +0 -257
- package/dist/modules/workflows/examples/order-approval-guard-rules.json +0 -32
- package/dist/modules/workflows/lib/event-trigger-service.js +0 -308
- package/dist/modules/workflows/lib/event-trigger-service.js.map +0 -7
- package/dist/modules/workflows/migrations/Migration20260123143500.js +0 -36
- package/dist/modules/workflows/migrations/Migration20260123143500.js.map +0 -7
- package/dist/modules/workflows/subscribers/event-trigger.js +0 -78
- package/dist/modules/workflows/subscribers/event-trigger.js.map +0 -7
- package/dist/modules/workflows/widgets/injection/order-approval/widget.client.js +0 -323
- package/dist/modules/workflows/widgets/injection/order-approval/widget.client.js.map +0 -7
- package/dist/modules/workflows/widgets/injection/order-approval/widget.js +0 -17
- package/dist/modules/workflows/widgets/injection/order-approval/widget.js.map +0 -7
- package/dist/modules/workflows/widgets/injection-table.js +0 -19
- package/dist/modules/workflows/widgets/injection-table.js.map +0 -7
- package/generated/entities/workflow_event_trigger/index.ts +0 -15
- package/src/modules/auth/events.ts +0 -39
- package/src/modules/business_rules/api/execute/[ruleId]/route.ts +0 -163
- package/src/modules/catalog/events.ts +0 -45
- package/src/modules/customers/events.ts +0 -63
- package/src/modules/directory/events.ts +0 -31
- package/src/modules/sales/events.ts +0 -82
- package/src/modules/sales/lib/frontend/documentDataEvents.ts +0 -28
- package/src/modules/workflows/components/DefinitionTriggersEditor.tsx +0 -581
- package/src/modules/workflows/components/EventTriggersEditor.tsx +0 -664
- package/src/modules/workflows/events.ts +0 -49
- package/src/modules/workflows/examples/order-approval-definition.json +0 -257
- package/src/modules/workflows/examples/order-approval-guard-rules.json +0 -32
- package/src/modules/workflows/lib/event-trigger-service.ts +0 -557
- package/src/modules/workflows/migrations/Migration20260123143500.ts +0 -38
- package/src/modules/workflows/subscribers/event-trigger.ts +0 -109
- package/src/modules/workflows/widgets/injection/order-approval/widget.client.tsx +0 -446
- package/src/modules/workflows/widgets/injection/order-approval/widget.ts +0 -16
- package/src/modules/workflows/widgets/injection-table.ts +0 -21
|
@@ -2,12 +2,26 @@
|
|
|
2
2
|
"auth.signIn": "Iniciar sesión",
|
|
3
3
|
"auth.email": "Correo electrónico",
|
|
4
4
|
"auth.password": "Contraseña",
|
|
5
|
+
"auth.password.requirements.help": "Requisitos de la contraseña: {requirements}",
|
|
6
|
+
"auth.password.requirements.minLength": "Al menos {min} caracteres",
|
|
7
|
+
"auth.password.requirements.digit": "Un número",
|
|
8
|
+
"auth.password.requirements.uppercase": "Una letra mayúscula",
|
|
9
|
+
"auth.password.requirements.special": "Un carácter especial",
|
|
10
|
+
"auth.password.requirements.separator": ", ",
|
|
5
11
|
"auth.sendResetLink": "Enviar enlace de restablecimiento",
|
|
6
12
|
"auth.resetPassword": "Restablecer contraseña",
|
|
13
|
+
"auth.reset.title": "Establecer una nueva contraseña",
|
|
14
|
+
"auth.reset.subtitle": "Elige una contraseña segura para tu cuenta.",
|
|
15
|
+
"auth.reset.form.password": "Nueva contraseña",
|
|
16
|
+
"auth.reset.form.loading": "...",
|
|
17
|
+
"auth.reset.form.submit": "Actualizar contraseña",
|
|
18
|
+
"auth.reset.errors.failed": "No se pudo restablecer la contraseña",
|
|
7
19
|
"auth.usersRoles": "Usuarios y roles",
|
|
8
20
|
"auth.manageAuthSettings": "Administra la configuración de autenticación.",
|
|
9
21
|
"auth.login.errors.permissionDenied": "No tienes permiso para acceder a esta área. Ponte en contacto con tu administrador.",
|
|
10
22
|
"auth.login.errors.invalidCredentials": "Correo electrónico o contraseña no válidos",
|
|
23
|
+
"auth.login.errors.tenantRequired": "Usa el enlace de inicio de sesión proporcionado con la activación de tu inquilino para continuar.",
|
|
24
|
+
"auth.login.errors.tenantInvalid": "No se encontró el inquilino. Borra la selección e inténtalo de nuevo.",
|
|
11
25
|
"auth.login.errors.generic": "Se produjo un error. Inténtalo de nuevo.",
|
|
12
26
|
"auth.login.logoAlt": "Logotipo de Open Mercato",
|
|
13
27
|
"auth.login.brandName": "Open Mercato",
|
|
@@ -15,6 +29,9 @@
|
|
|
15
29
|
"auth.login.requireRoleMessage": "El acceso requiere el rol: {roles}",
|
|
16
30
|
"auth.login.requireRolesMessage": "El acceso requiere uno de los siguientes roles: {roles}",
|
|
17
31
|
"auth.login.featureDenied": "No tienes acceso a esta funcionalidad ({feature}). Ponte en contacto con tu administrador.",
|
|
32
|
+
"auth.login.tenantBanner": "Estás iniciando sesión en el inquilino {tenant}.",
|
|
33
|
+
"auth.login.tenantLoading": "Cargando detalles del inquilino...",
|
|
34
|
+
"auth.login.tenantClear": "Borrar",
|
|
18
35
|
"auth.login.rememberMe": "Recordarme",
|
|
19
36
|
"auth.login.loading": "Cargando...",
|
|
20
37
|
"auth.login.forgotPassword": "¿Olvidaste tu contraseña?",
|
|
@@ -80,6 +97,21 @@
|
|
|
80
97
|
"auth.users.form.errors.load": "No se pudieron cargar los datos del usuario",
|
|
81
98
|
"auth.users.form.errors.aclUpdate": "No se pudo actualizar el control de acceso del usuario",
|
|
82
99
|
"auth.users.form.errors.delete": "No se pudo eliminar el usuario",
|
|
100
|
+
"auth.profile.title": "Perfil",
|
|
101
|
+
"auth.profile.subtitle": "Cambiar contraseña",
|
|
102
|
+
"auth.profile.form.email": "Correo electrónico",
|
|
103
|
+
"auth.profile.form.password": "Nueva contraseña",
|
|
104
|
+
"auth.profile.form.confirmPassword": "Confirmar nueva contraseña",
|
|
105
|
+
"auth.profile.form.save": "Guardar cambios",
|
|
106
|
+
"auth.profile.form.loading": "Cargando perfil...",
|
|
107
|
+
"auth.profile.form.errors.load": "No se pudo cargar el perfil.",
|
|
108
|
+
"auth.profile.form.errors.save": "No se pudo actualizar el perfil.",
|
|
109
|
+
"auth.profile.form.errors.invalid": "Actualización de perfil inválida.",
|
|
110
|
+
"auth.profile.form.errors.passwordMismatch": "Las contraseñas no coinciden.",
|
|
111
|
+
"auth.profile.form.errors.passwordRequirements": "La contraseña debe cumplir los requisitos.",
|
|
112
|
+
"auth.profile.form.errors.noChanges": "No hay cambios para guardar.",
|
|
113
|
+
"auth.profile.form.errors.emailRequired": "El correo electrónico es obligatorio.",
|
|
114
|
+
"auth.profile.form.success": "Perfil actualizado.",
|
|
83
115
|
"auth.users.list.error.load": "No se pudieron cargar los usuarios",
|
|
84
116
|
"auth.users.list.error.delete": "No se pudo eliminar el usuario",
|
|
85
117
|
"auth.users.flash.created": "Usuario creado",
|
|
@@ -95,5 +127,20 @@
|
|
|
95
127
|
"auth.email.resetPassword.title": "Restablecer tu contraseña",
|
|
96
128
|
"auth.email.resetPassword.body": "Haz clic en el siguiente enlace para establecer una nueva contraseña. Este enlace caducará en 60 minutos.",
|
|
97
129
|
"auth.email.resetPassword.cta": "Establecer nueva contraseña",
|
|
98
|
-
"auth.email.resetPassword.hint": "Si no solicitaste esto, puedes ignorar este correo de forma segura."
|
|
130
|
+
"auth.email.resetPassword.hint": "Si no solicitaste esto, puedes ignorar este correo de forma segura.",
|
|
131
|
+
"auth.notifications.passwordReset.requested.title": "Solicitud de restablecimiento de contraseña",
|
|
132
|
+
"auth.notifications.passwordReset.requested.body": "Se ha enviado un enlace de restablecimiento de contraseña a tu correo electrónico",
|
|
133
|
+
"auth.notifications.passwordReset.completed.title": "Contraseña cambiada correctamente",
|
|
134
|
+
"auth.notifications.passwordReset.completed.body": "Tu contraseña se actualizó correctamente",
|
|
135
|
+
"auth.notifications.account.locked.title": "Cuenta bloqueada",
|
|
136
|
+
"auth.notifications.account.locked.body": "Tu cuenta ha sido bloqueada por razones de seguridad. Ponte en contacto con soporte.",
|
|
137
|
+
"auth.notifications.login.newDevice.title": "Nuevo inicio de sesión detectado",
|
|
138
|
+
"auth.notifications.login.newDevice.body": "Se detectó un inicio de sesión desde un dispositivo no reconocido en tu cuenta",
|
|
139
|
+
"auth.notifications.role.assigned.title": "Nuevo rol asignado",
|
|
140
|
+
"auth.notifications.role.assigned.body": "Se te ha asignado un nuevo rol con permisos adicionales",
|
|
141
|
+
"auth.notifications.role.revoked.title": "Rol eliminado",
|
|
142
|
+
"auth.notifications.role.revoked.body": "Se ha eliminado un rol de tu cuenta",
|
|
143
|
+
"auth.actions.contactSupport": "Contactar soporte",
|
|
144
|
+
"auth.actions.viewSessions": "Ver sesiones",
|
|
145
|
+
"auth.actions.viewPermissions": "Ver permisos"
|
|
99
146
|
}
|
|
@@ -2,12 +2,26 @@
|
|
|
2
2
|
"auth.signIn": "Zaloguj się",
|
|
3
3
|
"auth.email": "Email",
|
|
4
4
|
"auth.password": "Hasło",
|
|
5
|
+
"auth.password.requirements.help": "Wymagania hasła: {requirements}",
|
|
6
|
+
"auth.password.requirements.minLength": "Co najmniej {min} znaków",
|
|
7
|
+
"auth.password.requirements.digit": "Jedna cyfra",
|
|
8
|
+
"auth.password.requirements.uppercase": "Jedna wielka litera",
|
|
9
|
+
"auth.password.requirements.special": "Jeden znak specjalny",
|
|
10
|
+
"auth.password.requirements.separator": ", ",
|
|
5
11
|
"auth.sendResetLink": "Wyślij link resetujący",
|
|
6
12
|
"auth.resetPassword": "Resetuj hasło",
|
|
13
|
+
"auth.reset.title": "Ustaw nowe hasło",
|
|
14
|
+
"auth.reset.subtitle": "Wybierz silne hasło dla swojego konta.",
|
|
15
|
+
"auth.reset.form.password": "Nowe hasło",
|
|
16
|
+
"auth.reset.form.loading": "...",
|
|
17
|
+
"auth.reset.form.submit": "Zaktualizuj hasło",
|
|
18
|
+
"auth.reset.errors.failed": "Nie udało się zresetować hasła",
|
|
7
19
|
"auth.usersRoles": "Użytkownicy i role",
|
|
8
20
|
"auth.manageAuthSettings": "Zarządzaj ustawieniami uwierzytelniania.",
|
|
9
21
|
"auth.login.errors.permissionDenied": "Nie masz uprawnień do tego obszaru. Skontaktuj się z administratorem.",
|
|
10
22
|
"auth.login.errors.invalidCredentials": "Nieprawidłowy email lub hasło",
|
|
23
|
+
"auth.login.errors.tenantRequired": "Użyj linku logowania z aktywacji najemcy, aby kontynuować.",
|
|
24
|
+
"auth.login.errors.tenantInvalid": "Nie znaleziono najemcy. Wyczyść wybór i spróbuj ponownie.",
|
|
11
25
|
"auth.login.errors.generic": "Wystąpił błąd. Spróbuj ponownie.",
|
|
12
26
|
"auth.login.logoAlt": "Logo Open Mercato",
|
|
13
27
|
"auth.login.brandName": "Open Mercato",
|
|
@@ -15,6 +29,9 @@
|
|
|
15
29
|
"auth.login.requireRoleMessage": "Dostęp wymaga roli: {roles}",
|
|
16
30
|
"auth.login.requireRolesMessage": "Dostęp wymaga jednej z następujących ról: {roles}",
|
|
17
31
|
"auth.login.featureDenied": "Nie masz dostępu do tej funkcji ({feature}). Skontaktuj się z administratorem.",
|
|
32
|
+
"auth.login.tenantBanner": "Logujesz się do najemcy {tenant}.",
|
|
33
|
+
"auth.login.tenantLoading": "Ładowanie szczegółów najemcy...",
|
|
34
|
+
"auth.login.tenantClear": "Wyczyść",
|
|
18
35
|
"auth.login.rememberMe": "Zapamiętaj mnie",
|
|
19
36
|
"auth.login.loading": "Ładowanie...",
|
|
20
37
|
"auth.login.forgotPassword": "Nie pamiętasz hasła?",
|
|
@@ -80,6 +97,21 @@
|
|
|
80
97
|
"auth.users.form.errors.load": "Nie udało się wczytać danych użytkownika",
|
|
81
98
|
"auth.users.form.errors.aclUpdate": "Nie udało się zaktualizować uprawnień użytkownika",
|
|
82
99
|
"auth.users.form.errors.delete": "Nie udało się usunąć użytkownika",
|
|
100
|
+
"auth.profile.title": "Profil",
|
|
101
|
+
"auth.profile.subtitle": "Zmiana hasła",
|
|
102
|
+
"auth.profile.form.email": "Email",
|
|
103
|
+
"auth.profile.form.password": "Nowe hasło",
|
|
104
|
+
"auth.profile.form.confirmPassword": "Potwierdź nowe hasło",
|
|
105
|
+
"auth.profile.form.save": "Zapisz zmiany",
|
|
106
|
+
"auth.profile.form.loading": "Ładowanie profilu...",
|
|
107
|
+
"auth.profile.form.errors.load": "Nie udało się wczytać profilu.",
|
|
108
|
+
"auth.profile.form.errors.save": "Nie udało się zaktualizować profilu.",
|
|
109
|
+
"auth.profile.form.errors.invalid": "Nieprawidłowa aktualizacja profilu.",
|
|
110
|
+
"auth.profile.form.errors.passwordMismatch": "Hasła nie są zgodne.",
|
|
111
|
+
"auth.profile.form.errors.passwordRequirements": "Hasło musi spełniać wymagania.",
|
|
112
|
+
"auth.profile.form.errors.noChanges": "Brak zmian do zapisania.",
|
|
113
|
+
"auth.profile.form.errors.emailRequired": "Email jest wymagany.",
|
|
114
|
+
"auth.profile.form.success": "Profil zaktualizowany.",
|
|
83
115
|
"auth.users.list.error.load": "Nie udało się wczytać użytkowników",
|
|
84
116
|
"auth.users.list.error.delete": "Nie udało się usunąć użytkownika",
|
|
85
117
|
"auth.users.flash.created": "Użytkownik utworzony",
|
|
@@ -95,5 +127,20 @@
|
|
|
95
127
|
"auth.email.resetPassword.title": "Zresetuj swoje hasło",
|
|
96
128
|
"auth.email.resetPassword.body": "Kliknij poniższy link, aby ustawić nowe hasło. Link wygaśnie za 60 minut.",
|
|
97
129
|
"auth.email.resetPassword.cta": "Ustaw nowe hasło",
|
|
98
|
-
"auth.email.resetPassword.hint": "Jeśli nie prosiłeś o tę wiadomość, możesz ją bezpiecznie zignorować."
|
|
130
|
+
"auth.email.resetPassword.hint": "Jeśli nie prosiłeś o tę wiadomość, możesz ją bezpiecznie zignorować.",
|
|
131
|
+
"auth.notifications.passwordReset.requested.title": "Żądanie resetu hasła",
|
|
132
|
+
"auth.notifications.passwordReset.requested.body": "Link do resetu hasła został wysłany na Twój adres e-mail",
|
|
133
|
+
"auth.notifications.passwordReset.completed.title": "Hasło zmienione pomyślnie",
|
|
134
|
+
"auth.notifications.passwordReset.completed.body": "Twoje hasło zostało pomyślnie zaktualizowane",
|
|
135
|
+
"auth.notifications.account.locked.title": "Konto zablokowane",
|
|
136
|
+
"auth.notifications.account.locked.body": "Twoje konto zostało zablokowane z powodów bezpieczeństwa. Skontaktuj się z pomocą techniczną.",
|
|
137
|
+
"auth.notifications.login.newDevice.title": "Wykryto logowanie z nowego urządzenia",
|
|
138
|
+
"auth.notifications.login.newDevice.body": "Wykryto logowanie z nieznanego urządzenia na Twoim koncie",
|
|
139
|
+
"auth.notifications.role.assigned.title": "Przypisano nową rolę",
|
|
140
|
+
"auth.notifications.role.assigned.body": "Przypisano Ci nową rolę z dodatkowymi uprawnieniami",
|
|
141
|
+
"auth.notifications.role.revoked.title": "Rola usunięta",
|
|
142
|
+
"auth.notifications.role.revoked.body": "Z Twojego konta usunięto rolę",
|
|
143
|
+
"auth.actions.contactSupport": "Skontaktuj się z pomocą",
|
|
144
|
+
"auth.actions.viewSessions": "Zobacz sesje",
|
|
145
|
+
"auth.actions.viewPermissions": "Zobacz uprawnienia"
|
|
99
146
|
}
|
|
@@ -16,6 +16,7 @@ import { DEFAULT_ENCRYPTION_MAPS } from '@open-mercato/core/modules/entities/lib
|
|
|
16
16
|
import { createKmsService } from '@open-mercato/shared/lib/encryption/kms'
|
|
17
17
|
import { TenantDataEncryptionService } from '@open-mercato/shared/lib/encryption/tenantDataEncryptionService'
|
|
18
18
|
import { findWithDecryption } from '@open-mercato/shared/lib/encryption/find'
|
|
19
|
+
import { parseBooleanToken } from '@open-mercato/shared/lib/boolean'
|
|
19
20
|
|
|
20
21
|
const DEFAULT_ROLE_NAMES = ['employee', 'admin', 'superadmin'] as const
|
|
21
22
|
const DEMO_SUPERADMIN_EMAIL = 'superadmin@acme.com'
|
|
@@ -87,6 +88,11 @@ type PrimaryUserInput = {
|
|
|
87
88
|
confirm?: boolean
|
|
88
89
|
}
|
|
89
90
|
|
|
91
|
+
const DERIVED_EMAIL_ENV = {
|
|
92
|
+
admin: 'OM_INIT_ADMIN_EMAIL',
|
|
93
|
+
employee: 'OM_INIT_EMPLOYEE_EMAIL',
|
|
94
|
+
} as const
|
|
95
|
+
|
|
90
96
|
export type SetupInitialTenantOptions = {
|
|
91
97
|
orgName: string
|
|
92
98
|
primaryUser: PrimaryUserInput
|
|
@@ -170,16 +176,28 @@ export async function setupInitialTenant(
|
|
|
170
176
|
})
|
|
171
177
|
|
|
172
178
|
if (!existingUser) {
|
|
173
|
-
const baseUsers: Array<{
|
|
179
|
+
const baseUsers: Array<{
|
|
180
|
+
email: string
|
|
181
|
+
roles: string[]
|
|
182
|
+
name?: string | null
|
|
183
|
+
passwordHash?: string | null
|
|
184
|
+
}> = [
|
|
174
185
|
{ email: primaryUser.email, roles: primaryRoles, name: resolvePrimaryName(primaryUser) },
|
|
175
186
|
]
|
|
176
187
|
if (includeDerivedUsers) {
|
|
177
|
-
const [
|
|
178
|
-
const
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
188
|
+
const [, domain] = String(primaryUser.email).split('@')
|
|
189
|
+
const adminOverride = readEnvValue(DERIVED_EMAIL_ENV.admin)
|
|
190
|
+
const employeeOverride = readEnvValue(DERIVED_EMAIL_ENV.employee)
|
|
191
|
+
const adminEmail = adminOverride ?? (domain ? `admin@${domain}` : '')
|
|
192
|
+
const employeeEmail = employeeOverride ?? (domain ? `employee@${domain}` : '')
|
|
193
|
+
const adminPassword = readEnvValue('OM_INIT_ADMIN_PASSWORD')
|
|
194
|
+
const employeePassword = readEnvValue('OM_INIT_EMPLOYEE_PASSWORD')
|
|
195
|
+
const adminPasswordHash = adminPassword ? await resolvePasswordHash({ email: adminEmail, password: adminPassword }) : null
|
|
196
|
+
const employeePasswordHash = employeePassword
|
|
197
|
+
? await resolvePasswordHash({ email: employeeEmail, password: employeePassword })
|
|
198
|
+
: null
|
|
199
|
+
addUniqueBaseUser(baseUsers, { email: adminEmail, roles: ['admin'], passwordHash: adminPasswordHash })
|
|
200
|
+
addUniqueBaseUser(baseUsers, { email: employeeEmail, roles: ['employee'], passwordHash: employeePasswordHash })
|
|
183
201
|
}
|
|
184
202
|
const passwordHash = await resolvePasswordHash(primaryUser)
|
|
185
203
|
|
|
@@ -271,13 +289,14 @@ export async function setupInitialTenant(
|
|
|
271
289
|
}
|
|
272
290
|
|
|
273
291
|
for (const base of baseUsers) {
|
|
292
|
+
const resolvedPasswordHash = base.passwordHash ?? passwordHash
|
|
274
293
|
let user = await tem.findOne(User, { email: base.email })
|
|
275
294
|
const confirm = primaryUser.confirm ?? true
|
|
276
295
|
const encryptedPayload = encryptionService
|
|
277
296
|
? await encryptionService.encryptEntityPayload('auth:user', { email: base.email }, tenantId, organizationId)
|
|
278
297
|
: { email: base.email, emailHash: computeEmailHash(base.email) }
|
|
279
298
|
if (user) {
|
|
280
|
-
user.passwordHash =
|
|
299
|
+
user.passwordHash = resolvedPasswordHash
|
|
281
300
|
user.organizationId = organizationId
|
|
282
301
|
user.tenantId = tenantId
|
|
283
302
|
if (isTenantDataEncryptionEnabled()) {
|
|
@@ -292,7 +311,7 @@ export async function setupInitialTenant(
|
|
|
292
311
|
user = tem.create(User, {
|
|
293
312
|
email: (encryptedPayload as any).email ?? base.email,
|
|
294
313
|
emailHash: isTenantDataEncryptionEnabled() ? (encryptedPayload as any).emailHash ?? computeEmailHash(base.email) : undefined,
|
|
295
|
-
passwordHash,
|
|
314
|
+
passwordHash: resolvedPasswordHash,
|
|
296
315
|
organizationId,
|
|
297
316
|
tenantId,
|
|
298
317
|
name: base.name ?? undefined,
|
|
@@ -340,6 +359,34 @@ function resolvePrimaryName(input: PrimaryUserInput): string | null {
|
|
|
340
359
|
return null
|
|
341
360
|
}
|
|
342
361
|
|
|
362
|
+
function readEnvValue(key: string): string | undefined {
|
|
363
|
+
const value = process.env[key]
|
|
364
|
+
if (typeof value !== 'string') return undefined
|
|
365
|
+
const trimmed = value.trim()
|
|
366
|
+
return trimmed.length > 0 ? trimmed : undefined
|
|
367
|
+
}
|
|
368
|
+
|
|
369
|
+
function addUniqueBaseUser(
|
|
370
|
+
baseUsers: Array<{ email: string; roles: string[]; name?: string | null; passwordHash?: string | null }>,
|
|
371
|
+
entry: { email: string; roles: string[]; name?: string | null; passwordHash?: string | null },
|
|
372
|
+
) {
|
|
373
|
+
if (!entry.email) return
|
|
374
|
+
const normalized = entry.email.toLowerCase()
|
|
375
|
+
if (baseUsers.some((user) => user.email.toLowerCase() === normalized)) return
|
|
376
|
+
baseUsers.push(entry)
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
function isDemoModeEnabled(): boolean {
|
|
380
|
+
const parsed = parseBooleanToken(process.env.DEMO_MODE ?? '')
|
|
381
|
+
return parsed === false ? false : true
|
|
382
|
+
}
|
|
383
|
+
|
|
384
|
+
function shouldKeepDemoSuperadminDuringInit(): boolean {
|
|
385
|
+
if (process.env.OM_INIT_FLOW !== 'true') return false
|
|
386
|
+
if (!readEnvValue('OM_INIT_SUPERADMIN_EMAIL')) return false
|
|
387
|
+
return isDemoModeEnabled()
|
|
388
|
+
}
|
|
389
|
+
|
|
343
390
|
async function resolvePasswordHash(input: PrimaryUserInput): Promise<string | null> {
|
|
344
391
|
if (typeof input.hashedPassword === 'string') return input.hashedPassword
|
|
345
392
|
if (input.password) return hash(input.password, 10)
|
|
@@ -396,6 +443,7 @@ async function ensureDefaultRoleAcls(
|
|
|
396
443
|
'dashboards.admin.assign-widgets',
|
|
397
444
|
'analytics.view',
|
|
398
445
|
'api_keys.*',
|
|
446
|
+
'notifications.manage',
|
|
399
447
|
'perspectives.use',
|
|
400
448
|
'perspectives.role_defaults',
|
|
401
449
|
'business_rules.*',
|
|
@@ -487,6 +535,7 @@ async function ensureRoleAclFor(
|
|
|
487
535
|
|
|
488
536
|
async function deactivateDemoSuperAdminIfSelfOnboardingEnabled(em: EntityManager) {
|
|
489
537
|
if (process.env.SELF_SERVICE_ONBOARDING_ENABLED !== 'true') return
|
|
538
|
+
if (shouldKeepDemoSuperadminDuringInit()) return
|
|
490
539
|
try {
|
|
491
540
|
const user = await em.findOne(User, { email: DEMO_SUPERADMIN_EMAIL })
|
|
492
541
|
if (!user) return
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import type { NotificationTypeDefinition } from '@open-mercato/shared/modules/notifications/types'
|
|
2
|
+
|
|
3
|
+
export const notificationTypes: NotificationTypeDefinition[] = [
|
|
4
|
+
{
|
|
5
|
+
type: 'auth.password_reset.requested',
|
|
6
|
+
module: 'auth',
|
|
7
|
+
titleKey: 'auth.notifications.passwordReset.requested.title',
|
|
8
|
+
bodyKey: 'auth.notifications.passwordReset.requested.body',
|
|
9
|
+
icon: 'key',
|
|
10
|
+
severity: 'info',
|
|
11
|
+
actions: [
|
|
12
|
+
{
|
|
13
|
+
id: 'view',
|
|
14
|
+
labelKey: 'common.view',
|
|
15
|
+
variant: 'outline',
|
|
16
|
+
href: '/backend/auth/profile',
|
|
17
|
+
icon: 'external-link',
|
|
18
|
+
},
|
|
19
|
+
],
|
|
20
|
+
linkHref: '/backend/auth/profile',
|
|
21
|
+
expiresAfterHours: 24,
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
type: 'auth.password_reset.completed',
|
|
25
|
+
module: 'auth',
|
|
26
|
+
titleKey: 'auth.notifications.passwordReset.completed.title',
|
|
27
|
+
bodyKey: 'auth.notifications.passwordReset.completed.body',
|
|
28
|
+
icon: 'check-circle',
|
|
29
|
+
severity: 'success',
|
|
30
|
+
actions: [],
|
|
31
|
+
expiresAfterHours: 72,
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
type: 'auth.account.locked',
|
|
35
|
+
module: 'auth',
|
|
36
|
+
titleKey: 'auth.notifications.account.locked.title',
|
|
37
|
+
bodyKey: 'auth.notifications.account.locked.body',
|
|
38
|
+
icon: 'lock',
|
|
39
|
+
severity: 'warning',
|
|
40
|
+
actions: [
|
|
41
|
+
{
|
|
42
|
+
id: 'contact_support',
|
|
43
|
+
labelKey: 'auth.actions.contactSupport',
|
|
44
|
+
variant: 'default',
|
|
45
|
+
href: '/backend/support',
|
|
46
|
+
icon: 'mail',
|
|
47
|
+
},
|
|
48
|
+
],
|
|
49
|
+
linkHref: '/backend/support',
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
type: 'auth.login.new_device',
|
|
53
|
+
module: 'auth',
|
|
54
|
+
titleKey: 'auth.notifications.login.newDevice.title',
|
|
55
|
+
bodyKey: 'auth.notifications.login.newDevice.body',
|
|
56
|
+
icon: 'smartphone',
|
|
57
|
+
severity: 'info',
|
|
58
|
+
actions: [
|
|
59
|
+
{
|
|
60
|
+
id: 'view_sessions',
|
|
61
|
+
labelKey: 'auth.actions.viewSessions',
|
|
62
|
+
variant: 'outline',
|
|
63
|
+
href: '/backend/auth/sessions',
|
|
64
|
+
icon: 'list',
|
|
65
|
+
},
|
|
66
|
+
],
|
|
67
|
+
linkHref: '/backend/auth/sessions',
|
|
68
|
+
expiresAfterHours: 168, // 7 days
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
type: 'auth.role.assigned',
|
|
72
|
+
module: 'auth',
|
|
73
|
+
titleKey: 'auth.notifications.role.assigned.title',
|
|
74
|
+
bodyKey: 'auth.notifications.role.assigned.body',
|
|
75
|
+
icon: 'user-plus',
|
|
76
|
+
severity: 'success',
|
|
77
|
+
actions: [
|
|
78
|
+
{
|
|
79
|
+
id: 'view_permissions',
|
|
80
|
+
labelKey: 'auth.actions.viewPermissions',
|
|
81
|
+
variant: 'outline',
|
|
82
|
+
href: '/backend/auth/profile',
|
|
83
|
+
icon: 'shield',
|
|
84
|
+
},
|
|
85
|
+
],
|
|
86
|
+
linkHref: '/backend/auth/profile',
|
|
87
|
+
expiresAfterHours: 168,
|
|
88
|
+
},
|
|
89
|
+
{
|
|
90
|
+
type: 'auth.role.revoked',
|
|
91
|
+
module: 'auth',
|
|
92
|
+
titleKey: 'auth.notifications.role.revoked.title',
|
|
93
|
+
bodyKey: 'auth.notifications.role.revoked.body',
|
|
94
|
+
icon: 'user-minus',
|
|
95
|
+
severity: 'warning',
|
|
96
|
+
actions: [
|
|
97
|
+
{
|
|
98
|
+
id: 'view_profile',
|
|
99
|
+
labelKey: 'common.view',
|
|
100
|
+
variant: 'outline',
|
|
101
|
+
href: '/backend/auth/profile',
|
|
102
|
+
},
|
|
103
|
+
],
|
|
104
|
+
linkHref: '/backend/auth/profile',
|
|
105
|
+
expiresAfterHours: 168,
|
|
106
|
+
},
|
|
107
|
+
]
|
|
108
|
+
|
|
109
|
+
export default notificationTypes
|
|
@@ -18,6 +18,29 @@ export class AuthService {
|
|
|
18
18
|
} as any)
|
|
19
19
|
}
|
|
20
20
|
|
|
21
|
+
async findUsersByEmail(email: string) {
|
|
22
|
+
const emailHash = computeEmailHash(email)
|
|
23
|
+
return this.em.find(User, {
|
|
24
|
+
deletedAt: null,
|
|
25
|
+
$or: [
|
|
26
|
+
{ email },
|
|
27
|
+
{ emailHash },
|
|
28
|
+
],
|
|
29
|
+
} as any)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
async findUserByEmailAndTenant(email: string, tenantId: string) {
|
|
33
|
+
const emailHash = computeEmailHash(email)
|
|
34
|
+
return this.em.findOne(User, {
|
|
35
|
+
tenantId,
|
|
36
|
+
deletedAt: null,
|
|
37
|
+
$or: [
|
|
38
|
+
{ email },
|
|
39
|
+
{ emailHash },
|
|
40
|
+
],
|
|
41
|
+
} as any)
|
|
42
|
+
}
|
|
43
|
+
|
|
21
44
|
async verifyPassword(user: User, password: string) {
|
|
22
45
|
if (!user.passwordHash) return false
|
|
23
46
|
return compare(password, user.passwordHash)
|
|
@@ -75,15 +98,15 @@ export class AuthService {
|
|
|
75
98
|
return { user, token }
|
|
76
99
|
}
|
|
77
100
|
|
|
78
|
-
async confirmPasswordReset(token: string, newPassword: string) {
|
|
101
|
+
async confirmPasswordReset(token: string, newPassword: string): Promise<User | null> {
|
|
79
102
|
const now = new Date()
|
|
80
103
|
const row = await this.em.findOne(PasswordReset, { token })
|
|
81
|
-
if (!row || (row.usedAt && row.usedAt <= now) || row.expiresAt <= now) return
|
|
104
|
+
if (!row || (row.usedAt && row.usedAt <= now) || row.expiresAt <= now) return null
|
|
82
105
|
const user = await this.em.findOne(User, { id: row.user.id })
|
|
83
|
-
if (!user) return
|
|
106
|
+
if (!user) return null
|
|
84
107
|
user.passwordHash = await hash(newPassword, 10)
|
|
85
108
|
row.usedAt = new Date()
|
|
86
109
|
await this.em.flush()
|
|
87
|
-
return
|
|
110
|
+
return user
|
|
88
111
|
}
|
|
89
112
|
}
|
|
@@ -4,6 +4,7 @@ import type { OpenApiRouteDoc } from '@open-mercato/shared/lib/openapi'
|
|
|
4
4
|
import { getAuthFromRequest } from '@open-mercato/shared/lib/auth/server'
|
|
5
5
|
import { createRequestContainer } from '@open-mercato/shared/lib/di/container'
|
|
6
6
|
import type { EntityManager } from '@mikro-orm/postgresql'
|
|
7
|
+
import type { EventBus } from '@open-mercato/events'
|
|
7
8
|
import { ruleEngineContextSchema } from '../../data/validators'
|
|
8
9
|
import * as ruleEngine from '../../lib/rule-engine'
|
|
9
10
|
|
|
@@ -46,6 +47,12 @@ export async function POST(req: Request) {
|
|
|
46
47
|
|
|
47
48
|
const container = await createRequestContainer()
|
|
48
49
|
const em = container.resolve('em') as EntityManager
|
|
50
|
+
let eventBus: EventBus | null = null
|
|
51
|
+
try {
|
|
52
|
+
eventBus = container.resolve('eventBus') as EventBus
|
|
53
|
+
} catch {
|
|
54
|
+
eventBus = null
|
|
55
|
+
}
|
|
49
56
|
|
|
50
57
|
let body: any
|
|
51
58
|
try {
|
|
@@ -85,7 +92,7 @@ export async function POST(req: Request) {
|
|
|
85
92
|
}
|
|
86
93
|
|
|
87
94
|
try {
|
|
88
|
-
const result = await ruleEngine.executeRules(em, context)
|
|
95
|
+
const result = await ruleEngine.executeRules(em, context, { eventBus })
|
|
89
96
|
|
|
90
97
|
const response = {
|
|
91
98
|
allowed: result.allowed,
|
|
@@ -264,14 +264,17 @@ export default function RulesListPage() {
|
|
|
264
264
|
<RowActions
|
|
265
265
|
items={[
|
|
266
266
|
{
|
|
267
|
+
id: 'edit',
|
|
267
268
|
label: t('common.edit'),
|
|
268
269
|
href: `/backend/rules/${row.original.id}`,
|
|
269
270
|
},
|
|
270
271
|
{
|
|
272
|
+
id: row.original.enabled ? 'disable' : 'enable',
|
|
271
273
|
label: row.original.enabled ? t('common.disable') : t('common.enable'),
|
|
272
274
|
onSelect: () => handleToggleEnabled(row.original.id, row.original.enabled),
|
|
273
275
|
},
|
|
274
276
|
{
|
|
277
|
+
id: 'duplicate',
|
|
275
278
|
label: t('common.duplicate'),
|
|
276
279
|
onSelect: () => {
|
|
277
280
|
// TODO: Implement duplicate functionality in Step 5.2
|
|
@@ -279,6 +282,7 @@ export default function RulesListPage() {
|
|
|
279
282
|
},
|
|
280
283
|
},
|
|
281
284
|
{
|
|
285
|
+
id: 'delete',
|
|
282
286
|
label: t('common.delete'),
|
|
283
287
|
onSelect: () => handleDelete(row.original.id, row.original.ruleName),
|
|
284
288
|
destructive: true,
|
|
@@ -196,14 +196,17 @@ export default function RuleSetsListPage() {
|
|
|
196
196
|
<RowActions
|
|
197
197
|
items={[
|
|
198
198
|
{
|
|
199
|
+
id: 'edit',
|
|
199
200
|
label: t('common.edit'),
|
|
200
201
|
href: `/backend/sets/${row.original.id}`,
|
|
201
202
|
},
|
|
202
203
|
{
|
|
204
|
+
id: row.original.enabled ? 'disable' : 'enable',
|
|
203
205
|
label: row.original.enabled ? t('common.disable') : t('common.enable'),
|
|
204
206
|
onSelect: () => handleToggleEnabled(row.original.id, row.original.enabled),
|
|
205
207
|
},
|
|
206
208
|
{
|
|
209
|
+
id: 'delete',
|
|
207
210
|
label: t('common.delete'),
|
|
208
211
|
onSelect: () => handleDelete(row.original.id, row.original.setName),
|
|
209
212
|
destructive: true,
|
|
@@ -44,6 +44,7 @@ const seedGuardRules: ModuleCli = {
|
|
|
44
44
|
const rulesPath = path.join(__dirname, '../workflows/examples', 'guard-rules-example.json')
|
|
45
45
|
const rulesData = JSON.parse(fs.readFileSync(rulesPath, 'utf8'))
|
|
46
46
|
|
|
47
|
+
console.log('🧠 Seeding guard rules...')
|
|
47
48
|
let seededCount = 0
|
|
48
49
|
let skippedCount = 0
|
|
49
50
|
|
|
@@ -73,7 +74,7 @@ const seedGuardRules: ModuleCli = {
|
|
|
73
74
|
seededCount++
|
|
74
75
|
}
|
|
75
76
|
|
|
76
|
-
console.log(`\n
|
|
77
|
+
console.log(`\n✅ Guard rules seeding complete:`)
|
|
77
78
|
console.log(` - Seeded: ${seededCount}`)
|
|
78
79
|
console.log(` - Skipped (existing): ${skippedCount}`)
|
|
79
80
|
console.log(` - Total: ${rulesData.length}`)
|
|
@@ -287,43 +287,3 @@ export const ruleDiscoveryOptionsSchema = z.object({
|
|
|
287
287
|
})
|
|
288
288
|
|
|
289
289
|
export type RuleDiscoveryOptionsInput = z.infer<typeof ruleDiscoveryOptionsSchema>
|
|
290
|
-
|
|
291
|
-
// Direct Rule Execution Context Schema (for executing a specific rule by ID)
|
|
292
|
-
export const directRuleExecutionContextSchema = z.object({
|
|
293
|
-
ruleId: z.uuid('ruleId must be a valid UUID'),
|
|
294
|
-
data: z.any(),
|
|
295
|
-
user: z.looseObject({
|
|
296
|
-
id: z.string().optional(),
|
|
297
|
-
email: z.string().optional(),
|
|
298
|
-
role: z.string().optional(),
|
|
299
|
-
}).optional(),
|
|
300
|
-
tenantId: z.uuid('tenantId must be a valid UUID'),
|
|
301
|
-
organizationId: z.uuid('organizationId must be a valid UUID'),
|
|
302
|
-
executedBy: z.string().optional(),
|
|
303
|
-
dryRun: z.boolean().optional(),
|
|
304
|
-
entityType: z.string().optional(),
|
|
305
|
-
entityId: z.string().optional(),
|
|
306
|
-
eventType: z.string().optional(),
|
|
307
|
-
})
|
|
308
|
-
|
|
309
|
-
export type DirectRuleExecutionContextInput = z.infer<typeof directRuleExecutionContextSchema>
|
|
310
|
-
|
|
311
|
-
// Rule ID Execution Context Schema (for executing a specific rule by its string rule_id identifier)
|
|
312
|
-
export const ruleIdExecutionContextSchema = z.object({
|
|
313
|
-
ruleId: z.string().min(1, 'ruleId must be a non-empty string').max(50),
|
|
314
|
-
data: z.any(),
|
|
315
|
-
user: z.looseObject({
|
|
316
|
-
id: z.string().optional(),
|
|
317
|
-
email: z.string().optional(),
|
|
318
|
-
role: z.string().optional(),
|
|
319
|
-
}).optional(),
|
|
320
|
-
tenantId: z.uuid('tenantId must be a valid UUID'),
|
|
321
|
-
organizationId: z.uuid('organizationId must be a valid UUID'),
|
|
322
|
-
executedBy: z.string().optional(),
|
|
323
|
-
dryRun: z.boolean().optional(),
|
|
324
|
-
entityType: z.string().optional(),
|
|
325
|
-
entityId: z.string().optional(),
|
|
326
|
-
eventType: z.string().optional(),
|
|
327
|
-
})
|
|
328
|
-
|
|
329
|
-
export type RuleIdExecutionContextInput = z.infer<typeof ruleIdExecutionContextSchema>
|
|
@@ -367,5 +367,7 @@
|
|
|
367
367
|
"business_rules.components.conditionRow.field.comparisonPlaceholder": "e.g., user.role",
|
|
368
368
|
"business_rules.components.conditionRow.value.help": "Use JSON for arrays: [\"a\",\"b\"]",
|
|
369
369
|
"business_rules.components.conditionRow.field.comparisonHelp": "Field path to compare with",
|
|
370
|
-
"business_rules.components.conditionRow.deleteCondition": "Delete condition"
|
|
370
|
+
"business_rules.components.conditionRow.deleteCondition": "Delete condition",
|
|
371
|
+
"businessRules.notifications.rule.executionFailed.title": "Business Rule Failed",
|
|
372
|
+
"businessRules.notifications.rule.executionFailed.body": "Rule \"{ruleName}\" failed to execute{entityType, select, other { on {entityType}}}: {errorMessage}"
|
|
371
373
|
}
|
|
@@ -8,28 +8,3 @@ export const metadata: ModuleInfo = {
|
|
|
8
8
|
author: 'Patryk Lewczuk',
|
|
9
9
|
license: 'Proprietary',
|
|
10
10
|
}
|
|
11
|
-
|
|
12
|
-
// Export rule engine types and functions for programmatic usage
|
|
13
|
-
export {
|
|
14
|
-
executeRules,
|
|
15
|
-
executeRuleById,
|
|
16
|
-
executeRuleByRuleId,
|
|
17
|
-
executeSingleRule,
|
|
18
|
-
findApplicableRules,
|
|
19
|
-
logRuleExecution,
|
|
20
|
-
type RuleEngineContext,
|
|
21
|
-
type RuleEngineResult,
|
|
22
|
-
type RuleExecutionResult,
|
|
23
|
-
type RuleDiscoveryOptions,
|
|
24
|
-
type DirectRuleExecutionContext,
|
|
25
|
-
type DirectRuleExecutionResult,
|
|
26
|
-
type RuleIdExecutionContext,
|
|
27
|
-
} from './lib/rule-engine'
|
|
28
|
-
|
|
29
|
-
// Export validator schemas
|
|
30
|
-
export {
|
|
31
|
-
directRuleExecutionContextSchema,
|
|
32
|
-
ruleIdExecutionContextSchema,
|
|
33
|
-
type DirectRuleExecutionContextInput,
|
|
34
|
-
type RuleIdExecutionContextInput,
|
|
35
|
-
} from './data/validators'
|