@unifiedcommerce/core 0.4.3 → 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/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,196 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* AnalyticsService — thin delegation layer over AnalyticsAdapter.
|
|
3
|
-
*
|
|
4
|
-
* The service manages plugin model registration, custom schema loading,
|
|
5
|
-
* and delegates all query execution to the configured adapter
|
|
6
|
-
* (DrizzleAnalyticsAdapter — always on, built into core).
|
|
7
|
-
*/
|
|
8
|
-
import { CommerceValidationError } from "../../kernel/errors.js";
|
|
9
|
-
import { Err, Ok } from "../../kernel/result.js";
|
|
10
|
-
export class AnalyticsService {
|
|
11
|
-
deps;
|
|
12
|
-
pluginModels = [];
|
|
13
|
-
customSchemaModels = [];
|
|
14
|
-
customModelsLoaded = false;
|
|
15
|
-
constructor(deps) {
|
|
16
|
-
this.deps = deps;
|
|
17
|
-
}
|
|
18
|
-
/**
|
|
19
|
-
* Register a plugin-contributed analytics model.
|
|
20
|
-
*
|
|
21
|
-
* If the model includes a `table` field and structured measures/dimensions,
|
|
22
|
-
* it is also registered as an AnalyticsModel on the adapter for SQL queries.
|
|
23
|
-
* Otherwise, it appears in getMeta() but queries return zero-value rows.
|
|
24
|
-
*/
|
|
25
|
-
registerModel(model) {
|
|
26
|
-
if (!model || typeof model !== "object")
|
|
27
|
-
return;
|
|
28
|
-
const raw = model;
|
|
29
|
-
const name = typeof raw.name === "string"
|
|
30
|
-
? raw.name
|
|
31
|
-
: `PluginModel_${this.pluginModels.length + 1}`;
|
|
32
|
-
const measures = Array.isArray(raw.measures)
|
|
33
|
-
? raw.measures.filter((v) => typeof v === "string")
|
|
34
|
-
: [];
|
|
35
|
-
const dimensions = Array.isArray(raw.dimensions)
|
|
36
|
-
? raw.dimensions.filter((v) => typeof v === "string")
|
|
37
|
-
: [];
|
|
38
|
-
const segments = Array.isArray(raw.segments)
|
|
39
|
-
? raw.segments.filter((v) => typeof v === "string")
|
|
40
|
-
: [];
|
|
41
|
-
this.pluginModels.push({
|
|
42
|
-
name,
|
|
43
|
-
source: "plugin",
|
|
44
|
-
measures,
|
|
45
|
-
dimensions,
|
|
46
|
-
segments,
|
|
47
|
-
raw: model,
|
|
48
|
-
});
|
|
49
|
-
// If the model provides a table + structured definitions, register on the adapter
|
|
50
|
-
if (typeof raw.table === "string" && Array.isArray(raw.measures)) {
|
|
51
|
-
this.tryRegisterModel(name, raw);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
/**
|
|
55
|
-
* Query analytics with scope-based filtering.
|
|
56
|
-
* Scope is REQUIRED — use buildAnalyticsScope(actor) to construct it.
|
|
57
|
-
*/
|
|
58
|
-
async query(params, scope) {
|
|
59
|
-
return this.deps.adapter.query(params, scope);
|
|
60
|
-
}
|
|
61
|
-
async getDashboard(name, scope) {
|
|
62
|
-
const normalized = name.trim().toLowerCase();
|
|
63
|
-
if (normalized === "revenue" || normalized === "revenue-overview") {
|
|
64
|
-
return this.query({
|
|
65
|
-
measures: ["Orders.revenue", "Orders.count"],
|
|
66
|
-
timeDimensions: [{
|
|
67
|
-
dimension: "Orders.placedAt",
|
|
68
|
-
granularity: "month",
|
|
69
|
-
dateRange: "this month",
|
|
70
|
-
}],
|
|
71
|
-
order: { "Orders.placedAt": "asc" },
|
|
72
|
-
}, scope);
|
|
73
|
-
}
|
|
74
|
-
if (normalized === "inventory" || normalized === "inventory-health") {
|
|
75
|
-
return this.query({
|
|
76
|
-
measures: ["Inventory.totalAvailable", "Inventory.lowStockCount"],
|
|
77
|
-
dimensions: ["Inventory.warehouseId"],
|
|
78
|
-
order: { "Inventory.totalAvailable": "desc" },
|
|
79
|
-
}, scope);
|
|
80
|
-
}
|
|
81
|
-
return Err(new CommerceValidationError(`Unknown analytics dashboard: ${name}`));
|
|
82
|
-
}
|
|
83
|
-
async getMeta() {
|
|
84
|
-
await this.ensureCustomSchemaModelsLoaded();
|
|
85
|
-
// Meta returns model definitions, not data — always use admin scope
|
|
86
|
-
const adapterMeta = await this.deps.adapter.getMeta({ role: "admin" });
|
|
87
|
-
if (!adapterMeta.ok)
|
|
88
|
-
return adapterMeta;
|
|
89
|
-
// Merge with plugin and custom schema models
|
|
90
|
-
const allModels = [
|
|
91
|
-
...adapterMeta.value.models,
|
|
92
|
-
...this.pluginModels,
|
|
93
|
-
...this.customSchemaModels,
|
|
94
|
-
];
|
|
95
|
-
return Ok({
|
|
96
|
-
models: allModels,
|
|
97
|
-
measures: allModels.flatMap((m) => m.measures),
|
|
98
|
-
dimensions: allModels.flatMap((m) => m.dimensions),
|
|
99
|
-
segments: allModels.flatMap((m) => m.segments ?? []),
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
async meta() {
|
|
103
|
-
const meta = await this.getMeta();
|
|
104
|
-
if (!meta.ok)
|
|
105
|
-
return meta;
|
|
106
|
-
return Ok({
|
|
107
|
-
measures: meta.value.measures,
|
|
108
|
-
dimensions: meta.value.dimensions,
|
|
109
|
-
segments: meta.value.segments,
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
// ─── Private ─────────────────────────────────────────────────────────────
|
|
113
|
-
tryRegisterModel(name, raw) {
|
|
114
|
-
try {
|
|
115
|
-
const table = raw.table;
|
|
116
|
-
const measuresArray = raw.measures;
|
|
117
|
-
const dimensionsArray = (raw.dimensions ?? []);
|
|
118
|
-
const modelDef = {
|
|
119
|
-
name,
|
|
120
|
-
table,
|
|
121
|
-
measures: {},
|
|
122
|
-
dimensions: {},
|
|
123
|
-
};
|
|
124
|
-
for (const m of measuresArray) {
|
|
125
|
-
if (typeof m === "string")
|
|
126
|
-
continue;
|
|
127
|
-
if (typeof m.name === "string" && typeof m.type === "string") {
|
|
128
|
-
modelDef.measures[m.name] = {
|
|
129
|
-
type: m.type,
|
|
130
|
-
sql: typeof m.sql === "string" ? m.sql : undefined,
|
|
131
|
-
filter: typeof m.filter === "string" ? m.filter : undefined,
|
|
132
|
-
};
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
for (const d of dimensionsArray) {
|
|
136
|
-
if (typeof d === "string")
|
|
137
|
-
continue;
|
|
138
|
-
if (typeof d.name === "string" && typeof d.sql === "string") {
|
|
139
|
-
modelDef.dimensions[d.name] = {
|
|
140
|
-
sql: d.sql,
|
|
141
|
-
type: (typeof d.type === "string" ? d.type : "string"),
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
if (Object.keys(modelDef.measures).length > 0) {
|
|
146
|
-
this.deps.adapter.registerModel(modelDef);
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
catch {
|
|
150
|
-
// Silently skip malformed plugin models
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
async ensureCustomSchemaModelsLoaded() {
|
|
154
|
-
if (this.customModelsLoaded)
|
|
155
|
-
return;
|
|
156
|
-
this.customModelsLoaded = true;
|
|
157
|
-
const customSchemaPath = this.deps.config.analytics?.customSchemaPath;
|
|
158
|
-
if (!customSchemaPath)
|
|
159
|
-
return;
|
|
160
|
-
try {
|
|
161
|
-
const fs = await import("node:fs/promises");
|
|
162
|
-
const path = await import("node:path");
|
|
163
|
-
const entries = await fs.readdir(customSchemaPath);
|
|
164
|
-
for (const entry of entries) {
|
|
165
|
-
if (!entry.endsWith(".js"))
|
|
166
|
-
continue;
|
|
167
|
-
const filePath = path.join(customSchemaPath, entry);
|
|
168
|
-
const content = await fs.readFile(filePath, "utf8");
|
|
169
|
-
const nameMatch = content.match(/cube\s*\(\s*["'`]([\w-]+)["'`]/);
|
|
170
|
-
const name = nameMatch?.[1] ?? entry.replace(/\.js$/, "");
|
|
171
|
-
const measures = [
|
|
172
|
-
...content.matchAll(/measures\s*:\s*{([\s\S]*?)}\s*,/g),
|
|
173
|
-
].flatMap((match) => {
|
|
174
|
-
const block = match[1] ?? "";
|
|
175
|
-
return [...block.matchAll(/([A-Za-z_][A-Za-z0-9_]*)\s*:\s*{/g)].map((x) => `${name}.${x[1]}`);
|
|
176
|
-
});
|
|
177
|
-
const dimensions = [
|
|
178
|
-
...content.matchAll(/dimensions\s*:\s*{([\s\S]*?)}\s*,/g),
|
|
179
|
-
].flatMap((match) => {
|
|
180
|
-
const block = match[1] ?? "";
|
|
181
|
-
return [...block.matchAll(/([A-Za-z_][A-Za-z0-9_]*)\s*:\s*{/g)].map((x) => `${name}.${x[1]}`);
|
|
182
|
-
});
|
|
183
|
-
this.customSchemaModels.push({
|
|
184
|
-
name,
|
|
185
|
-
source: "custom-schema",
|
|
186
|
-
measures,
|
|
187
|
-
dimensions,
|
|
188
|
-
raw: { path: filePath },
|
|
189
|
-
});
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
catch {
|
|
193
|
-
// Optional extension path: ignore file-system issues
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
}
|
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
import type { Result } from "../../kernel/result.js";
|
|
2
|
-
export interface AnalyticsTimeDimension {
|
|
3
|
-
dimension: string;
|
|
4
|
-
granularity?: "day" | "week" | "month" | "year";
|
|
5
|
-
dateRange?: [string, string] | string;
|
|
6
|
-
}
|
|
7
|
-
export interface AnalyticsFilter {
|
|
8
|
-
member: string;
|
|
9
|
-
operator: "equals" | "notEquals" | "contains" | "in" | "notIn" | "gt" | "gte" | "lt" | "lte" | "beforeDate" | "afterDate" | "inDateRange";
|
|
10
|
-
values?: string[];
|
|
11
|
-
}
|
|
12
|
-
export interface AnalyticsQueryParams {
|
|
13
|
-
measures: string[];
|
|
14
|
-
dimensions?: string[];
|
|
15
|
-
timeDimensions?: AnalyticsTimeDimension[];
|
|
16
|
-
filters?: AnalyticsFilter[];
|
|
17
|
-
order?: Record<string, "asc" | "desc">;
|
|
18
|
-
limit?: number;
|
|
19
|
-
}
|
|
20
|
-
export interface AnalyticsQueryResult {
|
|
21
|
-
query: AnalyticsQueryParams;
|
|
22
|
-
rows: Record<string, unknown>[];
|
|
23
|
-
source: string;
|
|
24
|
-
}
|
|
25
|
-
export interface AnalyticsModelDefinition {
|
|
26
|
-
name: string;
|
|
27
|
-
measures: string[];
|
|
28
|
-
dimensions: string[];
|
|
29
|
-
segments?: string[];
|
|
30
|
-
source: "builtin" | "plugin" | "custom-schema";
|
|
31
|
-
raw?: unknown;
|
|
32
|
-
}
|
|
33
|
-
export interface AnalyticsMeta {
|
|
34
|
-
models: AnalyticsModelDefinition[];
|
|
35
|
-
measures: string[];
|
|
36
|
-
dimensions: string[];
|
|
37
|
-
segments: string[];
|
|
38
|
-
}
|
|
39
|
-
export type MeasureType = "count" | "sum" | "avg" | "min" | "max" | "countDistinct";
|
|
40
|
-
export interface AnalyticsMeasure {
|
|
41
|
-
type: MeasureType;
|
|
42
|
-
/** SQL column or expression (e.g., "grand_total" or "quantity_on_hand * COALESCE(unit_cost, 0)") */
|
|
43
|
-
sql?: string | undefined;
|
|
44
|
-
/** SQL filter expression that must be true for this measure to count a row */
|
|
45
|
-
filter?: string | undefined;
|
|
46
|
-
}
|
|
47
|
-
export type DimensionType = "string" | "number" | "time" | "boolean";
|
|
48
|
-
export interface AnalyticsDimension {
|
|
49
|
-
/** SQL column or expression */
|
|
50
|
-
sql: string;
|
|
51
|
-
type: DimensionType;
|
|
52
|
-
}
|
|
53
|
-
export interface AnalyticsJoin {
|
|
54
|
-
table: string;
|
|
55
|
-
type: "left" | "inner";
|
|
56
|
-
on: string;
|
|
57
|
-
}
|
|
58
|
-
export interface AnalyticsModel {
|
|
59
|
-
name: string;
|
|
60
|
-
table: string;
|
|
61
|
-
joins?: AnalyticsJoin[];
|
|
62
|
-
measures: Record<string, AnalyticsMeasure>;
|
|
63
|
-
dimensions: Record<string, AnalyticsDimension>;
|
|
64
|
-
segments?: Record<string, {
|
|
65
|
-
sql: string;
|
|
66
|
-
}>;
|
|
67
|
-
/**
|
|
68
|
-
* Scope rules define how this model is filtered by role.
|
|
69
|
-
* The filter SQL uses :vendorId or :customerId as placeholders.
|
|
70
|
-
*
|
|
71
|
-
* Example: { role: "vendor", filter: "vendor_id = :vendorId" }
|
|
72
|
-
*/
|
|
73
|
-
scopeRules?: AnalyticsScopeRule[];
|
|
74
|
-
}
|
|
75
|
-
export interface AnalyticsScope {
|
|
76
|
-
role: "admin" | "staff" | "vendor" | "customer" | "public";
|
|
77
|
-
vendorId?: string | undefined;
|
|
78
|
-
customerId?: string | undefined;
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Scope rule: defines how an analytics model is filtered for a given role.
|
|
82
|
-
* Registered alongside model definitions.
|
|
83
|
-
*/
|
|
84
|
-
export interface AnalyticsScopeRule {
|
|
85
|
-
/** Which role this rule applies to */
|
|
86
|
-
role: "vendor" | "customer";
|
|
87
|
-
/** SQL WHERE clause fragment. Use :vendorId or :customerId as placeholders. */
|
|
88
|
-
filter: string;
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Build an AnalyticsScope from an actor (or null for public).
|
|
92
|
-
*
|
|
93
|
-
* This is the ONLY way scopes should be created. Every call site that
|
|
94
|
-
* invokes analytics.query() MUST use this function — never construct
|
|
95
|
-
* a scope manually. This ensures the scope always reflects the
|
|
96
|
-
* authenticated actor's actual role and identity.
|
|
97
|
-
*/
|
|
98
|
-
export declare function buildAnalyticsScope(actor: {
|
|
99
|
-
role?: string;
|
|
100
|
-
vendorId?: string | null;
|
|
101
|
-
userId?: string;
|
|
102
|
-
} | null): AnalyticsScope;
|
|
103
|
-
export interface AnalyticsAdapter {
|
|
104
|
-
/** Scope is REQUIRED. Use buildAnalyticsScope(actor) to construct it. */
|
|
105
|
-
query(params: AnalyticsQueryParams, scope: AnalyticsScope): Promise<Result<AnalyticsQueryResult>>;
|
|
106
|
-
getMeta(scope: AnalyticsScope): Promise<Result<AnalyticsMeta>>;
|
|
107
|
-
registerModel(model: AnalyticsModel): void;
|
|
108
|
-
}
|
|
109
|
-
/** @deprecated Use AnalyticsModel instead */
|
|
110
|
-
export type CubeDefinition = AnalyticsModel;
|
|
111
|
-
/** @deprecated Use AnalyticsScopeRule instead */
|
|
112
|
-
export type CubeScopeRule = AnalyticsScopeRule;
|
|
113
|
-
/** @deprecated Use AnalyticsMeasure instead */
|
|
114
|
-
export type MeasureDefinition = AnalyticsMeasure;
|
|
115
|
-
/** @deprecated Use AnalyticsDimension instead */
|
|
116
|
-
export type DimensionDefinition = AnalyticsDimension;
|
|
117
|
-
/** @deprecated Use AnalyticsJoin instead */
|
|
118
|
-
export type JoinDefinition = AnalyticsJoin;
|
|
119
|
-
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/modules/analytics/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
// ─── Scope Builder ───────────────────────────────────────────────────────────
|
|
2
|
-
/**
|
|
3
|
-
* Build an AnalyticsScope from an actor (or null for public).
|
|
4
|
-
*
|
|
5
|
-
* This is the ONLY way scopes should be created. Every call site that
|
|
6
|
-
* invokes analytics.query() MUST use this function — never construct
|
|
7
|
-
* a scope manually. This ensures the scope always reflects the
|
|
8
|
-
* authenticated actor's actual role and identity.
|
|
9
|
-
*/
|
|
10
|
-
export function buildAnalyticsScope(actor) {
|
|
11
|
-
if (!actor)
|
|
12
|
-
return { role: "public" };
|
|
13
|
-
const role = actor.role ?? "public";
|
|
14
|
-
if (role === "admin" || role === "owner" || role === "staff" || role === "ai_agent") {
|
|
15
|
-
return { role: "admin" };
|
|
16
|
-
}
|
|
17
|
-
if (actor.vendorId) {
|
|
18
|
-
return { role: "vendor", vendorId: actor.vendorId };
|
|
19
|
-
}
|
|
20
|
-
if (role === "customer" && actor.userId) {
|
|
21
|
-
return { role: "customer", customerId: actor.userId };
|
|
22
|
-
}
|
|
23
|
-
// Unknown role — deny access
|
|
24
|
-
return { role: "public" };
|
|
25
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import type { HookHandler } from "../../kernel/hooks/registry.js";
|
|
2
|
-
/**
|
|
3
|
-
* All audit hooks, keyed by hook registration key.
|
|
4
|
-
* Registered in kernel boot via hooks.append().
|
|
5
|
-
*/
|
|
6
|
-
export declare const auditHooks: Record<string, HookHandler>;
|
|
7
|
-
//# sourceMappingURL=hooks.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/modules/audit/hooks.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAiDlE;;;GAGG;AACH,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAuBlD,CAAC"}
|
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Creates an after-hook that records an audit entry for the operation.
|
|
3
|
-
*
|
|
4
|
-
* The audit entry is written using the same transaction context as the
|
|
5
|
-
* business operation (via ctx.tx). If the operation rolls back, the
|
|
6
|
-
* audit entry rolls back too.
|
|
7
|
-
*/
|
|
8
|
-
function createAuditAfterHook(entityType, event) {
|
|
9
|
-
return async ({ result, context }) => {
|
|
10
|
-
const audit = context.services.audit;
|
|
11
|
-
if (!audit?.record)
|
|
12
|
-
return;
|
|
13
|
-
const entityId = result?.id ?? "unknown";
|
|
14
|
-
await audit.record({
|
|
15
|
-
entityType,
|
|
16
|
-
entityId,
|
|
17
|
-
event,
|
|
18
|
-
payload: safePayload(result),
|
|
19
|
-
ctx: context,
|
|
20
|
-
});
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* Strips the result to a safe subset for audit logging.
|
|
25
|
-
* Avoids storing sensitive fields or excessively large payloads.
|
|
26
|
-
*/
|
|
27
|
-
function safePayload(result) {
|
|
28
|
-
if (result == null || typeof result !== "object")
|
|
29
|
-
return {};
|
|
30
|
-
const obj = result;
|
|
31
|
-
// Shallow copy, exclude fields that could be huge
|
|
32
|
-
const safe = {};
|
|
33
|
-
for (const [key, value] of Object.entries(obj)) {
|
|
34
|
-
// Skip binary data, nested arrays > 10 items, and known sensitive fields
|
|
35
|
-
if (key === "password" || key === "secret" || key === "bankAccount")
|
|
36
|
-
continue;
|
|
37
|
-
if (Array.isArray(value) && value.length > 10) {
|
|
38
|
-
safe[key] = `[${value.length} items]`;
|
|
39
|
-
continue;
|
|
40
|
-
}
|
|
41
|
-
safe[key] = value;
|
|
42
|
-
}
|
|
43
|
-
return safe;
|
|
44
|
-
}
|
|
45
|
-
/**
|
|
46
|
-
* All audit hooks, keyed by hook registration key.
|
|
47
|
-
* Registered in kernel boot via hooks.append().
|
|
48
|
-
*/
|
|
49
|
-
export const auditHooks = {
|
|
50
|
-
// Catalog
|
|
51
|
-
"catalog.afterCreate": createAuditAfterHook("catalog_entity", "created"),
|
|
52
|
-
"catalog.afterUpdate": createAuditAfterHook("catalog_entity", "updated"),
|
|
53
|
-
// Orders
|
|
54
|
-
"orders.afterCreate": createAuditAfterHook("order", "created"),
|
|
55
|
-
"orders.afterStatusChange": createAuditAfterHook("order", "status_changed"),
|
|
56
|
-
// Inventory
|
|
57
|
-
"inventory.afterAdjust": createAuditAfterHook("inventory", "adjusted"),
|
|
58
|
-
// Customers
|
|
59
|
-
"customers.afterCreate": createAuditAfterHook("customer", "created"),
|
|
60
|
-
"customers.afterUpdate": createAuditAfterHook("customer", "updated"),
|
|
61
|
-
// Pricing
|
|
62
|
-
"pricing.afterCreate": createAuditAfterHook("price", "created"),
|
|
63
|
-
"pricing.afterUpdate": createAuditAfterHook("price", "updated"),
|
|
64
|
-
// Promotions
|
|
65
|
-
"promotions.afterCreate": createAuditAfterHook("promotion", "created"),
|
|
66
|
-
"promotions.afterUpdate": createAuditAfterHook("promotion", "updated"),
|
|
67
|
-
};
|
|
@@ -1,178 +0,0 @@
|
|
|
1
|
-
export declare const auditLog: import("drizzle-orm/pg-core").PgTableWithColumns<{
|
|
2
|
-
name: "commerce_audit_log";
|
|
3
|
-
schema: undefined;
|
|
4
|
-
columns: {
|
|
5
|
-
id: import("drizzle-orm/pg-core").PgColumn<{
|
|
6
|
-
name: "id";
|
|
7
|
-
tableName: "commerce_audit_log";
|
|
8
|
-
dataType: "string";
|
|
9
|
-
columnType: "PgUUID";
|
|
10
|
-
data: string;
|
|
11
|
-
driverParam: string;
|
|
12
|
-
notNull: true;
|
|
13
|
-
hasDefault: true;
|
|
14
|
-
isPrimaryKey: true;
|
|
15
|
-
isAutoincrement: false;
|
|
16
|
-
hasRuntimeDefault: false;
|
|
17
|
-
enumValues: undefined;
|
|
18
|
-
baseColumn: never;
|
|
19
|
-
identity: undefined;
|
|
20
|
-
generated: undefined;
|
|
21
|
-
}, {}, {}>;
|
|
22
|
-
organizationId: import("drizzle-orm/pg-core").PgColumn<{
|
|
23
|
-
name: "organization_id";
|
|
24
|
-
tableName: "commerce_audit_log";
|
|
25
|
-
dataType: "string";
|
|
26
|
-
columnType: "PgText";
|
|
27
|
-
data: string;
|
|
28
|
-
driverParam: string;
|
|
29
|
-
notNull: true;
|
|
30
|
-
hasDefault: false;
|
|
31
|
-
isPrimaryKey: false;
|
|
32
|
-
isAutoincrement: false;
|
|
33
|
-
hasRuntimeDefault: false;
|
|
34
|
-
enumValues: [string, ...string[]];
|
|
35
|
-
baseColumn: never;
|
|
36
|
-
identity: undefined;
|
|
37
|
-
generated: undefined;
|
|
38
|
-
}, {}, {}>;
|
|
39
|
-
entityType: import("drizzle-orm/pg-core").PgColumn<{
|
|
40
|
-
name: "entity_type";
|
|
41
|
-
tableName: "commerce_audit_log";
|
|
42
|
-
dataType: "string";
|
|
43
|
-
columnType: "PgText";
|
|
44
|
-
data: string;
|
|
45
|
-
driverParam: string;
|
|
46
|
-
notNull: true;
|
|
47
|
-
hasDefault: false;
|
|
48
|
-
isPrimaryKey: false;
|
|
49
|
-
isAutoincrement: false;
|
|
50
|
-
hasRuntimeDefault: false;
|
|
51
|
-
enumValues: [string, ...string[]];
|
|
52
|
-
baseColumn: never;
|
|
53
|
-
identity: undefined;
|
|
54
|
-
generated: undefined;
|
|
55
|
-
}, {}, {}>;
|
|
56
|
-
entityId: import("drizzle-orm/pg-core").PgColumn<{
|
|
57
|
-
name: "entity_id";
|
|
58
|
-
tableName: "commerce_audit_log";
|
|
59
|
-
dataType: "string";
|
|
60
|
-
columnType: "PgText";
|
|
61
|
-
data: string;
|
|
62
|
-
driverParam: string;
|
|
63
|
-
notNull: true;
|
|
64
|
-
hasDefault: false;
|
|
65
|
-
isPrimaryKey: false;
|
|
66
|
-
isAutoincrement: false;
|
|
67
|
-
hasRuntimeDefault: false;
|
|
68
|
-
enumValues: [string, ...string[]];
|
|
69
|
-
baseColumn: never;
|
|
70
|
-
identity: undefined;
|
|
71
|
-
generated: undefined;
|
|
72
|
-
}, {}, {}>;
|
|
73
|
-
event: import("drizzle-orm/pg-core").PgColumn<{
|
|
74
|
-
name: "event";
|
|
75
|
-
tableName: "commerce_audit_log";
|
|
76
|
-
dataType: "string";
|
|
77
|
-
columnType: "PgText";
|
|
78
|
-
data: string;
|
|
79
|
-
driverParam: string;
|
|
80
|
-
notNull: true;
|
|
81
|
-
hasDefault: false;
|
|
82
|
-
isPrimaryKey: false;
|
|
83
|
-
isAutoincrement: false;
|
|
84
|
-
hasRuntimeDefault: false;
|
|
85
|
-
enumValues: [string, ...string[]];
|
|
86
|
-
baseColumn: never;
|
|
87
|
-
identity: undefined;
|
|
88
|
-
generated: undefined;
|
|
89
|
-
}, {}, {}>;
|
|
90
|
-
payload: import("drizzle-orm/pg-core").PgColumn<{
|
|
91
|
-
name: "payload";
|
|
92
|
-
tableName: "commerce_audit_log";
|
|
93
|
-
dataType: "json";
|
|
94
|
-
columnType: "PgJsonb";
|
|
95
|
-
data: unknown;
|
|
96
|
-
driverParam: unknown;
|
|
97
|
-
notNull: true;
|
|
98
|
-
hasDefault: true;
|
|
99
|
-
isPrimaryKey: false;
|
|
100
|
-
isAutoincrement: false;
|
|
101
|
-
hasRuntimeDefault: false;
|
|
102
|
-
enumValues: undefined;
|
|
103
|
-
baseColumn: never;
|
|
104
|
-
identity: undefined;
|
|
105
|
-
generated: undefined;
|
|
106
|
-
}, {}, {}>;
|
|
107
|
-
actorId: import("drizzle-orm/pg-core").PgColumn<{
|
|
108
|
-
name: "actor_id";
|
|
109
|
-
tableName: "commerce_audit_log";
|
|
110
|
-
dataType: "string";
|
|
111
|
-
columnType: "PgText";
|
|
112
|
-
data: string;
|
|
113
|
-
driverParam: string;
|
|
114
|
-
notNull: false;
|
|
115
|
-
hasDefault: false;
|
|
116
|
-
isPrimaryKey: false;
|
|
117
|
-
isAutoincrement: false;
|
|
118
|
-
hasRuntimeDefault: false;
|
|
119
|
-
enumValues: [string, ...string[]];
|
|
120
|
-
baseColumn: never;
|
|
121
|
-
identity: undefined;
|
|
122
|
-
generated: undefined;
|
|
123
|
-
}, {}, {}>;
|
|
124
|
-
actorType: import("drizzle-orm/pg-core").PgColumn<{
|
|
125
|
-
name: "actor_type";
|
|
126
|
-
tableName: "commerce_audit_log";
|
|
127
|
-
dataType: "string";
|
|
128
|
-
columnType: "PgText";
|
|
129
|
-
data: string;
|
|
130
|
-
driverParam: string;
|
|
131
|
-
notNull: false;
|
|
132
|
-
hasDefault: false;
|
|
133
|
-
isPrimaryKey: false;
|
|
134
|
-
isAutoincrement: false;
|
|
135
|
-
hasRuntimeDefault: false;
|
|
136
|
-
enumValues: [string, ...string[]];
|
|
137
|
-
baseColumn: never;
|
|
138
|
-
identity: undefined;
|
|
139
|
-
generated: undefined;
|
|
140
|
-
}, {}, {}>;
|
|
141
|
-
requestId: import("drizzle-orm/pg-core").PgColumn<{
|
|
142
|
-
name: "request_id";
|
|
143
|
-
tableName: "commerce_audit_log";
|
|
144
|
-
dataType: "string";
|
|
145
|
-
columnType: "PgText";
|
|
146
|
-
data: string;
|
|
147
|
-
driverParam: string;
|
|
148
|
-
notNull: false;
|
|
149
|
-
hasDefault: false;
|
|
150
|
-
isPrimaryKey: false;
|
|
151
|
-
isAutoincrement: false;
|
|
152
|
-
hasRuntimeDefault: false;
|
|
153
|
-
enumValues: [string, ...string[]];
|
|
154
|
-
baseColumn: never;
|
|
155
|
-
identity: undefined;
|
|
156
|
-
generated: undefined;
|
|
157
|
-
}, {}, {}>;
|
|
158
|
-
createdAt: import("drizzle-orm/pg-core").PgColumn<{
|
|
159
|
-
name: "created_at";
|
|
160
|
-
tableName: "commerce_audit_log";
|
|
161
|
-
dataType: "date";
|
|
162
|
-
columnType: "PgTimestamp";
|
|
163
|
-
data: Date;
|
|
164
|
-
driverParam: string;
|
|
165
|
-
notNull: true;
|
|
166
|
-
hasDefault: true;
|
|
167
|
-
isPrimaryKey: false;
|
|
168
|
-
isAutoincrement: false;
|
|
169
|
-
hasRuntimeDefault: false;
|
|
170
|
-
enumValues: undefined;
|
|
171
|
-
baseColumn: never;
|
|
172
|
-
identity: undefined;
|
|
173
|
-
generated: undefined;
|
|
174
|
-
}, {}, {}>;
|
|
175
|
-
};
|
|
176
|
-
dialect: "pg";
|
|
177
|
-
}>;
|
|
178
|
-
//# sourceMappingURL=schema.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/modules/audit/schema.ts"],"names":[],"mappings":"AAUA,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAsBpB,CAAC"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { pgTable, uuid, text, jsonb, timestamp, index, } from "drizzle-orm/pg-core";
|
|
2
|
-
import { organization } from "../../auth/auth-schema.js";
|
|
3
|
-
export const auditLog = pgTable("commerce_audit_log", {
|
|
4
|
-
id: uuid("id").primaryKey().defaultRandom(),
|
|
5
|
-
organizationId: text("organization_id")
|
|
6
|
-
.notNull()
|
|
7
|
-
.references(() => organization.id, { onDelete: "cascade" }),
|
|
8
|
-
entityType: text("entity_type").notNull(),
|
|
9
|
-
entityId: text("entity_id").notNull(),
|
|
10
|
-
event: text("event").notNull(),
|
|
11
|
-
payload: jsonb("payload").notNull().default("{}"),
|
|
12
|
-
actorId: text("actor_id"),
|
|
13
|
-
actorType: text("actor_type"),
|
|
14
|
-
requestId: text("request_id"),
|
|
15
|
-
createdAt: timestamp("created_at", { withTimezone: true })
|
|
16
|
-
.notNull()
|
|
17
|
-
.defaultNow(),
|
|
18
|
-
}, (table) => ({
|
|
19
|
-
entityIdx: index("idx_audit_entity").on(table.entityType, table.entityId),
|
|
20
|
-
orgIdx: index("idx_audit_org").on(table.organizationId),
|
|
21
|
-
}));
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import type { InferSelectModel } from "drizzle-orm";
|
|
2
|
-
import type { DrizzleDatabase } from "../../kernel/database/drizzle-db.js";
|
|
3
|
-
import type { TxContext } from "../../kernel/database/tx-context.js";
|
|
4
|
-
import type { HookContext } from "../../kernel/hooks/types.js";
|
|
5
|
-
import { auditLog } from "./schema.js";
|
|
6
|
-
export type AuditEntry = InferSelectModel<typeof auditLog>;
|
|
7
|
-
export interface RecordArgs {
|
|
8
|
-
entityType: string;
|
|
9
|
-
entityId: string;
|
|
10
|
-
event: string;
|
|
11
|
-
payload?: Record<string, unknown>;
|
|
12
|
-
ctx: HookContext;
|
|
13
|
-
}
|
|
14
|
-
export interface ListForEntityArgs {
|
|
15
|
-
organizationId?: string;
|
|
16
|
-
entityType: string;
|
|
17
|
-
entityId: string;
|
|
18
|
-
limit?: number;
|
|
19
|
-
ctx?: TxContext;
|
|
20
|
-
}
|
|
21
|
-
export interface ListArgs {
|
|
22
|
-
organizationId?: string | undefined;
|
|
23
|
-
entityType?: string | undefined;
|
|
24
|
-
entityId?: string | undefined;
|
|
25
|
-
event?: string | undefined;
|
|
26
|
-
actorId?: string | undefined;
|
|
27
|
-
from?: Date | undefined;
|
|
28
|
-
to?: Date | undefined;
|
|
29
|
-
limit?: number | undefined;
|
|
30
|
-
}
|
|
31
|
-
export interface AuditService {
|
|
32
|
-
record(args: RecordArgs): Promise<void>;
|
|
33
|
-
listForEntity(args: ListForEntityArgs): Promise<AuditEntry[]>;
|
|
34
|
-
list(args: ListArgs): Promise<AuditEntry[]>;
|
|
35
|
-
}
|
|
36
|
-
export declare function createNullAuditService(): AuditService;
|
|
37
|
-
export declare function createAuditService(db: DrizzleDatabase): AuditService;
|
|
38
|
-
//# sourceMappingURL=service.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../src/modules/audit/service.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAC3E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;AACrE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE/D,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,MAAM,MAAM,UAAU,GAAG,gBAAgB,CAAC,OAAO,QAAQ,CAAC,CAAC;AAE3D,MAAM,WAAW,UAAU;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,GAAG,EAAE,WAAW,CAAC;CAClB;AAED,MAAM,WAAW,iBAAiB;IAChC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,GAAG,CAAC,EAAE,SAAS,CAAC;CACjB;AAED,MAAM,WAAW,QAAQ;IACvB,cAAc,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACpC,UAAU,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAChC,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,IAAI,CAAC,EAAE,IAAI,GAAG,SAAS,CAAC;IACxB,EAAE,CAAC,EAAE,IAAI,GAAG,SAAS,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAC5B;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACxC,aAAa,CAAC,IAAI,EAAE,iBAAiB,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;IAC9D,IAAI,CAAC,IAAI,EAAE,QAAQ,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;CAC7C;AAED,wBAAgB,sBAAsB,IAAI,YAAY,CAyCrD;AAED,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,eAAe,GAAG,YAAY,CAgEpE"}
|