@unifiedcommerce/core 0.4.2 → 0.4.4
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/interfaces/rest/index.d.ts.map +1 -1
- package/dist/interfaces/rest/index.js +4 -17
- package/dist/runtime/server.d.ts.map +1 -1
- package/dist/runtime/server.js +33 -0
- package/package.json +1 -1
- package/src/interfaces/rest/index.ts +4 -18
- package/src/runtime/server.ts +33 -0
- package/dist/adapters/console-email.d.ts +0 -23
- package/dist/adapters/console-email.d.ts.map +0 -1
- package/dist/adapters/console-email.js +0 -38
- package/dist/auth/access.d.ts +0 -101
- package/dist/auth/access.d.ts.map +0 -1
- package/dist/auth/access.js +0 -128
- package/dist/auth/auth-schema.d.ts +0 -1475
- package/dist/auth/auth-schema.d.ts.map +0 -1
- package/dist/auth/auth-schema.js +0 -124
- package/dist/auth/middleware.d.ts +0 -5
- package/dist/auth/middleware.d.ts.map +0 -1
- package/dist/auth/middleware.js +0 -141
- package/dist/auth/org.d.ts +0 -22
- package/dist/auth/org.d.ts.map +0 -1
- package/dist/auth/org.js +0 -36
- package/dist/auth/permissions.d.ts +0 -4
- package/dist/auth/permissions.d.ts.map +0 -1
- package/dist/auth/permissions.js +0 -24
- package/dist/auth/setup.d.ts +0 -29
- package/dist/auth/setup.d.ts.map +0 -1
- package/dist/auth/setup.js +0 -117
- package/dist/auth/system-actor.d.ts +0 -7
- package/dist/auth/system-actor.d.ts.map +0 -1
- package/dist/auth/system-actor.js +0 -17
- package/dist/auth/types.d.ts +0 -11
- package/dist/auth/types.d.ts.map +0 -1
- package/dist/auth/types.js +0 -1
- package/dist/config/defaults.d.ts +0 -3
- package/dist/config/defaults.d.ts.map +0 -1
- package/dist/config/defaults.js +0 -80
- package/dist/config/define-config.d.ts +0 -9
- package/dist/config/define-config.d.ts.map +0 -1
- package/dist/config/define-config.js +0 -44
- package/dist/config/types.d.ts +0 -327
- package/dist/config/types.d.ts.map +0 -1
- package/dist/config/types.js +0 -1
- package/dist/generated/plugin-manifest.d.ts +0 -48
- package/dist/generated/plugin-manifest.d.ts.map +0 -1
- package/dist/generated/plugin-manifest.js +0 -20
- package/dist/hooks/checkout-completion.d.ts +0 -58
- package/dist/hooks/checkout-completion.d.ts.map +0 -1
- package/dist/hooks/checkout-completion.js +0 -137
- package/dist/hooks/checkout.d.ts +0 -99
- package/dist/hooks/checkout.d.ts.map +0 -1
- package/dist/hooks/checkout.js +0 -317
- package/dist/hooks/order-emails.d.ts +0 -16
- package/dist/hooks/order-emails.d.ts.map +0 -1
- package/dist/hooks/order-emails.js +0 -44
- package/dist/index.d.ts +0 -77
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -45
- package/dist/interfaces/mcp/agent-prompt.d.ts +0 -16
- package/dist/interfaces/mcp/agent-prompt.d.ts.map +0 -1
- package/dist/interfaces/mcp/agent-prompt.js +0 -172
- package/dist/interfaces/mcp/context-enrichment.d.ts +0 -39
- package/dist/interfaces/mcp/context-enrichment.d.ts.map +0 -1
- package/dist/interfaces/mcp/context-enrichment.js +0 -119
- package/dist/interfaces/mcp/server.d.ts +0 -5
- package/dist/interfaces/mcp/server.d.ts.map +0 -1
- package/dist/interfaces/mcp/server.js +0 -30
- package/dist/interfaces/mcp/tool-builder.d.ts +0 -120
- package/dist/interfaces/mcp/tool-builder.d.ts.map +0 -1
- package/dist/interfaces/mcp/tool-builder.js +0 -224
- package/dist/interfaces/mcp/tools/analytics.d.ts +0 -42
- package/dist/interfaces/mcp/tools/analytics.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/analytics.js +0 -70
- package/dist/interfaces/mcp/tools/cart.d.ts +0 -14
- package/dist/interfaces/mcp/tools/cart.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/cart.js +0 -47
- package/dist/interfaces/mcp/tools/catalog.d.ts +0 -53
- package/dist/interfaces/mcp/tools/catalog.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/catalog.js +0 -284
- package/dist/interfaces/mcp/tools/index.d.ts +0 -3
- package/dist/interfaces/mcp/tools/index.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/index.js +0 -20
- package/dist/interfaces/mcp/tools/inventory.d.ts +0 -27
- package/dist/interfaces/mcp/tools/inventory.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/inventory.js +0 -143
- package/dist/interfaces/mcp/tools/orders.d.ts +0 -18
- package/dist/interfaces/mcp/tools/orders.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/orders.js +0 -82
- package/dist/interfaces/mcp/tools/pricing.d.ts +0 -29
- package/dist/interfaces/mcp/tools/pricing.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/pricing.js +0 -90
- package/dist/interfaces/mcp/tools/promotions.d.ts +0 -44
- package/dist/interfaces/mcp/tools/promotions.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/promotions.js +0 -109
- package/dist/interfaces/mcp/tools/registry.d.ts +0 -32
- package/dist/interfaces/mcp/tools/registry.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/registry.js +0 -55
- package/dist/interfaces/mcp/tools/search.d.ts +0 -14
- package/dist/interfaces/mcp/tools/search.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/search.js +0 -39
- package/dist/interfaces/mcp/tools/webhooks.d.ts +0 -15
- package/dist/interfaces/mcp/tools/webhooks.d.ts.map +0 -1
- package/dist/interfaces/mcp/tools/webhooks.js +0 -48
- package/dist/interfaces/mcp/transport.d.ts +0 -20
- package/dist/interfaces/mcp/transport.d.ts.map +0 -1
- package/dist/interfaces/mcp/transport.js +0 -99
- package/dist/interfaces/rest/customer-portal.d.ts +0 -5
- package/dist/interfaces/rest/customer-portal.d.ts.map +0 -1
- package/dist/interfaces/rest/customer-portal.js +0 -206
- package/dist/interfaces/rest/router.d.ts +0 -164
- package/dist/interfaces/rest/router.d.ts.map +0 -1
- package/dist/interfaces/rest/router.js +0 -259
- package/dist/interfaces/rest/routes/admin-jobs.d.ts +0 -5
- package/dist/interfaces/rest/routes/admin-jobs.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/admin-jobs.js +0 -48
- package/dist/interfaces/rest/routes/audit.d.ts +0 -5
- package/dist/interfaces/rest/routes/audit.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/audit.js +0 -43
- package/dist/interfaces/rest/routes/carts.d.ts +0 -5
- package/dist/interfaces/rest/routes/carts.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/carts.js +0 -55
- package/dist/interfaces/rest/routes/catalog.d.ts +0 -5
- package/dist/interfaces/rest/routes/catalog.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/catalog.js +0 -256
- package/dist/interfaces/rest/routes/checkout.d.ts +0 -5
- package/dist/interfaces/rest/routes/checkout.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/checkout.js +0 -216
- package/dist/interfaces/rest/routes/customers.d.ts +0 -5
- package/dist/interfaces/rest/routes/customers.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/customers.js +0 -74
- package/dist/interfaces/rest/routes/entity-aliases.d.ts +0 -18
- package/dist/interfaces/rest/routes/entity-aliases.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/entity-aliases.js +0 -39
- package/dist/interfaces/rest/routes/inventory.d.ts +0 -5
- package/dist/interfaces/rest/routes/inventory.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/inventory.js +0 -72
- package/dist/interfaces/rest/routes/media.d.ts +0 -5
- package/dist/interfaces/rest/routes/media.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/media.js +0 -65
- package/dist/interfaces/rest/routes/orders.d.ts +0 -5
- package/dist/interfaces/rest/routes/orders.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/orders.js +0 -64
- package/dist/interfaces/rest/routes/payments.d.ts +0 -5
- package/dist/interfaces/rest/routes/payments.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/payments.js +0 -45
- package/dist/interfaces/rest/routes/pricing.d.ts +0 -5
- package/dist/interfaces/rest/routes/pricing.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/pricing.js +0 -48
- package/dist/interfaces/rest/routes/promotions.d.ts +0 -5
- package/dist/interfaces/rest/routes/promotions.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/promotions.js +0 -76
- package/dist/interfaces/rest/routes/search.d.ts +0 -5
- package/dist/interfaces/rest/routes/search.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/search.js +0 -60
- package/dist/interfaces/rest/routes/webhooks.d.ts +0 -5
- package/dist/interfaces/rest/routes/webhooks.d.ts.map +0 -1
- package/dist/interfaces/rest/routes/webhooks.js +0 -39
- package/dist/interfaces/rest/schemas/admin-jobs.d.ts +0 -327
- package/dist/interfaces/rest/schemas/admin-jobs.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/admin-jobs.js +0 -37
- package/dist/interfaces/rest/schemas/audit.d.ts +0 -59
- package/dist/interfaces/rest/schemas/audit.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/audit.js +0 -43
- package/dist/interfaces/rest/schemas/carts.d.ts +0 -1456
- package/dist/interfaces/rest/schemas/carts.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/carts.js +0 -109
- package/dist/interfaces/rest/schemas/catalog.d.ts +0 -5452
- package/dist/interfaces/rest/schemas/catalog.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/catalog.js +0 -397
- package/dist/interfaces/rest/schemas/checkout.d.ts +0 -160
- package/dist/interfaces/rest/schemas/checkout.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/checkout.js +0 -60
- package/dist/interfaces/rest/schemas/customer-portal.d.ts +0 -2203
- package/dist/interfaces/rest/schemas/customer-portal.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/customer-portal.js +0 -177
- package/dist/interfaces/rest/schemas/customers.d.ts +0 -422
- package/dist/interfaces/rest/schemas/customers.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/customers.js +0 -150
- package/dist/interfaces/rest/schemas/inventory.d.ts +0 -561
- package/dist/interfaces/rest/schemas/inventory.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/inventory.js +0 -148
- package/dist/interfaces/rest/schemas/media.d.ts +0 -303
- package/dist/interfaces/rest/schemas/media.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/media.js +0 -69
- package/dist/interfaces/rest/schemas/orders.d.ts +0 -1792
- package/dist/interfaces/rest/schemas/orders.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/orders.js +0 -93
- package/dist/interfaces/rest/schemas/pricing.d.ts +0 -256
- package/dist/interfaces/rest/schemas/pricing.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/pricing.js +0 -72
- package/dist/interfaces/rest/schemas/promotions.d.ts +0 -363
- package/dist/interfaces/rest/schemas/promotions.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/promotions.js +0 -98
- package/dist/interfaces/rest/schemas/responses.d.ts +0 -4086
- package/dist/interfaces/rest/schemas/responses.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/responses.js +0 -74
- package/dist/interfaces/rest/schemas/search.d.ts +0 -247
- package/dist/interfaces/rest/schemas/search.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/search.js +0 -55
- package/dist/interfaces/rest/schemas/shared.d.ts +0 -95
- package/dist/interfaces/rest/schemas/shared.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/shared.js +0 -51
- package/dist/interfaces/rest/schemas/webhooks.d.ts +0 -221
- package/dist/interfaces/rest/schemas/webhooks.d.ts.map +0 -1
- package/dist/interfaces/rest/schemas/webhooks.js +0 -62
- package/dist/interfaces/rest/utils.d.ts +0 -45
- package/dist/interfaces/rest/utils.d.ts.map +0 -1
- package/dist/interfaces/rest/utils.js +0 -71
- package/dist/interfaces/rest/webhook-router.d.ts +0 -41
- package/dist/interfaces/rest/webhook-router.d.ts.map +0 -1
- package/dist/interfaces/rest/webhook-router.js +0 -36
- package/dist/kernel/compensation/executor.d.ts +0 -21
- package/dist/kernel/compensation/executor.d.ts.map +0 -1
- package/dist/kernel/compensation/executor.js +0 -36
- package/dist/kernel/compensation/types.d.ts +0 -25
- package/dist/kernel/compensation/types.d.ts.map +0 -1
- package/dist/kernel/compensation/types.js +0 -1
- package/dist/kernel/database/adapter.d.ts +0 -18
- package/dist/kernel/database/adapter.d.ts.map +0 -1
- package/dist/kernel/database/adapter.js +0 -3
- package/dist/kernel/database/drizzle-db.d.ts +0 -49
- package/dist/kernel/database/drizzle-db.d.ts.map +0 -1
- package/dist/kernel/database/drizzle-db.js +0 -20
- package/dist/kernel/database/migrate.d.ts +0 -38
- package/dist/kernel/database/migrate.d.ts.map +0 -1
- package/dist/kernel/database/migrate.js +0 -61
- package/dist/kernel/database/plugin-types.d.ts +0 -32
- package/dist/kernel/database/plugin-types.d.ts.map +0 -1
- package/dist/kernel/database/plugin-types.js +0 -10
- package/dist/kernel/database/schema.d.ts +0 -24
- package/dist/kernel/database/schema.d.ts.map +0 -1
- package/dist/kernel/database/schema.js +0 -36
- package/dist/kernel/database/scoped-db.d.ts +0 -20
- package/dist/kernel/database/scoped-db.d.ts.map +0 -1
- package/dist/kernel/database/scoped-db.js +0 -62
- package/dist/kernel/database/tx-context.d.ts +0 -15
- package/dist/kernel/database/tx-context.d.ts.map +0 -1
- package/dist/kernel/database/tx-context.js +0 -19
- package/dist/kernel/error-mapper.d.ts +0 -3
- package/dist/kernel/error-mapper.d.ts.map +0 -1
- package/dist/kernel/error-mapper.js +0 -12
- package/dist/kernel/errors.d.ts +0 -38
- package/dist/kernel/errors.d.ts.map +0 -1
- package/dist/kernel/errors.js +0 -69
- package/dist/kernel/factory/repository-factory.d.ts +0 -71
- package/dist/kernel/factory/repository-factory.d.ts.map +0 -1
- package/dist/kernel/factory/repository-factory.js +0 -138
- package/dist/kernel/hooks/create-context.d.ts +0 -25
- package/dist/kernel/hooks/create-context.d.ts.map +0 -1
- package/dist/kernel/hooks/create-context.js +0 -22
- package/dist/kernel/hooks/executor.d.ts +0 -12
- package/dist/kernel/hooks/executor.d.ts.map +0 -1
- package/dist/kernel/hooks/executor.js +0 -50
- package/dist/kernel/hooks/registry.d.ts +0 -28
- package/dist/kernel/hooks/registry.d.ts.map +0 -1
- package/dist/kernel/hooks/registry.js +0 -58
- package/dist/kernel/hooks/types.d.ts +0 -37
- package/dist/kernel/hooks/types.d.ts.map +0 -1
- package/dist/kernel/hooks/types.js +0 -1
- package/dist/kernel/http-error.d.ts +0 -30
- package/dist/kernel/http-error.d.ts.map +0 -1
- package/dist/kernel/http-error.js +0 -35
- package/dist/kernel/jobs/adapter.d.ts +0 -25
- package/dist/kernel/jobs/adapter.d.ts.map +0 -1
- package/dist/kernel/jobs/adapter.js +0 -9
- package/dist/kernel/jobs/drizzle-adapter.d.ts +0 -15
- package/dist/kernel/jobs/drizzle-adapter.d.ts.map +0 -1
- package/dist/kernel/jobs/drizzle-adapter.js +0 -42
- package/dist/kernel/jobs/runner.d.ts +0 -24
- package/dist/kernel/jobs/runner.d.ts.map +0 -1
- package/dist/kernel/jobs/runner.js +0 -114
- package/dist/kernel/jobs/schema.d.ts +0 -280
- package/dist/kernel/jobs/schema.d.ts.map +0 -1
- package/dist/kernel/jobs/schema.js +0 -37
- package/dist/kernel/jobs/types.d.ts +0 -30
- package/dist/kernel/jobs/types.d.ts.map +0 -1
- package/dist/kernel/jobs/types.js +0 -1
- package/dist/kernel/local-api.d.ts +0 -103
- package/dist/kernel/local-api.d.ts.map +0 -1
- package/dist/kernel/local-api.js +0 -89
- package/dist/kernel/plugin/manifest.d.ts +0 -90
- package/dist/kernel/plugin/manifest.d.ts.map +0 -1
- package/dist/kernel/plugin/manifest.js +0 -169
- package/dist/kernel/query/executor.d.ts +0 -21
- package/dist/kernel/query/executor.d.ts.map +0 -1
- package/dist/kernel/query/executor.js +0 -128
- package/dist/kernel/query/registry.d.ts +0 -33
- package/dist/kernel/query/registry.d.ts.map +0 -1
- package/dist/kernel/query/registry.js +0 -20
- package/dist/kernel/result.d.ts +0 -36
- package/dist/kernel/result.d.ts.map +0 -1
- package/dist/kernel/result.js +0 -16
- package/dist/kernel/schema/extra-columns.d.ts +0 -23
- package/dist/kernel/schema/extra-columns.d.ts.map +0 -1
- package/dist/kernel/schema/extra-columns.js +0 -10
- package/dist/kernel/service-registry.d.ts +0 -109
- package/dist/kernel/service-registry.d.ts.map +0 -1
- package/dist/kernel/service-registry.js +0 -26
- package/dist/kernel/service-timing.d.ts +0 -25
- package/dist/kernel/service-timing.d.ts.map +0 -1
- package/dist/kernel/service-timing.js +0 -62
- package/dist/kernel/state-machine/machine.d.ts +0 -24
- package/dist/kernel/state-machine/machine.d.ts.map +0 -1
- package/dist/kernel/state-machine/machine.js +0 -70
- package/dist/modules/analytics/drizzle-adapter.d.ts +0 -13
- package/dist/modules/analytics/drizzle-adapter.d.ts.map +0 -1
- package/dist/modules/analytics/drizzle-adapter.js +0 -358
- package/dist/modules/analytics/hooks.d.ts +0 -13
- package/dist/modules/analytics/hooks.d.ts.map +0 -1
- package/dist/modules/analytics/hooks.js +0 -12
- package/dist/modules/analytics/models.d.ts +0 -14
- package/dist/modules/analytics/models.d.ts.map +0 -1
- package/dist/modules/analytics/models.js +0 -118
- package/dist/modules/analytics/repository/index.d.ts +0 -5
- package/dist/modules/analytics/repository/index.d.ts.map +0 -1
- package/dist/modules/analytics/repository/index.js +0 -1
- package/dist/modules/analytics/service.d.ts +0 -45
- package/dist/modules/analytics/service.d.ts.map +0 -1
- package/dist/modules/analytics/service.js +0 -196
- package/dist/modules/analytics/types.d.ts +0 -119
- package/dist/modules/analytics/types.d.ts.map +0 -1
- package/dist/modules/analytics/types.js +0 -25
- package/dist/modules/audit/hooks.d.ts +0 -7
- package/dist/modules/audit/hooks.d.ts.map +0 -1
- package/dist/modules/audit/hooks.js +0 -67
- package/dist/modules/audit/schema.d.ts +0 -178
- package/dist/modules/audit/schema.d.ts.map +0 -1
- package/dist/modules/audit/schema.js +0 -21
- package/dist/modules/audit/service.d.ts +0 -38
- package/dist/modules/audit/service.d.ts.map +0 -1
- package/dist/modules/audit/service.js +0 -109
- package/dist/modules/cart/access.d.ts +0 -11
- package/dist/modules/cart/access.d.ts.map +0 -1
- package/dist/modules/cart/access.js +0 -18
- package/dist/modules/cart/matcher.d.ts +0 -20
- package/dist/modules/cart/matcher.d.ts.map +0 -1
- package/dist/modules/cart/matcher.js +0 -2
- package/dist/modules/cart/repository/index.d.ts +0 -45
- package/dist/modules/cart/repository/index.d.ts.map +0 -1
- package/dist/modules/cart/repository/index.js +0 -158
- package/dist/modules/cart/schema.d.ts +0 -359
- package/dist/modules/cart/schema.d.ts.map +0 -1
- package/dist/modules/cart/schema.js +0 -40
- package/dist/modules/cart/schemas.d.ts +0 -29
- package/dist/modules/cart/schemas.d.ts.map +0 -1
- package/dist/modules/cart/schemas.js +0 -14
- package/dist/modules/cart/service.d.ts +0 -63
- package/dist/modules/cart/service.d.ts.map +0 -1
- package/dist/modules/cart/service.js +0 -339
- package/dist/modules/catalog/repository/index.d.ts +0 -106
- package/dist/modules/catalog/repository/index.d.ts.map +0 -1
- package/dist/modules/catalog/repository/index.js +0 -455
- package/dist/modules/catalog/schema.d.ts +0 -1193
- package/dist/modules/catalog/schema.d.ts.map +0 -1
- package/dist/modules/catalog/schema.js +0 -149
- package/dist/modules/catalog/schemas.d.ts +0 -81
- package/dist/modules/catalog/schemas.d.ts.map +0 -1
- package/dist/modules/catalog/schemas.js +0 -62
- package/dist/modules/catalog/service.d.ts +0 -160
- package/dist/modules/catalog/service.d.ts.map +0 -1
- package/dist/modules/catalog/service.js +0 -759
- package/dist/modules/customers/repository/index.d.ts +0 -47
- package/dist/modules/customers/repository/index.d.ts.map +0 -1
- package/dist/modules/customers/repository/index.js +0 -206
- package/dist/modules/customers/schema.d.ts +0 -560
- package/dist/modules/customers/schema.d.ts.map +0 -1
- package/dist/modules/customers/schema.js +0 -60
- package/dist/modules/customers/service.d.ts +0 -27
- package/dist/modules/customers/service.d.ts.map +0 -1
- package/dist/modules/customers/service.js +0 -106
- package/dist/modules/fulfillment/repository/index.d.ts +0 -63
- package/dist/modules/fulfillment/repository/index.d.ts.map +0 -1
- package/dist/modules/fulfillment/repository/index.js +0 -268
- package/dist/modules/fulfillment/schema.d.ts +0 -655
- package/dist/modules/fulfillment/schema.d.ts.map +0 -1
- package/dist/modules/fulfillment/schema.js +0 -83
- package/dist/modules/fulfillment/service.d.ts +0 -58
- package/dist/modules/fulfillment/service.d.ts.map +0 -1
- package/dist/modules/fulfillment/service.js +0 -338
- package/dist/modules/fulfillment/types.d.ts +0 -44
- package/dist/modules/fulfillment/types.d.ts.map +0 -1
- package/dist/modules/fulfillment/types.js +0 -1
- package/dist/modules/inventory/repository/index.d.ts +0 -81
- package/dist/modules/inventory/repository/index.d.ts.map +0 -1
- package/dist/modules/inventory/repository/index.js +0 -310
- package/dist/modules/inventory/schema.d.ts +0 -570
- package/dist/modules/inventory/schema.d.ts.map +0 -1
- package/dist/modules/inventory/schema.js +0 -69
- package/dist/modules/inventory/schemas.d.ts +0 -31
- package/dist/modules/inventory/schemas.d.ts.map +0 -1
- package/dist/modules/inventory/schemas.js +0 -28
- package/dist/modules/inventory/service.d.ts +0 -69
- package/dist/modules/inventory/service.d.ts.map +0 -1
- package/dist/modules/inventory/service.js +0 -283
- package/dist/modules/media/adapter.d.ts +0 -16
- package/dist/modules/media/adapter.d.ts.map +0 -1
- package/dist/modules/media/adapter.js +0 -1
- package/dist/modules/media/repository/index.d.ts +0 -35
- package/dist/modules/media/repository/index.d.ts.map +0 -1
- package/dist/modules/media/repository/index.js +0 -176
- package/dist/modules/media/schema.d.ts +0 -289
- package/dist/modules/media/schema.d.ts.map +0 -1
- package/dist/modules/media/schema.js +0 -35
- package/dist/modules/media/service.d.ts +0 -42
- package/dist/modules/media/service.d.ts.map +0 -1
- package/dist/modules/media/service.js +0 -89
- package/dist/modules/orders/repository/index.d.ts +0 -48
- package/dist/modules/orders/repository/index.d.ts.map +0 -1
- package/dist/modules/orders/repository/index.js +0 -199
- package/dist/modules/orders/schema.d.ts +0 -672
- package/dist/modules/orders/schema.d.ts.map +0 -1
- package/dist/modules/orders/schema.js +0 -63
- package/dist/modules/orders/service.d.ts +0 -85
- package/dist/modules/orders/service.d.ts.map +0 -1
- package/dist/modules/orders/service.js +0 -313
- package/dist/modules/orders/stale-order-cleanup.d.ts +0 -27
- package/dist/modules/orders/stale-order-cleanup.d.ts.map +0 -1
- package/dist/modules/orders/stale-order-cleanup.js +0 -55
- package/dist/modules/organization/service.d.ts +0 -53
- package/dist/modules/organization/service.d.ts.map +0 -1
- package/dist/modules/organization/service.js +0 -151
- package/dist/modules/payments/adapter.d.ts +0 -42
- package/dist/modules/payments/adapter.d.ts.map +0 -1
- package/dist/modules/payments/adapter.js +0 -1
- package/dist/modules/payments/repository/index.d.ts +0 -5
- package/dist/modules/payments/repository/index.d.ts.map +0 -1
- package/dist/modules/payments/repository/index.js +0 -1
- package/dist/modules/payments/service.d.ts +0 -23
- package/dist/modules/payments/service.d.ts.map +0 -1
- package/dist/modules/payments/service.js +0 -72
- package/dist/modules/pricing/repository/index.d.ts +0 -34
- package/dist/modules/pricing/repository/index.d.ts.map +0 -1
- package/dist/modules/pricing/repository/index.js +0 -176
- package/dist/modules/pricing/schema.d.ts +0 -565
- package/dist/modules/pricing/schema.d.ts.map +0 -1
- package/dist/modules/pricing/schema.js +0 -57
- package/dist/modules/pricing/schemas.d.ts +0 -37
- package/dist/modules/pricing/schemas.d.ts.map +0 -1
- package/dist/modules/pricing/schemas.js +0 -30
- package/dist/modules/pricing/service.d.ts +0 -62
- package/dist/modules/pricing/service.d.ts.map +0 -1
- package/dist/modules/pricing/service.js +0 -308
- package/dist/modules/promotions/repository/index.d.ts +0 -41
- package/dist/modules/promotions/repository/index.d.ts.map +0 -1
- package/dist/modules/promotions/repository/index.js +0 -204
- package/dist/modules/promotions/schema.d.ts +0 -427
- package/dist/modules/promotions/schema.d.ts.map +0 -1
- package/dist/modules/promotions/schema.js +0 -52
- package/dist/modules/promotions/schemas.d.ts +0 -33
- package/dist/modules/promotions/schemas.d.ts.map +0 -1
- package/dist/modules/promotions/schemas.js +0 -32
- package/dist/modules/promotions/service.d.ts +0 -80
- package/dist/modules/promotions/service.d.ts.map +0 -1
- package/dist/modules/promotions/service.js +0 -347
- package/dist/modules/search/adapter.d.ts +0 -51
- package/dist/modules/search/adapter.d.ts.map +0 -1
- package/dist/modules/search/adapter.js +0 -1
- package/dist/modules/search/hooks.d.ts +0 -8
- package/dist/modules/search/hooks.d.ts.map +0 -1
- package/dist/modules/search/hooks.js +0 -6
- package/dist/modules/search/repository/index.d.ts +0 -5
- package/dist/modules/search/repository/index.d.ts.map +0 -1
- package/dist/modules/search/repository/index.js +0 -1
- package/dist/modules/search/service.d.ts +0 -24
- package/dist/modules/search/service.d.ts.map +0 -1
- package/dist/modules/search/service.js +0 -217
- package/dist/modules/shipping/calculator.d.ts +0 -42
- package/dist/modules/shipping/calculator.d.ts.map +0 -1
- package/dist/modules/shipping/calculator.js +0 -91
- package/dist/modules/shipping/repository/index.d.ts +0 -5
- package/dist/modules/shipping/repository/index.d.ts.map +0 -1
- package/dist/modules/shipping/repository/index.js +0 -1
- package/dist/modules/shipping/service.d.ts +0 -28
- package/dist/modules/shipping/service.d.ts.map +0 -1
- package/dist/modules/shipping/service.js +0 -20
- package/dist/modules/tax/adapter.d.ts +0 -58
- package/dist/modules/tax/adapter.d.ts.map +0 -1
- package/dist/modules/tax/adapter.js +0 -1
- package/dist/modules/tax/repository/index.d.ts +0 -5
- package/dist/modules/tax/repository/index.d.ts.map +0 -1
- package/dist/modules/tax/repository/index.js +0 -1
- package/dist/modules/tax/service.d.ts +0 -19
- package/dist/modules/tax/service.d.ts.map +0 -1
- package/dist/modules/tax/service.js +0 -34
- package/dist/modules/webhooks/hook.d.ts +0 -13
- package/dist/modules/webhooks/hook.d.ts.map +0 -1
- package/dist/modules/webhooks/hook.js +0 -29
- package/dist/modules/webhooks/repository/index.d.ts +0 -40
- package/dist/modules/webhooks/repository/index.d.ts.map +0 -1
- package/dist/modules/webhooks/repository/index.js +0 -175
- package/dist/modules/webhooks/schema.d.ts +0 -404
- package/dist/modules/webhooks/schema.d.ts.map +0 -1
- package/dist/modules/webhooks/schema.js +0 -40
- package/dist/modules/webhooks/service.d.ts +0 -23
- package/dist/modules/webhooks/service.d.ts.map +0 -1
- package/dist/modules/webhooks/service.js +0 -92
- package/dist/modules/webhooks/signing.d.ts +0 -2
- package/dist/modules/webhooks/signing.d.ts.map +0 -1
- package/dist/modules/webhooks/signing.js +0 -5
- package/dist/modules/webhooks/ssrf-guard.d.ts +0 -19
- package/dist/modules/webhooks/ssrf-guard.d.ts.map +0 -1
- package/dist/modules/webhooks/ssrf-guard.js +0 -79
- package/dist/modules/webhooks/tasks.d.ts +0 -16
- package/dist/modules/webhooks/tasks.d.ts.map +0 -1
- package/dist/modules/webhooks/tasks.js +0 -35
- package/dist/modules/webhooks/worker.d.ts +0 -21
- package/dist/modules/webhooks/worker.d.ts.map +0 -1
- package/dist/modules/webhooks/worker.js +0 -113
- package/dist/runtime/commerce.d.ts +0 -110
- package/dist/runtime/commerce.d.ts.map +0 -1
- package/dist/runtime/commerce.js +0 -37
- package/dist/runtime/kernel.d.ts +0 -71
- package/dist/runtime/kernel.d.ts.map +0 -1
- package/dist/runtime/kernel.js +0 -306
- package/dist/runtime/logger.d.ts +0 -11
- package/dist/runtime/logger.d.ts.map +0 -1
- package/dist/runtime/logger.js +0 -32
- package/dist/runtime/shutdown.d.ts +0 -15
- package/dist/runtime/shutdown.d.ts.map +0 -1
- package/dist/runtime/shutdown.js +0 -34
- package/dist/test-utils/create-pglite-adapter.d.ts +0 -32
- package/dist/test-utils/create-pglite-adapter.d.ts.map +0 -1
- package/dist/test-utils/create-pglite-adapter.js +0 -107
- package/dist/test-utils/create-plugin-test-app.d.ts +0 -50
- package/dist/test-utils/create-plugin-test-app.d.ts.map +0 -1
- package/dist/test-utils/create-plugin-test-app.js +0 -74
- package/dist/test-utils/create-repository-test-harness.d.ts +0 -8
- package/dist/test-utils/create-repository-test-harness.d.ts.map +0 -1
- package/dist/test-utils/create-repository-test-harness.js +0 -7
- package/dist/test-utils/create-test-config.d.ts +0 -18
- package/dist/test-utils/create-test-config.d.ts.map +0 -1
- package/dist/test-utils/create-test-config.js +0 -172
- package/dist/test-utils/create-test-kernel.d.ts +0 -3
- package/dist/test-utils/create-test-kernel.d.ts.map +0 -1
- package/dist/test-utils/create-test-kernel.js +0 -5
- package/dist/test-utils/create-test-plugin-context.d.ts +0 -42
- package/dist/test-utils/create-test-plugin-context.d.ts.map +0 -1
- package/dist/test-utils/create-test-plugin-context.js +0 -46
- package/dist/test-utils/rest-api-test-utils.d.ts +0 -64
- package/dist/test-utils/rest-api-test-utils.d.ts.map +0 -1
- package/dist/test-utils/rest-api-test-utils.js +0 -207
- package/dist/test-utils/test-actors.d.ts +0 -15
- package/dist/test-utils/test-actors.d.ts.map +0 -1
- package/dist/test-utils/test-actors.js +0 -57
- package/dist/test-utils/typed-hooks.d.ts +0 -43
- package/dist/test-utils/typed-hooks.d.ts.map +0 -1
- package/dist/test-utils/typed-hooks.js +0 -35
- package/dist/testing.d.ts +0 -14
- package/dist/testing.d.ts.map +0 -1
- package/dist/testing.js +0 -13
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/dist/types/commerce-types.d.ts +0 -34
- package/dist/types/commerce-types.d.ts.map +0 -1
- package/dist/types/commerce-types.js +0 -1
- package/dist/utils/id.d.ts +0 -2
- package/dist/utils/id.d.ts.map +0 -1
- package/dist/utils/id.js +0 -3
- package/dist/utils/logger.d.ts +0 -3
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/logger.js +0 -16
- package/dist/utils/pagination.d.ts +0 -11
- package/dist/utils/pagination.d.ts.map +0 -1
- package/dist/utils/pagination.js +0 -15
|
@@ -1,347 +0,0 @@
|
|
|
1
|
-
import { CommerceNotFoundError, CommerceValidationError, } from "../../kernel/errors.js";
|
|
2
|
-
import { Err, Ok } from "../../kernel/result.js";
|
|
3
|
-
import { DEFAULT_ORG_ID, resolveOrgId } from "../../auth/org.js";
|
|
4
|
-
function matchesWindow(promotion, timestamp) {
|
|
5
|
-
if (!promotion.isActive)
|
|
6
|
-
return false;
|
|
7
|
-
if (promotion.validFrom && timestamp < promotion.validFrom)
|
|
8
|
-
return false;
|
|
9
|
-
if (promotion.validUntil && timestamp > promotion.validUntil)
|
|
10
|
-
return false;
|
|
11
|
-
return true;
|
|
12
|
-
}
|
|
13
|
-
function toConditions(raw) {
|
|
14
|
-
if (!raw)
|
|
15
|
-
return {};
|
|
16
|
-
const conditions = {};
|
|
17
|
-
if (typeof raw.minimumOrderValue === "number") {
|
|
18
|
-
conditions.minimumOrderValue = raw.minimumOrderValue;
|
|
19
|
-
}
|
|
20
|
-
if (typeof raw.minimumQuantity === "number") {
|
|
21
|
-
conditions.minimumQuantity = raw.minimumQuantity;
|
|
22
|
-
}
|
|
23
|
-
if (Array.isArray(raw.entityTypes)) {
|
|
24
|
-
conditions.entityTypes = raw.entityTypes.filter((item) => typeof item === "string");
|
|
25
|
-
}
|
|
26
|
-
if (Array.isArray(raw.categories)) {
|
|
27
|
-
conditions.categories = raw.categories.filter((item) => typeof item === "string");
|
|
28
|
-
}
|
|
29
|
-
if (Array.isArray(raw.customerGroups)) {
|
|
30
|
-
conditions.customerGroups = raw.customerGroups.filter((item) => typeof item === "string");
|
|
31
|
-
}
|
|
32
|
-
if (typeof raw.firstOrderOnly === "boolean") {
|
|
33
|
-
conditions.firstOrderOnly = raw.firstOrderOnly;
|
|
34
|
-
}
|
|
35
|
-
return conditions;
|
|
36
|
-
}
|
|
37
|
-
function roundMoney(amount) {
|
|
38
|
-
return Math.max(0, Math.round(amount));
|
|
39
|
-
}
|
|
40
|
-
function totalQuantity(items) {
|
|
41
|
-
return items.reduce((sum, item) => sum + item.quantity, 0);
|
|
42
|
-
}
|
|
43
|
-
function sortByPriority(promotions) {
|
|
44
|
-
return [...promotions].sort((a, b) => a.priority - b.priority);
|
|
45
|
-
}
|
|
46
|
-
export class PromotionService {
|
|
47
|
-
deps;
|
|
48
|
-
repo;
|
|
49
|
-
catalogRepo;
|
|
50
|
-
ordersRepo;
|
|
51
|
-
constructor(deps) {
|
|
52
|
-
this.deps = deps;
|
|
53
|
-
this.repo = deps.repository;
|
|
54
|
-
this.catalogRepo = deps.catalogRepository;
|
|
55
|
-
this.ordersRepo = deps.ordersRepository;
|
|
56
|
-
}
|
|
57
|
-
async create(input, actor, ctx) {
|
|
58
|
-
if (!input.name) {
|
|
59
|
-
return Err(new CommerceValidationError("Promotion name is required."));
|
|
60
|
-
}
|
|
61
|
-
if (input.value < 0) {
|
|
62
|
-
return Err(new CommerceValidationError("Promotion value cannot be negative."));
|
|
63
|
-
}
|
|
64
|
-
// Validate promotion type
|
|
65
|
-
const validTypes = [
|
|
66
|
-
"percentage_off_order",
|
|
67
|
-
"fixed_off_order",
|
|
68
|
-
"percentage_off_item",
|
|
69
|
-
"fixed_off_item",
|
|
70
|
-
"free_shipping",
|
|
71
|
-
"buy_x_get_y",
|
|
72
|
-
];
|
|
73
|
-
if (!validTypes.includes(input.type)) {
|
|
74
|
-
return Err(new CommerceValidationError(`Invalid promotion type "${input.type}". Must be one of: ${validTypes.join(", ")}`));
|
|
75
|
-
}
|
|
76
|
-
const orgId = resolveOrgId(actor ?? ctx?.actor ?? null);
|
|
77
|
-
if (input.code) {
|
|
78
|
-
const normalized = input.code.trim().toUpperCase();
|
|
79
|
-
const existing = await this.repo.findByCode(orgId, normalized, ctx);
|
|
80
|
-
if (existing) {
|
|
81
|
-
return Err(new CommerceValidationError(`Promotion code ${normalized} already exists.`));
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
const promotion = await this.repo.create({
|
|
85
|
-
organizationId: orgId,
|
|
86
|
-
name: input.name,
|
|
87
|
-
type: input.type,
|
|
88
|
-
value: roundMoney(input.value),
|
|
89
|
-
isAutomatic: input.isAutomatic ?? false,
|
|
90
|
-
isActive: input.isActive ?? true,
|
|
91
|
-
priority: input.priority ?? 100,
|
|
92
|
-
conditions: (input.conditions ?? {}),
|
|
93
|
-
metadata: input.metadata ?? {},
|
|
94
|
-
code: input.code ? input.code.trim().toUpperCase() : null,
|
|
95
|
-
buyQuantity: input.buyQuantity ?? null,
|
|
96
|
-
getQuantity: input.getQuantity ?? null,
|
|
97
|
-
usageLimitTotal: input.usageLimitTotal ?? null,
|
|
98
|
-
usageLimitPerCustomer: input.usageLimitPerCustomer ?? null,
|
|
99
|
-
validFrom: input.validFrom ?? null,
|
|
100
|
-
validUntil: input.validUntil ?? null,
|
|
101
|
-
}, ctx);
|
|
102
|
-
return Ok(promotion);
|
|
103
|
-
}
|
|
104
|
-
async deactivate(orgId, id, ctx) {
|
|
105
|
-
const promotion = await this.repo.findById(orgId, id, ctx);
|
|
106
|
-
if (!promotion) {
|
|
107
|
-
return Err(new CommerceNotFoundError("Promotion not found."));
|
|
108
|
-
}
|
|
109
|
-
const updated = await this.repo.update(id, { isActive: false }, ctx);
|
|
110
|
-
if (!updated) {
|
|
111
|
-
return Err(new CommerceNotFoundError("Promotion not found."));
|
|
112
|
-
}
|
|
113
|
-
return Ok(updated);
|
|
114
|
-
}
|
|
115
|
-
async listActive(actor, timestamp = new Date(), ctx) {
|
|
116
|
-
const orgId = resolveOrgId(actor ?? ctx?.actor ?? null);
|
|
117
|
-
const active = await this.repo.findActive(orgId, ctx);
|
|
118
|
-
// Further filter by timestamp in case repo returns slightly stale results
|
|
119
|
-
const filtered = active.filter((p) => matchesWindow(p, timestamp));
|
|
120
|
-
return Ok(sortByPriority(filtered));
|
|
121
|
-
}
|
|
122
|
-
async validate(code, context, ctx) {
|
|
123
|
-
const normalized = code.trim().toUpperCase();
|
|
124
|
-
const evalOrgId = context.orgId ?? DEFAULT_ORG_ID;
|
|
125
|
-
const promotion = await this.repo.findByCode(evalOrgId, normalized, ctx);
|
|
126
|
-
if (!promotion) {
|
|
127
|
-
return Err(new CommerceNotFoundError(`Promotion code ${normalized} not found.`));
|
|
128
|
-
}
|
|
129
|
-
const validation = await this.validatePromotionForContext(promotion, context, context.timestamp ?? new Date(), ctx);
|
|
130
|
-
if (validation !== undefined) {
|
|
131
|
-
return Err(new CommerceValidationError(validation));
|
|
132
|
-
}
|
|
133
|
-
return Ok(promotion);
|
|
134
|
-
}
|
|
135
|
-
async apply(code, context, ctx) {
|
|
136
|
-
const validation = await this.validate(code, context, ctx);
|
|
137
|
-
if (!validation.ok)
|
|
138
|
-
return validation;
|
|
139
|
-
const evaluated = await this.evaluatePromotion(validation.value, context, ctx);
|
|
140
|
-
return Ok({
|
|
141
|
-
totalDiscount: evaluated.discountAmount,
|
|
142
|
-
freeShipping: evaluated.freeShipping,
|
|
143
|
-
applied: [evaluated],
|
|
144
|
-
rejectedCodes: [],
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
async applyPromotions(context, ctx) {
|
|
148
|
-
const timestamp = context.timestamp ?? new Date();
|
|
149
|
-
const applyOrgId = context.orgId ?? DEFAULT_ORG_ID;
|
|
150
|
-
const result = {
|
|
151
|
-
totalDiscount: 0,
|
|
152
|
-
freeShipping: false,
|
|
153
|
-
applied: [],
|
|
154
|
-
rejectedCodes: [],
|
|
155
|
-
};
|
|
156
|
-
const selectedPromotions = [];
|
|
157
|
-
// Process explicit promotion codes
|
|
158
|
-
const codeSet = new Set((context.promotionCodes ?? []).map((code) => code.trim().toUpperCase()));
|
|
159
|
-
if (codeSet.size > 0) {
|
|
160
|
-
for (const code of codeSet) {
|
|
161
|
-
const promotion = await this.repo.findByCode(applyOrgId, code, ctx);
|
|
162
|
-
if (!promotion) {
|
|
163
|
-
result.rejectedCodes.push({ code, reason: "Code not found." });
|
|
164
|
-
continue;
|
|
165
|
-
}
|
|
166
|
-
const reason = await this.validatePromotionForContext(promotion, context, timestamp, ctx);
|
|
167
|
-
if (reason !== undefined) {
|
|
168
|
-
result.rejectedCodes.push({ code, reason });
|
|
169
|
-
continue;
|
|
170
|
-
}
|
|
171
|
-
selectedPromotions.push(promotion);
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
// Process automatic promotions
|
|
175
|
-
const automaticPromotions = await this.repo.findAutomatic(applyOrgId, ctx);
|
|
176
|
-
for (const promotion of automaticPromotions) {
|
|
177
|
-
const reason = await this.validatePromotionForContext(promotion, context, timestamp, ctx);
|
|
178
|
-
if (reason !== undefined)
|
|
179
|
-
continue;
|
|
180
|
-
selectedPromotions.push(promotion);
|
|
181
|
-
}
|
|
182
|
-
for (const promotion of sortByPriority(selectedPromotions)) {
|
|
183
|
-
const evaluated = await this.evaluatePromotion(promotion, context, ctx);
|
|
184
|
-
if (evaluated.discountAmount <= 0 && !evaluated.freeShipping)
|
|
185
|
-
continue;
|
|
186
|
-
result.totalDiscount += evaluated.discountAmount;
|
|
187
|
-
result.freeShipping = result.freeShipping || evaluated.freeShipping;
|
|
188
|
-
result.applied.push(evaluated);
|
|
189
|
-
}
|
|
190
|
-
result.totalDiscount = Math.min(roundMoney(result.totalDiscount), roundMoney(context.subtotal));
|
|
191
|
-
return Ok(result);
|
|
192
|
-
}
|
|
193
|
-
async recordUsage(input, ctx) {
|
|
194
|
-
const usages = [];
|
|
195
|
-
for (const applied of input.promotions) {
|
|
196
|
-
const usage = await this.repo.createUsage({
|
|
197
|
-
promotionId: applied.promotionId,
|
|
198
|
-
customerId: input.customerId ?? null,
|
|
199
|
-
orderId: input.orderId ?? null,
|
|
200
|
-
}, ctx);
|
|
201
|
-
usages.push(usage);
|
|
202
|
-
}
|
|
203
|
-
return Ok(usages);
|
|
204
|
-
}
|
|
205
|
-
async validatePromotionForContext(promotion, context, timestamp, ctx) {
|
|
206
|
-
if (!matchesWindow(promotion, timestamp)) {
|
|
207
|
-
return "Promotion is inactive or outside validity window.";
|
|
208
|
-
}
|
|
209
|
-
const conditions = toConditions(promotion.conditions);
|
|
210
|
-
if (conditions.minimumOrderValue !== undefined &&
|
|
211
|
-
roundMoney(context.subtotal) < roundMoney(conditions.minimumOrderValue)) {
|
|
212
|
-
return `Requires minimum order value of ${conditions.minimumOrderValue}.`;
|
|
213
|
-
}
|
|
214
|
-
if (conditions.minimumQuantity !== undefined &&
|
|
215
|
-
totalQuantity(context.lineItems) < conditions.minimumQuantity) {
|
|
216
|
-
return `Requires minimum quantity of ${conditions.minimumQuantity}.`;
|
|
217
|
-
}
|
|
218
|
-
if (conditions.customerGroups && conditions.customerGroups.length > 0) {
|
|
219
|
-
const set = new Set(context.customerGroupIds ?? []);
|
|
220
|
-
const matchesGroup = conditions.customerGroups.some((group) => set.has(group));
|
|
221
|
-
if (!matchesGroup) {
|
|
222
|
-
return "Customer group not eligible for this promotion.";
|
|
223
|
-
}
|
|
224
|
-
}
|
|
225
|
-
if (conditions.entityTypes && conditions.entityTypes.length > 0) {
|
|
226
|
-
const hasType = context.lineItems.some((lineItem) => conditions.entityTypes.includes(lineItem.entityType));
|
|
227
|
-
if (!hasType)
|
|
228
|
-
return "Cart does not include required entity type.";
|
|
229
|
-
}
|
|
230
|
-
if (conditions.categories && conditions.categories.length > 0) {
|
|
231
|
-
const categoryMatches = await this.checkCategoryMatch(context.lineItems, conditions.categories, ctx);
|
|
232
|
-
if (!categoryMatches)
|
|
233
|
-
return "Cart does not include required category.";
|
|
234
|
-
}
|
|
235
|
-
if (conditions.firstOrderOnly) {
|
|
236
|
-
if (!context.customerId) {
|
|
237
|
-
return "First-order promotion requires authenticated customer.";
|
|
238
|
-
}
|
|
239
|
-
const orders = await this.ordersRepo.findByCustomerId(context.orgId ?? DEFAULT_ORG_ID, context.customerId, ctx);
|
|
240
|
-
if (orders.length > 0) {
|
|
241
|
-
return "Promotion is valid for first order only.";
|
|
242
|
-
}
|
|
243
|
-
}
|
|
244
|
-
// Check usage limits
|
|
245
|
-
const usageCount = await this.repo.countUsages(promotion.id, ctx);
|
|
246
|
-
if (promotion.usageLimitTotal !== null &&
|
|
247
|
-
usageCount >= promotion.usageLimitTotal) {
|
|
248
|
-
return "Promotion usage limit reached.";
|
|
249
|
-
}
|
|
250
|
-
if (promotion.usageLimitPerCustomer !== null && context.customerId) {
|
|
251
|
-
const customerUses = await this.repo.countUsagesByCustomer(promotion.id, context.customerId, ctx);
|
|
252
|
-
if (customerUses >= promotion.usageLimitPerCustomer) {
|
|
253
|
-
return "Promotion per-customer usage limit reached.";
|
|
254
|
-
}
|
|
255
|
-
}
|
|
256
|
-
return undefined;
|
|
257
|
-
}
|
|
258
|
-
async checkCategoryMatch(lineItems, categorySlugs, ctx) {
|
|
259
|
-
for (const lineItem of lineItems) {
|
|
260
|
-
const entityCategories = await this.catalogRepo.findEntityCategories(lineItem.entityId, ctx);
|
|
261
|
-
for (const link of entityCategories) {
|
|
262
|
-
const category = await this.catalogRepo.findCategoryById(link.categoryId, ctx);
|
|
263
|
-
if (category && categorySlugs.includes(category.slug)) {
|
|
264
|
-
return true;
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
return false;
|
|
269
|
-
}
|
|
270
|
-
async evaluatePromotion(promotion, context, ctx) {
|
|
271
|
-
const conditions = toConditions(promotion.conditions);
|
|
272
|
-
const eligibleItems = await this.filterEligibleLineItems(context.lineItems, conditions, ctx);
|
|
273
|
-
const eligibleSubtotal = eligibleItems.reduce((sum, item) => sum + item.totalPrice, 0);
|
|
274
|
-
let discountAmount = 0;
|
|
275
|
-
let freeShipping = false;
|
|
276
|
-
switch (promotion.type) {
|
|
277
|
-
case "percentage_off_order":
|
|
278
|
-
discountAmount = Math.round((context.subtotal * promotion.value) / 100);
|
|
279
|
-
break;
|
|
280
|
-
case "fixed_off_order":
|
|
281
|
-
discountAmount = promotion.value;
|
|
282
|
-
break;
|
|
283
|
-
case "percentage_off_item":
|
|
284
|
-
discountAmount = Math.round((eligibleSubtotal * promotion.value) / 100);
|
|
285
|
-
break;
|
|
286
|
-
case "fixed_off_item": {
|
|
287
|
-
const totalUnits = eligibleItems.reduce((sum, item) => sum + item.quantity, 0);
|
|
288
|
-
discountAmount = totalUnits * promotion.value;
|
|
289
|
-
break;
|
|
290
|
-
}
|
|
291
|
-
case "free_shipping":
|
|
292
|
-
freeShipping = true;
|
|
293
|
-
break;
|
|
294
|
-
case "buy_x_get_y": {
|
|
295
|
-
const buy = promotion.buyQuantity ?? 0;
|
|
296
|
-
const get = promotion.getQuantity ?? 0;
|
|
297
|
-
const totalUnits = eligibleItems.reduce((sum, item) => sum + item.quantity, 0);
|
|
298
|
-
if (buy > 0 && get > 0 && totalUnits > 0) {
|
|
299
|
-
const groups = Math.floor(totalUnits / (buy + get));
|
|
300
|
-
const freeUnits = groups * get;
|
|
301
|
-
const minUnitPrice = eligibleItems.length
|
|
302
|
-
? Math.min(...eligibleItems.map((item) => item.unitPrice))
|
|
303
|
-
: 0;
|
|
304
|
-
discountAmount = freeUnits * minUnitPrice;
|
|
305
|
-
}
|
|
306
|
-
break;
|
|
307
|
-
}
|
|
308
|
-
default:
|
|
309
|
-
discountAmount = 0;
|
|
310
|
-
}
|
|
311
|
-
return {
|
|
312
|
-
promotionId: promotion.id,
|
|
313
|
-
type: promotion.type,
|
|
314
|
-
discountAmount: roundMoney(discountAmount),
|
|
315
|
-
freeShipping,
|
|
316
|
-
description: promotion.code
|
|
317
|
-
? `Promotion ${promotion.code}`
|
|
318
|
-
: `Promotion ${promotion.name}`,
|
|
319
|
-
...(promotion.code !== null ? { code: promotion.code } : {}),
|
|
320
|
-
};
|
|
321
|
-
}
|
|
322
|
-
async filterEligibleLineItems(lineItems, conditions, ctx) {
|
|
323
|
-
const eligible = [];
|
|
324
|
-
for (const lineItem of lineItems) {
|
|
325
|
-
if (conditions.entityTypes && conditions.entityTypes.length > 0) {
|
|
326
|
-
if (!conditions.entityTypes.includes(lineItem.entityType))
|
|
327
|
-
continue;
|
|
328
|
-
}
|
|
329
|
-
if (conditions.categories && conditions.categories.length > 0) {
|
|
330
|
-
const entityCats = await this.catalogRepo.findEntityCategories(lineItem.entityId, ctx);
|
|
331
|
-
const hasCategory = await (async () => {
|
|
332
|
-
for (const link of entityCats) {
|
|
333
|
-
const category = await this.catalogRepo.findCategoryById(link.categoryId, ctx);
|
|
334
|
-
if (category && conditions.categories.includes(category.slug)) {
|
|
335
|
-
return true;
|
|
336
|
-
}
|
|
337
|
-
}
|
|
338
|
-
return false;
|
|
339
|
-
})();
|
|
340
|
-
if (!hasCategory)
|
|
341
|
-
continue;
|
|
342
|
-
}
|
|
343
|
-
eligible.push(lineItem);
|
|
344
|
-
}
|
|
345
|
-
return eligible;
|
|
346
|
-
}
|
|
347
|
-
}
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import type { Result } from "../../kernel/result.js";
|
|
2
|
-
export interface SearchDocument {
|
|
3
|
-
id: string;
|
|
4
|
-
type: string;
|
|
5
|
-
slug: string;
|
|
6
|
-
title: string;
|
|
7
|
-
description?: string;
|
|
8
|
-
status?: string;
|
|
9
|
-
categories: string[];
|
|
10
|
-
brands: string[];
|
|
11
|
-
text: string;
|
|
12
|
-
payload?: Record<string, unknown>;
|
|
13
|
-
}
|
|
14
|
-
export interface SearchFilters {
|
|
15
|
-
type?: string;
|
|
16
|
-
category?: string;
|
|
17
|
-
brand?: string;
|
|
18
|
-
status?: string;
|
|
19
|
-
}
|
|
20
|
-
export interface SearchQueryParams {
|
|
21
|
-
query: string;
|
|
22
|
-
page?: number;
|
|
23
|
-
limit?: number;
|
|
24
|
-
filters?: SearchFilters;
|
|
25
|
-
facets?: string[];
|
|
26
|
-
}
|
|
27
|
-
export interface SearchSuggestParams {
|
|
28
|
-
prefix: string;
|
|
29
|
-
type?: string;
|
|
30
|
-
limit?: number;
|
|
31
|
-
}
|
|
32
|
-
export interface SearchHit {
|
|
33
|
-
id: string;
|
|
34
|
-
score?: number;
|
|
35
|
-
document: SearchDocument;
|
|
36
|
-
}
|
|
37
|
-
export interface SearchQueryResult {
|
|
38
|
-
hits: SearchHit[];
|
|
39
|
-
total: number;
|
|
40
|
-
page: number;
|
|
41
|
-
limit: number;
|
|
42
|
-
facets: Record<string, Record<string, number>>;
|
|
43
|
-
}
|
|
44
|
-
export interface SearchAdapter {
|
|
45
|
-
readonly providerId: string;
|
|
46
|
-
index(documents: SearchDocument[]): Promise<Result<void>>;
|
|
47
|
-
remove(ids: string[]): Promise<Result<void>>;
|
|
48
|
-
search(params: SearchQueryParams): Promise<Result<SearchQueryResult>>;
|
|
49
|
-
suggest(params: SearchSuggestParams): Promise<Result<string[]>>;
|
|
50
|
-
}
|
|
51
|
-
//# sourceMappingURL=adapter.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../src/modules/search/adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,aAAa,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,cAAc,CAAC;CAC1B;AAED,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,SAAS,EAAE,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;CAChD;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,KAAK,CAAC,SAAS,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1D,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IAC7C,MAAM,CAAC,MAAM,EAAE,iBAAiB,GAAG,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC;IACtE,OAAO,CAAC,MAAM,EAAE,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;CACjE"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/modules/search/hooks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAG/D,wBAAsB,iBAAiB,CAAC,IAAI,EAAE;IAC5C,MAAM,EAAE;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,CAAC;IACvB,OAAO,EAAE,WAAW,CAAC;CACtB,GAAG,OAAO,CAAC,IAAI,CAAC,CAKhB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/modules/search/repository/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAC;AAExE,MAAM,WAAW,gBAAgB;IAE/B,IAAI,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACrC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { type Result } from "../../kernel/result.js";
|
|
2
|
-
import type { TxContext } from "../../kernel/database/tx-context.js";
|
|
3
|
-
import type { CatalogRepository } from "../catalog/repository/index.js";
|
|
4
|
-
import type { SearchAdapter, SearchQueryParams, SearchQueryResult, SearchSuggestParams } from "./adapter.js";
|
|
5
|
-
interface SearchServiceDeps {
|
|
6
|
-
catalogRepository: CatalogRepository;
|
|
7
|
-
adapter?: SearchAdapter;
|
|
8
|
-
defaultFacets?: string[];
|
|
9
|
-
}
|
|
10
|
-
export declare class SearchService {
|
|
11
|
-
private deps;
|
|
12
|
-
constructor(deps: SearchServiceDeps);
|
|
13
|
-
private entityCategories;
|
|
14
|
-
private entityBrands;
|
|
15
|
-
private buildDocument;
|
|
16
|
-
private allDocuments;
|
|
17
|
-
private matchesFilters;
|
|
18
|
-
private computeFacets;
|
|
19
|
-
syncEntity(entityId: string, ctx?: TxContext): Promise<Result<void>>;
|
|
20
|
-
query(params: SearchQueryParams, ctx?: TxContext): Promise<Result<SearchQueryResult>>;
|
|
21
|
-
suggest(params: SearchSuggestParams, ctx?: TxContext): Promise<Result<string[]>>;
|
|
22
|
-
}
|
|
23
|
-
export {};
|
|
24
|
-
//# sourceMappingURL=service.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../src/modules/search/service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAM,KAAK,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEzD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AACrE,OAAO,KAAK,EAAE,iBAAiB,EAAkB,MAAM,gCAAgC,CAAC;AACxF,OAAO,KAAK,EACV,aAAa,EAGb,iBAAiB,EACjB,iBAAiB,EACjB,mBAAmB,EACpB,MAAM,cAAc,CAAC;AAEtB,UAAU,iBAAiB;IACzB,iBAAiB,EAAE,iBAAiB,CAAC;IACrC,OAAO,CAAC,EAAE,aAAa,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;CAC1B;AAuCD,qBAAa,aAAa;IACZ,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,iBAAiB;YAE7B,gBAAgB;YAwBhB,YAAY;YAwBZ,aAAa;YAyCb,YAAY;IAY1B,OAAO,CAAC,cAAc;IAatB,OAAO,CAAC,aAAa;IAgDf,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAcpE,KAAK,CACT,MAAM,EAAE,iBAAiB,EACzB,GAAG,CAAC,EAAE,SAAS,GACd,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;IA8C/B,OAAO,CACX,MAAM,EAAE,mBAAmB,EAC3B,GAAG,CAAC,EAAE,SAAS,GACd,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;CA2B7B"}
|