pipework 0.7.11 → 0.7.13
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/CHANGELOG.md +17 -0
- package/REFERENCE.md +778 -0
- package/dist/REFERENCE.md +844 -0
- package/dist/async/jobs/cron.d.ts +11 -0
- package/dist/async/jobs/cron.d.ts.map +1 -0
- package/dist/async/jobs/cron.js +176 -0
- package/dist/async/jobs/cron.js.map +1 -0
- package/dist/async/jobs/execute.d.ts +12 -0
- package/dist/async/jobs/execute.d.ts.map +1 -0
- package/dist/async/jobs/execute.js +19 -0
- package/dist/async/jobs/execute.js.map +1 -0
- package/dist/async/jobs/index.d.ts +8 -0
- package/dist/async/jobs/index.d.ts.map +1 -0
- package/dist/async/jobs/index.js +4 -0
- package/dist/async/jobs/index.js.map +1 -0
- package/dist/async/jobs/listener.d.ts +32 -0
- package/dist/async/jobs/listener.d.ts.map +1 -0
- package/dist/async/jobs/listener.js +95 -0
- package/dist/async/jobs/listener.js.map +1 -0
- package/dist/async/jobs/namespace.d.ts +15 -0
- package/dist/async/jobs/namespace.d.ts.map +1 -0
- package/dist/async/jobs/namespace.js +15 -0
- package/dist/async/jobs/namespace.js.map +1 -0
- package/dist/async/jobs/queue.d.ts +58 -0
- package/dist/async/jobs/queue.d.ts.map +1 -0
- package/dist/async/jobs/queue.js +163 -0
- package/dist/async/jobs/queue.js.map +1 -0
- package/dist/async/jobs/scheduler.d.ts +31 -0
- package/dist/async/jobs/scheduler.d.ts.map +1 -0
- package/dist/async/jobs/scheduler.js +94 -0
- package/dist/async/jobs/scheduler.js.map +1 -0
- package/dist/async/pipeline/define.d.ts +3 -0
- package/dist/async/pipeline/define.d.ts.map +1 -0
- package/dist/async/pipeline/define.js +44 -0
- package/dist/async/pipeline/define.js.map +1 -0
- package/dist/async/pipeline/errors.d.ts +17 -0
- package/dist/async/pipeline/errors.d.ts.map +1 -0
- package/dist/async/pipeline/errors.js +28 -0
- package/dist/async/pipeline/errors.js.map +1 -0
- package/dist/async/pipeline/execute.d.ts +4 -0
- package/dist/async/pipeline/execute.d.ts.map +1 -0
- package/dist/async/pipeline/execute.js +90 -0
- package/dist/async/pipeline/execute.js.map +1 -0
- package/dist/async/pipeline/index.d.ts +4 -0
- package/dist/async/pipeline/index.d.ts.map +1 -0
- package/dist/async/pipeline/index.js +3 -0
- package/dist/async/pipeline/index.js.map +1 -0
- package/dist/async/pipeline/namespace.d.ts +12 -0
- package/dist/async/pipeline/namespace.d.ts.map +1 -0
- package/dist/async/pipeline/namespace.js +12 -0
- package/dist/async/pipeline/namespace.js.map +1 -0
- package/dist/async/pipeline/resume.d.ts +4 -0
- package/dist/async/pipeline/resume.d.ts.map +1 -0
- package/dist/async/pipeline/resume.js +100 -0
- package/dist/async/pipeline/resume.js.map +1 -0
- package/dist/async/pipeline/types.d.ts +50 -0
- package/dist/async/pipeline/types.d.ts.map +1 -0
- package/dist/async/pipeline/types.js +2 -0
- package/dist/async/pipeline/types.js.map +1 -0
- package/dist/async/state-machine/define.d.ts +3 -0
- package/dist/async/state-machine/define.d.ts.map +1 -0
- package/dist/async/state-machine/define.js +46 -0
- package/dist/async/state-machine/define.js.map +1 -0
- package/dist/async/state-machine/errors.d.ts +12 -0
- package/dist/async/state-machine/errors.d.ts.map +1 -0
- package/dist/async/state-machine/errors.js +19 -0
- package/dist/async/state-machine/errors.js.map +1 -0
- package/dist/async/state-machine/index.d.ts +4 -0
- package/dist/async/state-machine/index.d.ts.map +1 -0
- package/dist/async/state-machine/index.js +3 -0
- package/dist/async/state-machine/index.js.map +1 -0
- package/dist/async/state-machine/namespace.d.ts +12 -0
- package/dist/async/state-machine/namespace.d.ts.map +1 -0
- package/dist/async/state-machine/namespace.js +12 -0
- package/dist/async/state-machine/namespace.js.map +1 -0
- package/dist/async/state-machine/transition.d.ts +7 -0
- package/dist/async/state-machine/transition.d.ts.map +1 -0
- package/dist/async/state-machine/transition.js +57 -0
- package/dist/async/state-machine/transition.js.map +1 -0
- package/dist/async/state-machine/types.d.ts +33 -0
- package/dist/async/state-machine/types.d.ts.map +1 -0
- package/dist/async/state-machine/types.js +2 -0
- package/dist/async/state-machine/types.js.map +1 -0
- package/dist/auth/auth/chain.d.ts +26 -0
- package/dist/auth/auth/chain.d.ts.map +1 -0
- package/dist/auth/auth/chain.js +46 -0
- package/dist/auth/auth/chain.js.map +1 -0
- package/dist/auth/auth/cookie.d.ts +24 -0
- package/dist/auth/auth/cookie.d.ts.map +1 -0
- package/dist/auth/auth/cookie.js +59 -0
- package/dist/auth/auth/cookie.js.map +1 -0
- package/dist/auth/auth/index.d.ts +10 -0
- package/dist/auth/auth/index.d.ts.map +1 -0
- package/dist/auth/auth/index.js +5 -0
- package/dist/auth/auth/index.js.map +1 -0
- package/dist/auth/auth/multi-org.d.ts +77 -0
- package/dist/auth/auth/multi-org.d.ts.map +1 -0
- package/dist/auth/auth/multi-org.js +164 -0
- package/dist/auth/auth/multi-org.js.map +1 -0
- package/dist/auth/auth/namespace.d.ts +22 -0
- package/dist/auth/auth/namespace.d.ts.map +1 -0
- package/dist/auth/auth/namespace.js +22 -0
- package/dist/auth/auth/namespace.js.map +1 -0
- package/dist/auth/auth/sessions.d.ts +70 -0
- package/dist/auth/auth/sessions.d.ts.map +1 -0
- package/dist/auth/auth/sessions.js +231 -0
- package/dist/auth/auth/sessions.js.map +1 -0
- package/dist/auth/auth/types.d.ts +22 -0
- package/dist/auth/auth/types.d.ts.map +1 -0
- package/dist/auth/auth/types.js +2 -0
- package/dist/auth/auth/types.js.map +1 -0
- package/dist/auth/rbac/cache.d.ts +13 -0
- package/dist/auth/rbac/cache.d.ts.map +1 -0
- package/dist/auth/rbac/cache.js +43 -0
- package/dist/auth/rbac/cache.js.map +1 -0
- package/dist/auth/rbac/check.d.ts +4 -0
- package/dist/auth/rbac/check.d.ts.map +1 -0
- package/dist/auth/rbac/check.js +20 -0
- package/dist/auth/rbac/check.js.map +1 -0
- package/dist/auth/rbac/index.d.ts +8 -0
- package/dist/auth/rbac/index.d.ts.map +1 -0
- package/dist/auth/rbac/index.js +32 -0
- package/dist/auth/rbac/index.js.map +1 -0
- package/dist/auth/rbac/middleware.d.ts +4 -0
- package/dist/auth/rbac/middleware.d.ts.map +1 -0
- package/dist/auth/rbac/middleware.js +9 -0
- package/dist/auth/rbac/middleware.js.map +1 -0
- package/dist/auth/rbac/namespace.d.ts +15 -0
- package/dist/auth/rbac/namespace.d.ts.map +1 -0
- package/dist/auth/rbac/namespace.js +15 -0
- package/dist/auth/rbac/namespace.js.map +1 -0
- package/dist/auth/rbac/resolve.d.ts +4 -0
- package/dist/auth/rbac/resolve.d.ts.map +1 -0
- package/dist/auth/rbac/resolve.js +24 -0
- package/dist/auth/rbac/resolve.js.map +1 -0
- package/dist/auth/rbac/seed.d.ts +4 -0
- package/dist/auth/rbac/seed.d.ts.map +1 -0
- package/dist/auth/rbac/seed.js +63 -0
- package/dist/auth/rbac/seed.js.map +1 -0
- package/dist/auth/rbac/types.d.ts +56 -0
- package/dist/auth/rbac/types.d.ts.map +1 -0
- package/dist/auth/rbac/types.js +2 -0
- package/dist/auth/rbac/types.js.map +1 -0
- package/dist/auth/tenant/extract.d.ts +6 -0
- package/dist/auth/tenant/extract.d.ts.map +1 -0
- package/dist/auth/tenant/extract.js +18 -0
- package/dist/auth/tenant/extract.js.map +1 -0
- package/dist/auth/tenant/index.d.ts +8 -0
- package/dist/auth/tenant/index.d.ts.map +1 -0
- package/dist/auth/tenant/index.js +7 -0
- package/dist/auth/tenant/index.js.map +1 -0
- package/dist/auth/tenant/namespace.d.ts +23 -0
- package/dist/auth/tenant/namespace.d.ts.map +1 -0
- package/dist/auth/tenant/namespace.js +23 -0
- package/dist/auth/tenant/namespace.js.map +1 -0
- package/dist/auth/tenant/propagate.d.ts +4 -0
- package/dist/auth/tenant/propagate.d.ts.map +1 -0
- package/dist/auth/tenant/propagate.js +15 -0
- package/dist/auth/tenant/propagate.js.map +1 -0
- package/dist/auth/tenant/rls.d.ts +5 -0
- package/dist/auth/tenant/rls.d.ts.map +1 -0
- package/dist/auth/tenant/rls.js +35 -0
- package/dist/auth/tenant/rls.js.map +1 -0
- package/dist/auth/tenant/scope.d.ts +8 -0
- package/dist/auth/tenant/scope.d.ts.map +1 -0
- package/dist/auth/tenant/scope.js +21 -0
- package/dist/auth/tenant/scope.js.map +1 -0
- package/dist/auth/tenant/scoped-db.d.ts +4 -0
- package/dist/auth/tenant/scoped-db.d.ts.map +1 -0
- package/dist/auth/tenant/scoped-db.js +234 -0
- package/dist/auth/tenant/scoped-db.js.map +1 -0
- package/dist/auth/tenant/types.d.ts +14 -0
- package/dist/auth/tenant/types.d.ts.map +1 -0
- package/dist/auth/tenant/types.js +2 -0
- package/dist/auth/tenant/types.js.map +1 -0
- package/dist/auth/tenant/validate.d.ts +4 -0
- package/dist/auth/tenant/validate.d.ts.map +1 -0
- package/dist/auth/tenant/validate.js +20 -0
- package/dist/auth/tenant/validate.js.map +1 -0
- package/dist/cli/commands/check.js +1 -1
- package/dist/cli/commands/check.js.map +1 -1
- package/dist/cli/commands/generate.js +2 -2
- package/dist/cli/commands/generate.js.map +1 -1
- package/dist/cli/commands/migrate.js +3 -3
- package/dist/cli/commands/migrate.js.map +1 -1
- package/dist/cli/commands/run.d.ts.map +1 -1
- package/dist/cli/commands/run.js +1 -3
- package/dist/cli/commands/run.js.map +1 -1
- package/dist/cli/commands/shared/load-config.d.ts +1 -1
- package/dist/cli/commands/shared/load-config.d.ts.map +1 -1
- package/dist/cli/commands/shared/load-config.js +1 -1
- package/dist/cli/commands/shared/load-config.js.map +1 -1
- package/dist/cli/commands/test.d.ts.map +1 -1
- package/dist/cli/commands/test.js +1 -3
- package/dist/cli/commands/test.js.map +1 -1
- package/dist/cli/dev-bootstrap.js +2 -2
- package/dist/cli/dev-bootstrap.js.map +1 -1
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +2 -0
- package/dist/cli/index.js.map +1 -1
- package/dist/core/config/discover.d.ts +4 -0
- package/dist/core/config/discover.d.ts.map +1 -0
- package/dist/core/config/discover.js +57 -0
- package/dist/core/config/discover.js.map +1 -0
- package/dist/core/config/env-resolve.d.ts +4 -0
- package/dist/core/config/env-resolve.d.ts.map +1 -0
- package/dist/core/config/env-resolve.js +71 -0
- package/dist/core/config/env-resolve.js.map +1 -0
- package/dist/core/config/env-types.d.ts +42 -0
- package/dist/core/config/env-types.d.ts.map +1 -0
- package/dist/core/config/env-types.js +2 -0
- package/dist/core/config/env-types.js.map +1 -0
- package/dist/core/config/env.d.ts +2 -0
- package/dist/core/config/env.d.ts.map +1 -0
- package/dist/core/config/env.js +48 -0
- package/dist/core/config/env.js.map +1 -0
- package/dist/core/config/index.d.ts +8 -0
- package/dist/core/config/index.d.ts.map +1 -0
- package/dist/core/config/index.js +7 -0
- package/dist/core/config/index.js.map +1 -0
- package/dist/core/config/load.d.ts +34 -0
- package/dist/core/config/load.d.ts.map +1 -0
- package/dist/core/config/load.js +113 -0
- package/dist/core/config/load.js.map +1 -0
- package/dist/core/config/namespace.d.ts +172 -0
- package/dist/core/config/namespace.d.ts.map +1 -0
- package/dist/core/config/namespace.js +14 -0
- package/dist/core/config/namespace.js.map +1 -0
- package/dist/core/config/resolve.d.ts +8 -0
- package/dist/core/config/resolve.d.ts.map +1 -0
- package/dist/core/config/resolve.js +43 -0
- package/dist/core/config/resolve.js.map +1 -0
- package/dist/core/config/schema.d.ts +400 -0
- package/dist/core/config/schema.d.ts.map +1 -0
- package/dist/core/config/schema.js +106 -0
- package/dist/core/config/schema.js.map +1 -0
- package/dist/core/config/ts-register.d.ts +2 -0
- package/dist/core/config/ts-register.d.ts.map +1 -0
- package/dist/core/config/ts-register.js +3 -0
- package/dist/core/config/ts-register.js.map +1 -0
- package/dist/core/config/ts-resolve-hooks.d.ts +10 -0
- package/dist/core/config/ts-resolve-hooks.d.ts.map +1 -0
- package/dist/core/config/ts-resolve-hooks.js +15 -0
- package/dist/core/config/ts-resolve-hooks.js.map +1 -0
- package/dist/core/errors/base.d.ts +7 -0
- package/dist/core/errors/base.d.ts.map +1 -0
- package/dist/core/errors/base.js +9 -0
- package/dist/core/errors/base.js.map +1 -0
- package/dist/core/errors/index.d.ts +3 -0
- package/dist/core/errors/index.d.ts.map +1 -0
- package/dist/core/errors/index.js +3 -0
- package/dist/core/errors/index.js.map +1 -0
- package/dist/core/errors/namespace.d.ts +17 -0
- package/dist/core/errors/namespace.d.ts.map +1 -0
- package/dist/core/errors/namespace.js +17 -0
- package/dist/core/errors/namespace.js.map +1 -0
- package/dist/core/errors/types.d.ts +29 -0
- package/dist/core/errors/types.d.ts.map +1 -0
- package/dist/core/errors/types.js +46 -0
- package/dist/core/errors/types.js.map +1 -0
- package/dist/core/lifecycle/drain.d.ts +7 -0
- package/dist/core/lifecycle/drain.d.ts.map +1 -0
- package/dist/core/lifecycle/drain.js +24 -0
- package/dist/core/lifecycle/drain.js.map +1 -0
- package/dist/core/lifecycle/health.d.ts +8 -0
- package/dist/core/lifecycle/health.d.ts.map +1 -0
- package/dist/core/lifecycle/health.js +62 -0
- package/dist/core/lifecycle/health.js.map +1 -0
- package/dist/core/lifecycle/index.d.ts +5 -0
- package/dist/core/lifecycle/index.d.ts.map +1 -0
- package/dist/core/lifecycle/index.js +4 -0
- package/dist/core/lifecycle/index.js.map +1 -0
- package/dist/core/lifecycle/namespace.d.ts +7 -0
- package/dist/core/lifecycle/namespace.d.ts.map +1 -0
- package/dist/core/lifecycle/namespace.js +7 -0
- package/dist/core/lifecycle/namespace.js.map +1 -0
- package/dist/core/lifecycle/startup.d.ts +8 -0
- package/dist/core/lifecycle/startup.d.ts.map +1 -0
- package/dist/core/lifecycle/startup.js +43 -0
- package/dist/core/lifecycle/startup.js.map +1 -0
- package/dist/core/lifecycle/types.d.ts +30 -0
- package/dist/core/lifecycle/types.d.ts.map +1 -0
- package/dist/core/lifecycle/types.js +2 -0
- package/dist/core/lifecycle/types.js.map +1 -0
- package/dist/core/log/namespace.d.ts +15 -0
- package/dist/core/log/namespace.d.ts.map +1 -0
- package/dist/core/log/namespace.js +16 -0
- package/dist/core/log/namespace.js.map +1 -0
- package/dist/core/logging/context.d.ts +11 -0
- package/dist/core/logging/context.d.ts.map +1 -0
- package/dist/core/logging/context.js +46 -0
- package/dist/core/logging/context.js.map +1 -0
- package/dist/core/logging/index.d.ts +4 -0
- package/dist/core/logging/index.d.ts.map +1 -0
- package/dist/core/logging/index.js +3 -0
- package/dist/core/logging/index.js.map +1 -0
- package/dist/core/logging/logger.d.ts +8 -0
- package/dist/core/logging/logger.d.ts.map +1 -0
- package/dist/core/logging/logger.js +39 -0
- package/dist/core/logging/logger.js.map +1 -0
- package/dist/core/logging/proxy.d.ts +3 -0
- package/dist/core/logging/proxy.d.ts.map +1 -0
- package/dist/core/logging/proxy.js +21 -0
- package/dist/core/logging/proxy.js.map +1 -0
- package/dist/core/logging/types.d.ts +43 -0
- package/dist/core/logging/types.d.ts.map +1 -0
- package/dist/core/logging/types.js +2 -0
- package/dist/core/logging/types.js.map +1 -0
- package/dist/core/pipework.d.ts +88 -0
- package/dist/core/pipework.d.ts.map +1 -0
- package/dist/core/pipework.js +222 -0
- package/dist/core/pipework.js.map +1 -0
- package/dist/core/surface/http.d.ts +3 -0
- package/dist/core/surface/http.d.ts.map +1 -0
- package/dist/core/surface/http.js +101 -0
- package/dist/core/surface/http.js.map +1 -0
- package/dist/core/surface/index.d.ts +7 -0
- package/dist/core/surface/index.d.ts.map +1 -0
- package/dist/core/surface/index.js +6 -0
- package/dist/core/surface/index.js.map +1 -0
- package/dist/core/surface/namespace.d.ts +13 -0
- package/dist/core/surface/namespace.d.ts.map +1 -0
- package/dist/core/surface/namespace.js +13 -0
- package/dist/core/surface/namespace.js.map +1 -0
- package/dist/core/surface/script.d.ts +3 -0
- package/dist/core/surface/script.d.ts.map +1 -0
- package/dist/core/surface/script.js +24 -0
- package/dist/core/surface/script.js.map +1 -0
- package/dist/core/surface/start.d.ts +8 -0
- package/dist/core/surface/start.d.ts.map +1 -0
- package/dist/core/surface/start.js +64 -0
- package/dist/core/surface/start.js.map +1 -0
- package/dist/core/surface/types.d.ts +118 -0
- package/dist/core/surface/types.d.ts.map +1 -0
- package/dist/core/surface/types.js +2 -0
- package/dist/core/surface/types.js.map +1 -0
- package/dist/core/surface/validate.d.ts +7 -0
- package/dist/core/surface/validate.d.ts.map +1 -0
- package/dist/core/surface/validate.js +121 -0
- package/dist/core/surface/validate.js.map +1 -0
- package/dist/core/surface/worker.d.ts +3 -0
- package/dist/core/surface/worker.d.ts.map +1 -0
- package/dist/core/surface/worker.js +151 -0
- package/dist/core/surface/worker.js.map +1 -0
- package/dist/core/validation/connectivity.d.ts +4 -0
- package/dist/core/validation/connectivity.d.ts.map +1 -0
- package/dist/core/validation/connectivity.js +32 -0
- package/dist/core/validation/connectivity.js.map +1 -0
- package/dist/core/validation/doctrine.d.ts +13 -0
- package/dist/core/validation/doctrine.d.ts.map +1 -0
- package/dist/core/validation/doctrine.js +115 -0
- package/dist/core/validation/doctrine.js.map +1 -0
- package/dist/core/validation/domain.d.ts +4 -0
- package/dist/core/validation/domain.d.ts.map +1 -0
- package/dist/core/validation/domain.js +72 -0
- package/dist/core/validation/domain.js.map +1 -0
- package/dist/core/validation/index.d.ts +6 -0
- package/dist/core/validation/index.d.ts.map +1 -0
- package/dist/core/validation/index.js +6 -0
- package/dist/core/validation/index.js.map +1 -0
- package/dist/core/validation/startup.d.ts +12 -0
- package/dist/core/validation/startup.d.ts.map +1 -0
- package/dist/core/validation/startup.js +19 -0
- package/dist/core/validation/startup.js.map +1 -0
- package/dist/core/validation/types.d.ts +13 -0
- package/dist/core/validation/types.d.ts.map +1 -0
- package/dist/core/validation/types.js +13 -0
- package/dist/core/validation/types.js.map +1 -0
- package/dist/data/db/col/index.d.ts +2 -0
- package/dist/data/db/col/index.d.ts.map +1 -0
- package/dist/data/db/col/index.js +5 -0
- package/dist/data/db/col/index.js.map +1 -0
- package/dist/data/db/context.d.ts +4 -0
- package/dist/data/db/context.d.ts.map +1 -0
- package/dist/data/db/context.js +3 -0
- package/dist/data/db/context.js.map +1 -0
- package/dist/data/db/db.d.ts +6 -0
- package/dist/data/db/db.d.ts.map +1 -0
- package/dist/data/db/db.js +65 -0
- package/dist/data/db/db.js.map +1 -0
- package/dist/data/db/excluded.d.ts +7 -0
- package/dist/data/db/excluded.d.ts.map +1 -0
- package/dist/data/db/excluded.js +11 -0
- package/dist/data/db/excluded.js.map +1 -0
- package/dist/data/db/filter.d.ts +46 -0
- package/dist/data/db/filter.d.ts.map +1 -0
- package/dist/data/db/filter.js +9 -0
- package/dist/data/db/filter.js.map +1 -0
- package/dist/data/db/generated/drizzle-orm/aggregate.d.ts +2 -0
- package/dist/data/db/generated/drizzle-orm/aggregate.d.ts.map +1 -0
- package/dist/data/db/generated/drizzle-orm/aggregate.js +5 -0
- package/dist/data/db/generated/drizzle-orm/aggregate.js.map +1 -0
- package/dist/data/db/generated/drizzle-orm/introspection.d.ts +2 -0
- package/dist/data/db/generated/drizzle-orm/introspection.d.ts.map +1 -0
- package/dist/data/db/generated/drizzle-orm/introspection.js +5 -0
- package/dist/data/db/generated/drizzle-orm/introspection.js.map +1 -0
- package/dist/data/db/generated/drizzle-orm/operator.d.ts +2 -0
- package/dist/data/db/generated/drizzle-orm/operator.d.ts.map +1 -0
- package/dist/data/db/generated/drizzle-orm/operator.js +5 -0
- package/dist/data/db/generated/drizzle-orm/operator.js.map +1 -0
- package/dist/data/db/generated/drizzle-orm/relation.d.ts +2 -0
- package/dist/data/db/generated/drizzle-orm/relation.d.ts.map +1 -0
- package/dist/data/db/generated/drizzle-orm/relation.js +5 -0
- package/dist/data/db/generated/drizzle-orm/relation.js.map +1 -0
- package/dist/data/db/generated/drizzle-orm/type.d.ts +3 -0
- package/dist/data/db/generated/drizzle-orm/type.d.ts.map +1 -0
- package/dist/data/db/generated/drizzle-orm/type.js +5 -0
- package/dist/data/db/generated/drizzle-orm/type.js.map +1 -0
- package/dist/data/db/generated/pg-core/introspection.d.ts +2 -0
- package/dist/data/db/generated/pg-core/introspection.d.ts.map +1 -0
- package/dist/data/db/generated/pg-core/introspection.js +5 -0
- package/dist/data/db/generated/pg-core/introspection.js.map +1 -0
- package/dist/data/db/generated/pg-core/set-operation.d.ts +2 -0
- package/dist/data/db/generated/pg-core/set-operation.d.ts.map +1 -0
- package/dist/data/db/generated/pg-core/set-operation.js +5 -0
- package/dist/data/db/generated/pg-core/set-operation.js.map +1 -0
- package/dist/data/db/generated/pg-core/type.d.ts +3 -0
- package/dist/data/db/generated/pg-core/type.d.ts.map +1 -0
- package/dist/data/db/generated/pg-core/type.js +5 -0
- package/dist/data/db/generated/pg-core/type.js.map +1 -0
- package/dist/data/db/identifiers.d.ts +3 -0
- package/dist/data/db/identifiers.d.ts.map +1 -0
- package/dist/data/db/identifiers.js +13 -0
- package/dist/data/db/identifiers.js.map +1 -0
- package/dist/data/db/idx/index.d.ts +2 -0
- package/dist/data/db/idx/index.d.ts.map +1 -0
- package/dist/data/db/idx/index.js +5 -0
- package/dist/data/db/idx/index.js.map +1 -0
- package/dist/data/db/index.d.ts +10 -0
- package/dist/data/db/index.d.ts.map +1 -0
- package/dist/data/db/index.js +8 -0
- package/dist/data/db/index.js.map +1 -0
- package/dist/data/db/instrumentation.d.ts +5 -0
- package/dist/data/db/instrumentation.d.ts.map +1 -0
- package/dist/data/db/instrumentation.js +44 -0
- package/dist/data/db/instrumentation.js.map +1 -0
- package/dist/data/db/namespace.d.ts +94 -0
- package/dist/data/db/namespace.d.ts.map +1 -0
- package/dist/data/db/namespace.js +35 -0
- package/dist/data/db/namespace.js.map +1 -0
- package/dist/data/db/pool.d.ts +17 -0
- package/dist/data/db/pool.d.ts.map +1 -0
- package/dist/data/db/pool.js +39 -0
- package/dist/data/db/pool.js.map +1 -0
- package/dist/data/db/schema-features.d.ts +2 -0
- package/dist/data/db/schema-features.d.ts.map +1 -0
- package/dist/data/db/schema-features.js +4 -0
- package/dist/data/db/schema-features.js.map +1 -0
- package/dist/data/db/sql.d.ts +2 -0
- package/dist/data/db/sql.d.ts.map +1 -0
- package/dist/data/db/sql.js +2 -0
- package/dist/data/db/sql.js.map +1 -0
- package/dist/data/db/types.d.ts +17 -0
- package/dist/data/db/types.d.ts.map +1 -0
- package/dist/data/db/types.js +2 -0
- package/dist/data/db/types.js.map +1 -0
- package/dist/data/domain/brand.d.ts +19 -0
- package/dist/data/domain/brand.d.ts.map +1 -0
- package/dist/data/domain/brand.js +2 -0
- package/dist/data/domain/brand.js.map +1 -0
- package/dist/data/domain/define.d.ts +5 -0
- package/dist/data/domain/define.d.ts.map +1 -0
- package/dist/data/domain/define.js +155 -0
- package/dist/data/domain/define.js.map +1 -0
- package/dist/data/domain/field.d.ts +37 -0
- package/dist/data/domain/field.d.ts.map +1 -0
- package/dist/data/domain/field.js +115 -0
- package/dist/data/domain/field.js.map +1 -0
- package/dist/data/domain/index.d.ts +8 -0
- package/dist/data/domain/index.d.ts.map +1 -0
- package/dist/data/domain/index.js +6 -0
- package/dist/data/domain/index.js.map +1 -0
- package/dist/data/domain/naming.d.ts +2 -0
- package/dist/data/domain/naming.d.ts.map +1 -0
- package/dist/data/domain/naming.js +7 -0
- package/dist/data/domain/naming.js.map +1 -0
- package/dist/data/domain/project-factory.d.ts +4 -0
- package/dist/data/domain/project-factory.d.ts.map +1 -0
- package/dist/data/domain/project-factory.js +138 -0
- package/dist/data/domain/project-factory.js.map +1 -0
- package/dist/data/domain/project-schema.d.ts +6 -0
- package/dist/data/domain/project-schema.d.ts.map +1 -0
- package/dist/data/domain/project-schema.js +123 -0
- package/dist/data/domain/project-schema.js.map +1 -0
- package/dist/data/domain/project-table.d.ts +30 -0
- package/dist/data/domain/project-table.d.ts.map +1 -0
- package/dist/data/domain/project-table.js +125 -0
- package/dist/data/domain/project-table.js.map +1 -0
- package/dist/data/domain/traits.d.ts +9 -0
- package/dist/data/domain/traits.d.ts.map +1 -0
- package/dist/data/domain/traits.js +48 -0
- package/dist/data/domain/traits.js.map +1 -0
- package/dist/data/domain/types.d.ts +130 -0
- package/dist/data/domain/types.d.ts.map +1 -0
- package/dist/data/domain/types.js +2 -0
- package/dist/data/domain/types.js.map +1 -0
- package/dist/data/jsonb/index.d.ts +2 -0
- package/dist/data/jsonb/index.d.ts.map +1 -0
- package/dist/data/jsonb/index.js +2 -0
- package/dist/data/jsonb/index.js.map +1 -0
- package/dist/data/jsonb/namespace.d.ts +11 -0
- package/dist/data/jsonb/namespace.d.ts.map +1 -0
- package/dist/data/jsonb/namespace.js +11 -0
- package/dist/data/jsonb/namespace.js.map +1 -0
- package/dist/data/jsonb/query.d.ts +5 -0
- package/dist/data/jsonb/query.d.ts.map +1 -0
- package/dist/data/jsonb/query.js +11 -0
- package/dist/data/jsonb/query.js.map +1 -0
- package/dist/data/migrate/check.d.ts +14 -0
- package/dist/data/migrate/check.d.ts.map +1 -0
- package/dist/data/migrate/check.js +58 -0
- package/dist/data/migrate/check.js.map +1 -0
- package/dist/data/migrate/generate.d.ts +9 -0
- package/dist/data/migrate/generate.d.ts.map +1 -0
- package/dist/data/migrate/generate.js +152 -0
- package/dist/data/migrate/generate.js.map +1 -0
- package/dist/data/migrate/index.d.ts +7 -0
- package/dist/data/migrate/index.d.ts.map +1 -0
- package/dist/data/migrate/index.js +7 -0
- package/dist/data/migrate/index.js.map +1 -0
- package/dist/data/migrate/post-process.d.ts +9 -0
- package/dist/data/migrate/post-process.d.ts.map +1 -0
- package/dist/data/migrate/post-process.js +60 -0
- package/dist/data/migrate/post-process.js.map +1 -0
- package/dist/data/migrate/rls-generate.d.ts +3 -0
- package/dist/data/migrate/rls-generate.d.ts.map +1 -0
- package/dist/data/migrate/rls-generate.js +28 -0
- package/dist/data/migrate/rls-generate.js.map +1 -0
- package/dist/data/migrate/run.d.ts +21 -0
- package/dist/data/migrate/run.d.ts.map +1 -0
- package/dist/data/migrate/run.js +66 -0
- package/dist/data/migrate/run.js.map +1 -0
- package/dist/data/migrate/safety.d.ts +10 -0
- package/dist/data/migrate/safety.d.ts.map +1 -0
- package/dist/data/migrate/safety.js +115 -0
- package/dist/data/migrate/safety.js.map +1 -0
- package/dist/data/schema/branded.d.ts +3 -0
- package/dist/data/schema/branded.d.ts.map +1 -0
- package/dist/data/schema/branded.js +8 -0
- package/dist/data/schema/branded.js.map +1 -0
- package/dist/data/schema/generated/coerce.d.ts +2 -0
- package/dist/data/schema/generated/coerce.d.ts.map +1 -0
- package/dist/data/schema/generated/coerce.js +5 -0
- package/dist/data/schema/generated/coerce.js.map +1 -0
- package/dist/data/schema/generated/combinator.d.ts +3 -0
- package/dist/data/schema/generated/combinator.d.ts.map +1 -0
- package/dist/data/schema/generated/combinator.js +5 -0
- package/dist/data/schema/generated/combinator.js.map +1 -0
- package/dist/data/schema/generated/encoding.d.ts +2 -0
- package/dist/data/schema/generated/encoding.d.ts.map +1 -0
- package/dist/data/schema/generated/encoding.js +5 -0
- package/dist/data/schema/generated/encoding.js.map +1 -0
- package/dist/data/schema/generated/error.d.ts +3 -0
- package/dist/data/schema/generated/error.d.ts.map +1 -0
- package/dist/data/schema/generated/error.js +5 -0
- package/dist/data/schema/generated/error.js.map +1 -0
- package/dist/data/schema/generated/format.d.ts +2 -0
- package/dist/data/schema/generated/format.d.ts.map +1 -0
- package/dist/data/schema/generated/format.js +5 -0
- package/dist/data/schema/generated/format.js.map +1 -0
- package/dist/data/schema/generated/type-constructor.d.ts +3 -0
- package/dist/data/schema/generated/type-constructor.d.ts.map +1 -0
- package/dist/data/schema/generated/type-constructor.js +8 -0
- package/dist/data/schema/generated/type-constructor.js.map +1 -0
- package/dist/data/schema/generated/type.d.ts +3 -0
- package/dist/data/schema/generated/type.d.ts.map +1 -0
- package/dist/data/schema/generated/type.js +5 -0
- package/dist/data/schema/generated/type.js.map +1 -0
- package/dist/data/schema/index.d.ts +6 -0
- package/dist/data/schema/index.d.ts.map +1 -0
- package/dist/data/schema/index.js +5 -0
- package/dist/data/schema/index.js.map +1 -0
- package/dist/data/schema/json-schema.d.ts +5 -0
- package/dist/data/schema/json-schema.d.ts.map +1 -0
- package/dist/data/schema/json-schema.js +5 -0
- package/dist/data/schema/json-schema.js.map +1 -0
- package/dist/data/schema/namespace.d.ts +139 -0
- package/dist/data/schema/namespace.d.ts.map +1 -0
- package/dist/data/schema/namespace.js +46 -0
- package/dist/data/schema/namespace.js.map +1 -0
- package/dist/data/schema/parse.d.ts +11 -0
- package/dist/data/schema/parse.d.ts.map +1 -0
- package/dist/data/schema/parse.js +30 -0
- package/dist/data/schema/parse.js.map +1 -0
- package/dist/data/schema/types.d.ts +6 -0
- package/dist/data/schema/types.d.ts.map +1 -0
- package/dist/data/schema/types.js +2 -0
- package/dist/data/schema/types.js.map +1 -0
- package/dist/data/temporal/close.d.ts +3 -0
- package/dist/data/temporal/close.d.ts.map +1 -0
- package/dist/data/temporal/close.js +19 -0
- package/dist/data/temporal/close.js.map +1 -0
- package/dist/data/temporal/columns.d.ts +7 -0
- package/dist/data/temporal/columns.d.ts.map +1 -0
- package/dist/data/temporal/columns.js +10 -0
- package/dist/data/temporal/columns.js.map +1 -0
- package/dist/data/temporal/definition-queries.d.ts +14 -0
- package/dist/data/temporal/definition-queries.d.ts.map +1 -0
- package/dist/data/temporal/definition-queries.js +45 -0
- package/dist/data/temporal/definition-queries.js.map +1 -0
- package/dist/data/temporal/errors.d.ts +7 -0
- package/dist/data/temporal/errors.d.ts.map +1 -0
- package/dist/data/temporal/errors.js +9 -0
- package/dist/data/temporal/errors.js.map +1 -0
- package/dist/data/temporal/get-current.d.ts +3 -0
- package/dist/data/temporal/get-current.d.ts.map +1 -0
- package/dist/data/temporal/get-current.js +18 -0
- package/dist/data/temporal/get-current.js.map +1 -0
- package/dist/data/temporal/index.d.ts +9 -0
- package/dist/data/temporal/index.d.ts.map +1 -0
- package/dist/data/temporal/index.js +8 -0
- package/dist/data/temporal/index.js.map +1 -0
- package/dist/data/temporal/namespace.d.ts +31 -0
- package/dist/data/temporal/namespace.d.ts.map +1 -0
- package/dist/data/temporal/namespace.js +31 -0
- package/dist/data/temporal/namespace.js.map +1 -0
- package/dist/data/temporal/query.d.ts +10 -0
- package/dist/data/temporal/query.d.ts.map +1 -0
- package/dist/data/temporal/query.js +11 -0
- package/dist/data/temporal/query.js.map +1 -0
- package/dist/data/temporal/revise.d.ts +3 -0
- package/dist/data/temporal/revise.d.ts.map +1 -0
- package/dist/data/temporal/revise.js +52 -0
- package/dist/data/temporal/revise.js.map +1 -0
- package/dist/data/temporal/types.d.ts +19 -0
- package/dist/data/temporal/types.d.ts.map +1 -0
- package/dist/data/temporal/types.js +2 -0
- package/dist/data/temporal/types.js.map +1 -0
- package/dist/data/vector/index.d.ts +5 -0
- package/dist/data/vector/index.d.ts.map +1 -0
- package/dist/data/vector/index.js +4 -0
- package/dist/data/vector/index.js.map +1 -0
- package/dist/data/vector/namespace.d.ts +33 -0
- package/dist/data/vector/namespace.d.ts.map +1 -0
- package/dist/data/vector/namespace.js +33 -0
- package/dist/data/vector/namespace.js.map +1 -0
- package/dist/data/vector/query.d.ts +22 -0
- package/dist/data/vector/query.d.ts.map +1 -0
- package/dist/data/vector/query.js +71 -0
- package/dist/data/vector/query.js.map +1 -0
- package/dist/data/vector/types.d.ts +19 -0
- package/dist/data/vector/types.d.ts.map +1 -0
- package/dist/data/vector/types.js +26 -0
- package/dist/data/vector/types.js.map +1 -0
- package/dist/data/vector/validate.d.ts +3 -0
- package/dist/data/vector/validate.d.ts.map +1 -0
- package/dist/data/vector/validate.js +10 -0
- package/dist/data/vector/validate.js.map +1 -0
- package/dist/db/excluded.d.ts +7 -0
- package/dist/db/excluded.d.ts.map +1 -0
- package/dist/db/excluded.js +11 -0
- package/dist/db/excluded.js.map +1 -0
- package/dist/db/index.d.ts +1 -0
- package/dist/db/index.d.ts.map +1 -1
- package/dist/db/index.js +1 -0
- package/dist/db/index.js.map +1 -1
- package/dist/db/namespace.d.ts +5 -0
- package/dist/db/namespace.d.ts.map +1 -1
- package/dist/db/namespace.js +5 -0
- package/dist/db/namespace.js.map +1 -1
- package/dist/domain/field.d.ts +4 -2
- package/dist/domain/field.d.ts.map +1 -1
- package/dist/domain/field.js.map +1 -1
- package/dist/domain/index.d.ts +1 -1
- package/dist/domain/index.d.ts.map +1 -1
- package/dist/domain/types.d.ts +19 -6
- package/dist/domain/types.d.ts.map +1 -1
- package/dist/index.d.ts +64 -64
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +30 -30
- package/dist/index.js.map +1 -1
- package/dist/infra/audit/emit.d.ts +3 -0
- package/dist/infra/audit/emit.d.ts.map +1 -0
- package/dist/infra/audit/emit.js +66 -0
- package/dist/infra/audit/emit.js.map +1 -0
- package/dist/infra/audit/index.d.ts +3 -0
- package/dist/infra/audit/index.d.ts.map +1 -0
- package/dist/infra/audit/index.js +2 -0
- package/dist/infra/audit/index.js.map +1 -0
- package/dist/infra/audit/namespace.d.ts +7 -0
- package/dist/infra/audit/namespace.d.ts.map +1 -0
- package/dist/infra/audit/namespace.js +7 -0
- package/dist/infra/audit/namespace.js.map +1 -0
- package/dist/infra/audit/types.d.ts +17 -0
- package/dist/infra/audit/types.d.ts.map +1 -0
- package/dist/infra/audit/types.js +2 -0
- package/dist/infra/audit/types.js.map +1 -0
- package/dist/infra/cache/create.d.ts +3 -0
- package/dist/infra/cache/create.d.ts.map +1 -0
- package/dist/infra/cache/create.js +90 -0
- package/dist/infra/cache/create.js.map +1 -0
- package/dist/infra/cache/index.d.ts +5 -0
- package/dist/infra/cache/index.d.ts.map +1 -0
- package/dist/infra/cache/index.js +3 -0
- package/dist/infra/cache/index.js.map +1 -0
- package/dist/infra/cache/namespace.d.ts +10 -0
- package/dist/infra/cache/namespace.d.ts.map +1 -0
- package/dist/infra/cache/namespace.js +10 -0
- package/dist/infra/cache/namespace.js.map +1 -0
- package/dist/infra/cache/tenant.d.ts +21 -0
- package/dist/infra/cache/tenant.d.ts.map +1 -0
- package/dist/infra/cache/tenant.js +101 -0
- package/dist/infra/cache/tenant.js.map +1 -0
- package/dist/infra/cache/types.d.ts +22 -0
- package/dist/infra/cache/types.d.ts.map +1 -0
- package/dist/infra/cache/types.js +2 -0
- package/dist/infra/cache/types.js.map +1 -0
- package/dist/infra/idempotency/index.d.ts +4 -0
- package/dist/infra/idempotency/index.d.ts.map +1 -0
- package/dist/infra/idempotency/index.js +3 -0
- package/dist/infra/idempotency/index.js.map +1 -0
- package/dist/infra/idempotency/middleware.d.ts +21 -0
- package/dist/infra/idempotency/middleware.d.ts.map +1 -0
- package/dist/infra/idempotency/middleware.js +56 -0
- package/dist/infra/idempotency/middleware.js.map +1 -0
- package/dist/infra/idempotency/store.d.ts +3 -0
- package/dist/infra/idempotency/store.d.ts.map +1 -0
- package/dist/infra/idempotency/store.js +63 -0
- package/dist/infra/idempotency/store.js.map +1 -0
- package/dist/infra/idempotency/types.d.ts +28 -0
- package/dist/infra/idempotency/types.d.ts.map +1 -0
- package/dist/infra/idempotency/types.js +2 -0
- package/dist/infra/idempotency/types.js.map +1 -0
- package/dist/infra/webhook/inbound.d.ts +16 -0
- package/dist/infra/webhook/inbound.d.ts.map +1 -0
- package/dist/infra/webhook/inbound.js +21 -0
- package/dist/infra/webhook/inbound.js.map +1 -0
- package/dist/infra/webhook/index.d.ts +5 -0
- package/dist/infra/webhook/index.d.ts.map +1 -0
- package/dist/infra/webhook/index.js +5 -0
- package/dist/infra/webhook/index.js.map +1 -0
- package/dist/infra/webhook/namespace.d.ts +22 -0
- package/dist/infra/webhook/namespace.d.ts.map +1 -0
- package/dist/infra/webhook/namespace.js +22 -0
- package/dist/infra/webhook/namespace.js.map +1 -0
- package/dist/infra/webhook/outbound.d.ts +48 -0
- package/dist/infra/webhook/outbound.d.ts.map +1 -0
- package/dist/infra/webhook/outbound.js +160 -0
- package/dist/infra/webhook/outbound.js.map +1 -0
- package/dist/infra/webhook/sign.d.ts +12 -0
- package/dist/infra/webhook/sign.d.ts.map +1 -0
- package/dist/infra/webhook/sign.js +12 -0
- package/dist/infra/webhook/sign.js.map +1 -0
- package/dist/infra/webhook/verify.d.ts +16 -0
- package/dist/infra/webhook/verify.d.ts.map +1 -0
- package/dist/infra/webhook/verify.js +64 -0
- package/dist/infra/webhook/verify.js.map +1 -0
- package/dist/log/namespace.d.ts +1 -1
- package/dist/logging/index.d.ts +1 -1
- package/dist/logging/index.d.ts.map +1 -1
- package/dist/logging/proxy.d.ts +2 -2
- package/dist/logging/proxy.d.ts.map +1 -1
- package/dist/logging/proxy.js +9 -2
- package/dist/logging/proxy.js.map +1 -1
- package/dist/logging/types.d.ts +7 -0
- package/dist/logging/types.d.ts.map +1 -1
- package/dist/request/behavior/audited.d.ts +5 -0
- package/dist/request/behavior/audited.d.ts.map +1 -0
- package/dist/request/behavior/audited.js +78 -0
- package/dist/request/behavior/audited.js.map +1 -0
- package/dist/request/behavior/cached.d.ts +7 -0
- package/dist/request/behavior/cached.d.ts.map +1 -0
- package/dist/request/behavior/cached.js +48 -0
- package/dist/request/behavior/cached.js.map +1 -0
- package/dist/request/behavior/compose.d.ts +4 -0
- package/dist/request/behavior/compose.d.ts.map +1 -0
- package/dist/request/behavior/compose.js +18 -0
- package/dist/request/behavior/compose.js.map +1 -0
- package/dist/request/behavior/index.d.ts +6 -0
- package/dist/request/behavior/index.d.ts.map +1 -0
- package/dist/request/behavior/index.js +5 -0
- package/dist/request/behavior/index.js.map +1 -0
- package/dist/request/behavior/namespace.d.ts +16 -0
- package/dist/request/behavior/namespace.d.ts.map +1 -0
- package/dist/request/behavior/namespace.js +16 -0
- package/dist/request/behavior/namespace.js.map +1 -0
- package/dist/request/behavior/types.d.ts +23 -0
- package/dist/request/behavior/types.d.ts.map +1 -0
- package/dist/request/behavior/types.js +2 -0
- package/dist/request/behavior/types.js.map +1 -0
- package/dist/request/behavior/versioned.d.ts +4 -0
- package/dist/request/behavior/versioned.d.ts.map +1 -0
- package/dist/request/behavior/versioned.js +39 -0
- package/dist/request/behavior/versioned.js.map +1 -0
- package/dist/request/context/create.d.ts +24 -0
- package/dist/request/context/create.d.ts.map +1 -0
- package/dist/request/context/create.js +38 -0
- package/dist/request/context/create.js.map +1 -0
- package/dist/request/context/guard.d.ts +5 -0
- package/dist/request/context/guard.d.ts.map +1 -0
- package/dist/request/context/guard.js +35 -0
- package/dist/request/context/guard.js.map +1 -0
- package/dist/request/context/index.d.ts +5 -0
- package/dist/request/context/index.d.ts.map +1 -0
- package/dist/request/context/index.js +4 -0
- package/dist/request/context/index.js.map +1 -0
- package/dist/request/context/store.d.ts +7 -0
- package/dist/request/context/store.d.ts.map +1 -0
- package/dist/request/context/store.js +18 -0
- package/dist/request/context/store.js.map +1 -0
- package/dist/request/context/types.d.ts +28 -0
- package/dist/request/context/types.d.ts.map +1 -0
- package/dist/request/context/types.js +2 -0
- package/dist/request/context/types.js.map +1 -0
- package/dist/request/di/builder.d.ts +73 -0
- package/dist/request/di/builder.d.ts.map +1 -0
- package/dist/request/di/builder.js +189 -0
- package/dist/request/di/builder.js.map +1 -0
- package/dist/request/di/index.d.ts +6 -0
- package/dist/request/di/index.d.ts.map +1 -0
- package/dist/request/di/index.js +6 -0
- package/dist/request/di/index.js.map +1 -0
- package/dist/request/di/resolve.d.ts +9 -0
- package/dist/request/di/resolve.d.ts.map +1 -0
- package/dist/request/di/resolve.js +90 -0
- package/dist/request/di/resolve.js.map +1 -0
- package/dist/request/di/types.d.ts +56 -0
- package/dist/request/di/types.d.ts.map +1 -0
- package/dist/request/di/types.js +3 -0
- package/dist/request/di/types.js.map +1 -0
- package/dist/request/fitting/namespace.d.ts +3 -0
- package/dist/request/fitting/namespace.d.ts.map +1 -0
- package/dist/request/fitting/namespace.js +4 -0
- package/dist/request/fitting/namespace.js.map +1 -0
- package/dist/request/fixture/batch.d.ts +17 -0
- package/dist/request/fixture/batch.d.ts.map +1 -0
- package/dist/request/fixture/batch.js +47 -0
- package/dist/request/fixture/batch.js.map +1 -0
- package/dist/request/fixture/builder.d.ts +11 -0
- package/dist/request/fixture/builder.d.ts.map +1 -0
- package/dist/request/fixture/builder.js +12 -0
- package/dist/request/fixture/builder.js.map +1 -0
- package/dist/request/fixture/errors.d.ts +7 -0
- package/dist/request/fixture/errors.d.ts.map +1 -0
- package/dist/request/fixture/errors.js +9 -0
- package/dist/request/fixture/errors.js.map +1 -0
- package/dist/request/fixture/index.d.ts +9 -0
- package/dist/request/fixture/index.d.ts.map +1 -0
- package/dist/request/fixture/index.js +6 -0
- package/dist/request/fixture/index.js.map +1 -0
- package/dist/request/fixture/namespace.d.ts +23 -0
- package/dist/request/fixture/namespace.d.ts.map +1 -0
- package/dist/request/fixture/namespace.js +23 -0
- package/dist/request/fixture/namespace.js.map +1 -0
- package/dist/request/fixture/paginate.d.ts +13 -0
- package/dist/request/fixture/paginate.d.ts.map +1 -0
- package/dist/request/fixture/paginate.js +29 -0
- package/dist/request/fixture/paginate.js.map +1 -0
- package/dist/request/fixture/register.d.ts +16 -0
- package/dist/request/fixture/register.d.ts.map +1 -0
- package/dist/request/fixture/register.js +181 -0
- package/dist/request/fixture/register.js.map +1 -0
- package/dist/request/fixture/to-handlers.d.ts +6 -0
- package/dist/request/fixture/to-handlers.d.ts.map +1 -0
- package/dist/request/fixture/to-handlers.js +245 -0
- package/dist/request/fixture/to-handlers.js.map +1 -0
- package/dist/request/fixture/types.d.ts +69 -0
- package/dist/request/fixture/types.d.ts.map +1 -0
- package/dist/request/fixture/types.js +2 -0
- package/dist/request/fixture/types.js.map +1 -0
- package/dist/request/flow/namespace.d.ts +14 -0
- package/dist/request/flow/namespace.d.ts.map +1 -0
- package/dist/request/flow/namespace.js +14 -0
- package/dist/request/flow/namespace.js.map +1 -0
- package/dist/request/http/index.d.ts +4 -0
- package/dist/request/http/index.d.ts.map +1 -0
- package/dist/request/http/index.js +3 -0
- package/dist/request/http/index.js.map +1 -0
- package/dist/request/http/middleware.d.ts +20 -0
- package/dist/request/http/middleware.d.ts.map +1 -0
- package/dist/request/http/middleware.js +71 -0
- package/dist/request/http/middleware.js.map +1 -0
- package/dist/request/http/namespace.d.ts +3 -0
- package/dist/request/http/namespace.d.ts.map +1 -0
- package/dist/request/http/namespace.js +3 -0
- package/dist/request/http/namespace.js.map +1 -0
- package/dist/request/http/response.d.ts +5 -0
- package/dist/request/http/response.d.ts.map +1 -0
- package/dist/request/http/response.js +22 -0
- package/dist/request/http/response.js.map +1 -0
- package/dist/request/http/server.d.ts +17 -0
- package/dist/request/http/server.d.ts.map +1 -0
- package/dist/request/http/server.js +391 -0
- package/dist/request/http/server.js.map +1 -0
- package/dist/request/http/types.d.ts +130 -0
- package/dist/request/http/types.d.ts.map +1 -0
- package/dist/request/http/types.js +2 -0
- package/dist/request/http/types.js.map +1 -0
- package/dist/request/openapi/generate.d.ts +13 -0
- package/dist/request/openapi/generate.d.ts.map +1 -0
- package/dist/request/openapi/generate.js +84 -0
- package/dist/request/openapi/generate.js.map +1 -0
- package/dist/request/openapi/index.d.ts +3 -0
- package/dist/request/openapi/index.d.ts.map +1 -0
- package/dist/request/openapi/index.js +2 -0
- package/dist/request/openapi/index.js.map +1 -0
- package/dist/request/openapi/namespace.d.ts +7 -0
- package/dist/request/openapi/namespace.d.ts.map +1 -0
- package/dist/request/openapi/namespace.js +7 -0
- package/dist/request/openapi/namespace.js.map +1 -0
- package/dist/temporal/definition-queries.d.ts +5 -5
- package/dist/temporal/definition-queries.d.ts.map +1 -1
- package/dist/temporal/definition-queries.js.map +1 -1
- package/dist/test/auth.d.ts +1 -1
- package/dist/test/auth.d.ts.map +1 -1
- package/dist/test/auto-setup.js +2 -2
- package/dist/test/auto-setup.js.map +1 -1
- package/dist/test/context.d.ts +1 -1
- package/dist/test/context.d.ts.map +1 -1
- package/dist/test/context.js +2 -2
- package/dist/test/context.js.map +1 -1
- package/dist/test/globals.d.ts +1 -1
- package/dist/test/index.d.ts +1 -1
- package/dist/test/index.d.ts.map +1 -1
- package/dist/test/index.js +1 -1
- package/dist/test/index.js.map +1 -1
- package/dist/test/plugin.d.ts +3 -3
- package/dist/test/plugin.d.ts.map +1 -1
- package/dist/test/plugin.js +2 -2
- package/dist/test/plugin.js.map +1 -1
- package/dist/test/setup.d.ts +1 -1
- package/dist/test/setup.d.ts.map +1 -1
- package/dist/test/setup.js +1 -1
- package/dist/test/setup.js.map +1 -1
- package/dist/test/vitest-workspace.d.ts +1 -1
- package/dist/test/vitest-workspace.d.ts.map +1 -1
- package/dist/test/vitest-workspace.js +2 -2
- package/dist/test/vitest-workspace.js.map +1 -1
- package/dist/test/vitest.d.ts +3 -3
- package/dist/test/vitest.d.ts.map +1 -1
- package/dist/test/vitest.js +1 -1
- package/dist/test/vitest.js.map +1 -1
- package/dist/vector/query.d.ts +1 -1
- package/dist/vector/query.d.ts.map +1 -1
- package/dist/vector/query.js.map +1 -1
- package/dist/workspace/discover.d.ts +1 -1
- package/dist/workspace/discover.d.ts.map +1 -1
- package/dist/workspace/sync.d.ts +1 -1
- package/dist/workspace/sync.d.ts.map +1 -1
- package/package.json +23 -22
package/dist/logging/proxy.js
CHANGED
|
@@ -1,5 +1,12 @@
|
|
|
1
|
-
import { getLogger } from './logger.js';
|
|
2
|
-
|
|
1
|
+
import { createPipeworkLogger, getLogger, getBaseLogger, setLoggingConfig, DEFAULT_REDACT_PATHS } from './logger.js';
|
|
2
|
+
const target = {
|
|
3
|
+
create: createPipeworkLogger,
|
|
4
|
+
get: getLogger,
|
|
5
|
+
getBase: getBaseLogger,
|
|
6
|
+
configure: setLoggingConfig,
|
|
7
|
+
REDACT_PATHS: DEFAULT_REDACT_PATHS,
|
|
8
|
+
};
|
|
9
|
+
export const log = new Proxy(target, {
|
|
3
10
|
get(target, prop) {
|
|
4
11
|
if (Object.hasOwn(target, prop))
|
|
5
12
|
return target[prop];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"proxy.js","sourceRoot":"","sources":["../../src/logging/proxy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"proxy.js","sourceRoot":"","sources":["../../src/logging/proxy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,SAAS,EAAE,aAAa,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AAEpH,MAAM,MAAM,GAAG;IACb,MAAM,EAAE,oBAAoB;IAC5B,GAAG,EAAE,SAAS;IACd,OAAO,EAAE,aAAa;IACtB,SAAS,EAAE,gBAAgB;IAC3B,YAAY,EAAE,oBAAoB;CACR,CAAA;AAE5B,MAAM,CAAC,MAAM,GAAG,GAAiB,IAAI,KAAK,CAAC,MAAM,EAAE;IACjD,GAAG,CAAC,MAAM,EAAE,IAAqB;QAC/B,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC;YAAE,OAAQ,MAAsD,CAAC,IAAI,CAAC,CAAA;QACrG,MAAM,MAAM,GAAG,SAAS,EAAE,CAAA;QAC1B,MAAM,KAAK,GAAG,MAAM,CAAC,IAA4B,CAAC,CAAA;QAClD,IAAI,OAAO,KAAK,KAAK,UAAU,EAAE,CAAC;YAChC,OAAQ,KAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QACzC,CAAC;QACD,OAAO,KAAK,CAAA;IACd,CAAC;CACF,CAAC,CAAA"}
|
package/dist/logging/types.d.ts
CHANGED
|
@@ -16,6 +16,13 @@ export interface PipeworkLogger {
|
|
|
16
16
|
child(bindings: Record<string, unknown>): PipeworkLogger;
|
|
17
17
|
silent: boolean;
|
|
18
18
|
}
|
|
19
|
+
export interface LogNamespace extends PipeworkLogger {
|
|
20
|
+
create(config?: LoggerConfig): PipeworkLogger;
|
|
21
|
+
get(): PipeworkLogger;
|
|
22
|
+
getBase(): PipeworkLogger;
|
|
23
|
+
configure(config: LoggingConfig): void;
|
|
24
|
+
readonly REDACT_PATHS: readonly string[];
|
|
25
|
+
}
|
|
19
26
|
export interface LoggerConfig {
|
|
20
27
|
readonly level?: LogLevel;
|
|
21
28
|
readonly pretty?: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/logging/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,CAAA;AAE9E,MAAM,MAAM,YAAY,GAAG,WAAW,GAAG,UAAU,GAAG,QAAQ,GAAG,WAAW,GAAG,SAAS,CAAA;AAExF,MAAM,WAAW,cAAc;IAC7B,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtD,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,cAAc,CAAA;IACxD,MAAM,EAAE,OAAO,CAAA;CAChB;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,KAAK,CAAC,EAAE,QAAQ,CAAA;IACzB,QAAQ,CAAC,MAAM,CAAC,EAAE,OAAO,CAAA;IACzB,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,MAAM,CAAC,EAAE,SAAS,MAAM,EAAE,GAAG;QACpC,QAAQ,CAAC,KAAK,EAAE,SAAS,MAAM,EAAE,CAAA;QACjC,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;QACxB,QAAQ,CAAC,MAAM,CAAC,EAAE,OAAO,CAAA;KAC1B,CAAA;CACF;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,eAAe,CAAC,EAAE,MAAM,CAAA;IACjC,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,CAAA;IAC/B,QAAQ,CAAC,UAAU,CAAC,EAAE,SAAS,MAAM,EAAE,CAAA;IACvC,QAAQ,CAAC,aAAa,CAAC,EAAE,SAAS,YAAY,EAAE,CAAA;CACjD"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/logging/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,CAAA;AAE9E,MAAM,MAAM,YAAY,GAAG,WAAW,GAAG,UAAU,GAAG,QAAQ,GAAG,WAAW,GAAG,SAAS,CAAA;AAExF,MAAM,WAAW,cAAc;IAC7B,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtD,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,cAAc,CAAA;IACxD,MAAM,EAAE,OAAO,CAAA;CAChB;AAED,MAAM,WAAW,YAAa,SAAQ,cAAc;IAClD,MAAM,CAAC,MAAM,CAAC,EAAE,YAAY,GAAG,cAAc,CAAA;IAC7C,GAAG,IAAI,cAAc,CAAA;IACrB,OAAO,IAAI,cAAc,CAAA;IACzB,SAAS,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI,CAAA;IACtC,QAAQ,CAAC,YAAY,EAAE,SAAS,MAAM,EAAE,CAAA;CACzC;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,KAAK,CAAC,EAAE,QAAQ,CAAA;IACzB,QAAQ,CAAC,MAAM,CAAC,EAAE,OAAO,CAAA;IACzB,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,MAAM,CAAC,EAAE,SAAS,MAAM,EAAE,GAAG;QACpC,QAAQ,CAAC,KAAK,EAAE,SAAS,MAAM,EAAE,CAAA;QACjC,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;QACxB,QAAQ,CAAC,MAAM,CAAC,EAAE,OAAO,CAAA;KAC1B,CAAA;CACF;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,eAAe,CAAC,EAAE,MAAM,CAAA;IACjC,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,CAAA;IAC/B,QAAQ,CAAC,UAAU,CAAC,EAAE,SAAS,MAAM,EAAE,CAAA;IACvC,QAAQ,CAAC,aAAa,CAAC,EAAE,SAAS,YAAY,EAAE,CAAA;CACjD"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ResourceOperations } from '../fixture/types.js';
|
|
2
|
+
import type { AuditedBehaviorConfig } from './types.js';
|
|
3
|
+
import type { Audit } from '../../infra/audit/types.js';
|
|
4
|
+
export declare function applyAudited<TAuth>(ops: ResourceOperations<TAuth>, config: AuditedBehaviorConfig | Audit, resourceName: string): ResourceOperations<TAuth>;
|
|
5
|
+
//# sourceMappingURL=audited.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audited.d.ts","sourceRoot":"","sources":["../../../src/request/behavior/audited.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAc,MAAM,qBAAqB,CAAA;AACzE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAA;AACvD,OAAO,KAAK,EAAE,KAAK,EAAoB,MAAM,4BAA4B,CAAA;AAEzE,wBAAgB,YAAY,CAAC,KAAK,EAChC,GAAG,EAAE,kBAAkB,CAAC,KAAK,CAAC,EAC9B,MAAM,EAAE,qBAAqB,GAAG,KAAK,EACrC,YAAY,EAAE,MAAM,GACnB,kBAAkB,CAAC,KAAK,CAAC,CAkE3B"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
export function applyAudited(ops, config, resourceName) {
|
|
2
|
+
const audit = 'emit' in config ? config : config.audit;
|
|
3
|
+
const isConfig = !('emit' in config);
|
|
4
|
+
const entityType = isConfig && config.entityType !== undefined
|
|
5
|
+
? config.entityType
|
|
6
|
+
: singularize(resourceName);
|
|
7
|
+
const prefix = isConfig && config.actionPrefix !== undefined
|
|
8
|
+
? config.actionPrefix
|
|
9
|
+
: entityType;
|
|
10
|
+
const result = { ...ops };
|
|
11
|
+
if (ops.create !== undefined) {
|
|
12
|
+
const original = ops.create;
|
|
13
|
+
result['create'] = {
|
|
14
|
+
input: original.input,
|
|
15
|
+
handler: async (db, auth, tenant, input) => {
|
|
16
|
+
const created = await original.handler(db, auth, tenant, input);
|
|
17
|
+
const opts = {
|
|
18
|
+
actionType: `${prefix}.created`,
|
|
19
|
+
entityType,
|
|
20
|
+
entityId: extractEntityId(created),
|
|
21
|
+
after: created,
|
|
22
|
+
};
|
|
23
|
+
await audit.emit(opts);
|
|
24
|
+
return created;
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
if (ops.update !== undefined) {
|
|
29
|
+
const original = ops.update;
|
|
30
|
+
result['update'] = {
|
|
31
|
+
input: original.input,
|
|
32
|
+
handler: async (db, auth, tenant, id, input) => {
|
|
33
|
+
const before = ops.get !== undefined ? await ops.get(db, auth, tenant, id) : null;
|
|
34
|
+
const updated = await original.handler(db, auth, tenant, id, input);
|
|
35
|
+
const opts = {
|
|
36
|
+
actionType: `${prefix}.updated`,
|
|
37
|
+
entityType,
|
|
38
|
+
entityId: id,
|
|
39
|
+
before: before ?? undefined,
|
|
40
|
+
after: updated,
|
|
41
|
+
};
|
|
42
|
+
await audit.emit(opts);
|
|
43
|
+
return updated;
|
|
44
|
+
},
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
if (ops.delete !== undefined) {
|
|
48
|
+
const original = ops.delete;
|
|
49
|
+
result['delete'] = async (db, auth, tenant, id) => {
|
|
50
|
+
const before = ops.get !== undefined ? await ops.get(db, auth, tenant, id) : null;
|
|
51
|
+
await original(db, auth, tenant, id);
|
|
52
|
+
const opts = {
|
|
53
|
+
actionType: `${prefix}.deleted`,
|
|
54
|
+
entityType,
|
|
55
|
+
entityId: id,
|
|
56
|
+
before: before ?? undefined,
|
|
57
|
+
};
|
|
58
|
+
await audit.emit(opts);
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
return result;
|
|
62
|
+
}
|
|
63
|
+
function extractEntityId(result) {
|
|
64
|
+
if (result !== null && typeof result === 'object' && 'id' in result) {
|
|
65
|
+
return String(result.id);
|
|
66
|
+
}
|
|
67
|
+
return 'unknown';
|
|
68
|
+
}
|
|
69
|
+
function singularize(s) {
|
|
70
|
+
if (s.endsWith('ies'))
|
|
71
|
+
return s.slice(0, -3) + 'y';
|
|
72
|
+
if (s.endsWith('ses') || s.endsWith('xes'))
|
|
73
|
+
return s.slice(0, -2);
|
|
74
|
+
if (s.endsWith('s') && !s.endsWith('ss'))
|
|
75
|
+
return s.slice(0, -1);
|
|
76
|
+
return s;
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=audited.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audited.js","sourceRoot":"","sources":["../../../src/request/behavior/audited.ts"],"names":[],"mappings":"AAKA,MAAM,UAAU,YAAY,CAC1B,GAA8B,EAC9B,MAAqC,EACrC,YAAoB;IAEpB,MAAM,KAAK,GAAU,MAAM,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAA;IAC7D,MAAM,QAAQ,GAAG,CAAC,CAAC,MAAM,IAAI,MAAM,CAAC,CAAA;IACpC,MAAM,UAAU,GAAG,QAAQ,IAAK,MAAgC,CAAC,UAAU,KAAK,SAAS;QACvF,CAAC,CAAE,MAAgC,CAAC,UAAW;QAC/C,CAAC,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;IAC7B,MAAM,MAAM,GAAG,QAAQ,IAAK,MAAgC,CAAC,YAAY,KAAK,SAAS;QACrF,CAAC,CAAE,MAAgC,CAAC,YAAa;QACjD,CAAC,CAAC,UAAU,CAAA;IAEd,MAAM,MAAM,GAA4B,EAAE,GAAG,GAAG,EAAE,CAAA;IAElD,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAA;QAC3B,MAAM,CAAC,QAAQ,CAAC,GAAG;YACjB,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,OAAO,EAAE,KAAK,EAAE,EAAM,EAAE,IAAW,EAAE,MAAc,EAAE,KAAc,EAAE,EAAE;gBACrE,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,CAAA;gBAC/D,MAAM,IAAI,GAAqB;oBAC7B,UAAU,EAAE,GAAG,MAAM,UAAU;oBAC/B,UAAU;oBACV,QAAQ,EAAE,eAAe,CAAC,OAAO,CAAC;oBAClC,KAAK,EAAE,OAAO;iBACf,CAAA;gBACD,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;gBACtB,OAAO,OAAO,CAAA;YAChB,CAAC;SACF,CAAA;IACH,CAAC;IAED,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAA;QAC3B,MAAM,CAAC,QAAQ,CAAC,GAAG;YACjB,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,OAAO,EAAE,KAAK,EAAE,EAAM,EAAE,IAAW,EAAE,MAAc,EAAE,EAAc,EAAE,KAAc,EAAE,EAAE;gBACrF,MAAM,MAAM,GAAG,GAAG,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;gBACjF,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,CAAC,CAAA;gBACnE,MAAM,IAAI,GAAqB;oBAC7B,UAAU,EAAE,GAAG,MAAM,UAAU;oBAC/B,UAAU;oBACV,QAAQ,EAAE,EAAE;oBACZ,MAAM,EAAE,MAAM,IAAI,SAAS;oBAC3B,KAAK,EAAE,OAAO;iBACf,CAAA;gBACD,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;gBACtB,OAAO,OAAO,CAAA;YAChB,CAAC;SACF,CAAA;IACH,CAAC;IAED,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAA;QAC3B,MAAM,CAAC,QAAQ,CAAC,GAAG,KAAK,EAAE,EAAM,EAAE,IAAW,EAAE,MAAc,EAAE,EAAc,EAAE,EAAE;YAC/E,MAAM,MAAM,GAAG,GAAG,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;YACjF,MAAM,QAAQ,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,CAAC,CAAA;YACpC,MAAM,IAAI,GAAqB;gBAC7B,UAAU,EAAE,GAAG,MAAM,UAAU;gBAC/B,UAAU;gBACV,QAAQ,EAAE,EAAE;gBACZ,MAAM,EAAE,MAAM,IAAI,SAAS;aAC5B,CAAA;YACD,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACxB,CAAC,CAAA;IACH,CAAC;IAED,OAAO,MAAmC,CAAA;AAC5C,CAAC;AAED,SAAS,eAAe,CAAC,MAAe;IACtC,IAAI,MAAM,KAAK,IAAI,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,IAAI,IAAI,MAAM,EAAE,CAAC;QACpE,OAAO,MAAM,CAAE,MAA0B,CAAC,EAAE,CAAC,CAAA;IAC/C,CAAC;IACD,OAAO,SAAS,CAAA;AAClB,CAAC;AAED,SAAS,WAAW,CAAC,CAAS;IAC5B,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAA;IAClD,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IACjE,IAAI,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC;QAAE,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IAC/D,OAAO,CAAC,CAAA;AACV,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ResourceOperations } from '../fixture/types.js';
|
|
2
|
+
import type { InvalidationBehaviorConfig } from './types.js';
|
|
3
|
+
import type { Cache } from '../../infra/cache/types.js';
|
|
4
|
+
export declare function withInvalidation<TAuth>(ops: ResourceOperations<TAuth>, config: InvalidationBehaviorConfig, resourceName: string): ResourceOperations<TAuth> & {
|
|
5
|
+
readonly cache: Cache<unknown[]>;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=cached.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cached.d.ts","sourceRoot":"","sources":["../../../src/request/behavior/cached.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAc,MAAM,qBAAqB,CAAA;AACzE,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,YAAY,CAAA;AAE5D,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAA;AAEvD,wBAAgB,gBAAgB,CAAC,KAAK,EACpC,GAAG,EAAE,kBAAkB,CAAC,KAAK,CAAC,EAC9B,MAAM,EAAE,0BAA0B,EAClC,YAAY,EAAE,MAAM,GACnB,kBAAkB,CAAC,KAAK,CAAC,GAAG;IAAE,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAA;CAAE,CAmDlE"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { createCache } from '../../infra/cache/create.js';
|
|
2
|
+
export function withInvalidation(ops, config, resourceName) {
|
|
3
|
+
const listCache = createCache({
|
|
4
|
+
name: `resource:${resourceName}:list`,
|
|
5
|
+
database: config.database,
|
|
6
|
+
ttlMs: config.ttlMs,
|
|
7
|
+
load: () => Promise.resolve([]),
|
|
8
|
+
});
|
|
9
|
+
const result = { ...ops, cache: listCache };
|
|
10
|
+
if (ops.list !== undefined) {
|
|
11
|
+
const original = ops.list;
|
|
12
|
+
result['list'] = async (db, auth, tenant) => {
|
|
13
|
+
const data = await original(db, auth, tenant);
|
|
14
|
+
return data;
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
if (ops.create !== undefined) {
|
|
18
|
+
const original = ops.create;
|
|
19
|
+
result['create'] = {
|
|
20
|
+
input: original.input,
|
|
21
|
+
handler: async (db, auth, tenant, input) => {
|
|
22
|
+
const created = await original.handler(db, auth, tenant, input);
|
|
23
|
+
listCache.invalidate();
|
|
24
|
+
return created;
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
if (ops.update !== undefined) {
|
|
29
|
+
const original = ops.update;
|
|
30
|
+
result['update'] = {
|
|
31
|
+
input: original.input,
|
|
32
|
+
handler: async (db, auth, tenant, id, input) => {
|
|
33
|
+
const updated = await original.handler(db, auth, tenant, id, input);
|
|
34
|
+
listCache.invalidate();
|
|
35
|
+
return updated;
|
|
36
|
+
},
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
if (ops.delete !== undefined) {
|
|
40
|
+
const original = ops.delete;
|
|
41
|
+
result['delete'] = async (db, _auth, _tenant, id) => {
|
|
42
|
+
await original(db, _auth, _tenant, id);
|
|
43
|
+
listCache.invalidate();
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
return result;
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=cached.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cached.js","sourceRoot":"","sources":["../../../src/request/behavior/cached.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAA;AAGzD,MAAM,UAAU,gBAAgB,CAC9B,GAA8B,EAC9B,MAAkC,EAClC,YAAoB;IAEpB,MAAM,SAAS,GAAG,WAAW,CAAY;QACvC,IAAI,EAAE,YAAY,YAAY,OAAO;QACrC,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,KAAK,EAAE,MAAM,CAAC,KAAK;QACnB,IAAI,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;KAChC,CAAC,CAAA;IAEF,MAAM,MAAM,GAA4B,EAAE,GAAG,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,CAAA;IAEpE,IAAI,GAAG,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC3B,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,CAAA;QACzB,MAAM,CAAC,MAAM,CAAC,GAAG,KAAK,EAAE,EAAM,EAAE,IAAW,EAAE,MAAc,EAAE,EAAE;YAC7D,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,CAAC,CAAA;YAC7C,OAAO,IAAI,CAAA;QACb,CAAC,CAAA;IACH,CAAC;IAED,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAA;QAC3B,MAAM,CAAC,QAAQ,CAAC,GAAG;YACjB,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,OAAO,EAAE,KAAK,EAAE,EAAM,EAAE,IAAW,EAAE,MAAc,EAAE,KAAc,EAAE,EAAE;gBACrE,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,CAAA;gBAC/D,SAAS,CAAC,UAAU,EAAE,CAAA;gBACtB,OAAO,OAAO,CAAA;YAChB,CAAC;SACF,CAAA;IACH,CAAC;IAED,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAA;QAC3B,MAAM,CAAC,QAAQ,CAAC,GAAG;YACjB,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,OAAO,EAAE,KAAK,EAAE,EAAM,EAAE,IAAW,EAAE,MAAc,EAAE,EAAc,EAAE,KAAc,EAAE,EAAE;gBACrF,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,CAAC,CAAA;gBACnE,SAAS,CAAC,UAAU,EAAE,CAAA;gBACtB,OAAO,OAAO,CAAA;YAChB,CAAC;SACF,CAAA;IACH,CAAC;IAED,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAA;QAC3B,MAAM,CAAC,QAAQ,CAAC,GAAG,KAAK,EAAE,EAAM,EAAE,KAAY,EAAE,OAAe,EAAE,EAAc,EAAE,EAAE;YACjF,MAAM,QAAQ,CAAC,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,CAAC,CAAA;YACtC,SAAS,CAAC,UAAU,EAAE,CAAA;QACxB,CAAC,CAAA;IACH,CAAC;IAED,OAAO,MAAqF,CAAA;AAC9F,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ResourceOperations } from '../fixture/types.js';
|
|
2
|
+
import type { BehaviorConfig } from './types.js';
|
|
3
|
+
export declare function withBehaviors<TAuth>(ops: ResourceOperations<TAuth>, config: BehaviorConfig, resourceName?: string): ResourceOperations<TAuth>;
|
|
4
|
+
//# sourceMappingURL=compose.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compose.d.ts","sourceRoot":"","sources":["../../../src/request/behavior/compose.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAA;AAC7D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAKhD,wBAAgB,aAAa,CAAC,KAAK,EACjC,GAAG,EAAE,kBAAkB,CAAC,KAAK,CAAC,EAC9B,MAAM,EAAE,cAAc,EACtB,YAAY,CAAC,EAAE,MAAM,GACpB,kBAAkB,CAAC,KAAK,CAAC,CAiB3B"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { applyVersioned } from './versioned.js';
|
|
2
|
+
import { applyAudited } from './audited.js';
|
|
3
|
+
import { withInvalidation } from './cached.js';
|
|
4
|
+
export function withBehaviors(ops, config, resourceName) {
|
|
5
|
+
const name = resourceName ?? 'resource';
|
|
6
|
+
let decorated = ops;
|
|
7
|
+
if (config.versioned !== undefined) {
|
|
8
|
+
decorated = applyVersioned(decorated, config.versioned, name);
|
|
9
|
+
}
|
|
10
|
+
if (config.audited !== undefined) {
|
|
11
|
+
decorated = applyAudited(decorated, config.audited, name);
|
|
12
|
+
}
|
|
13
|
+
if (config.cached !== undefined) {
|
|
14
|
+
decorated = withInvalidation(decorated, config.cached, name);
|
|
15
|
+
}
|
|
16
|
+
return decorated;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=compose.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compose.js","sourceRoot":"","sources":["../../../src/request/behavior/compose.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAE9C,MAAM,UAAU,aAAa,CAC3B,GAA8B,EAC9B,MAAsB,EACtB,YAAqB;IAErB,MAAM,IAAI,GAAG,YAAY,IAAI,UAAU,CAAA;IACvC,IAAI,SAAS,GAAG,GAAG,CAAA;IAEnB,IAAI,MAAM,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;QACnC,SAAS,GAAG,cAAc,CAAC,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,CAAA;IAC/D,CAAC;IAED,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;QACjC,SAAS,GAAG,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAA;IAC3D,CAAC;IAED,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAChC,SAAS,GAAG,gBAAgB,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;IAC9D,CAAC;IAED,OAAO,SAAS,CAAA;AAClB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { withBehaviors } from './compose.js';
|
|
2
|
+
export { applyVersioned } from './versioned.js';
|
|
3
|
+
export { applyAudited } from './audited.js';
|
|
4
|
+
export { withInvalidation } from './cached.js';
|
|
5
|
+
export type { BehaviorConfig, VersionedBehaviorConfig, AuditedBehaviorConfig, InvalidationBehaviorConfig } from './types.js';
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/request/behavior/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAC9C,YAAY,EAAE,cAAc,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,0BAA0B,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/request/behavior/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { withBehaviors } from './compose.js';
|
|
2
|
+
import { applyVersioned } from './versioned.js';
|
|
3
|
+
import { applyAudited } from './audited.js';
|
|
4
|
+
import { withInvalidation } from './cached.js';
|
|
5
|
+
/** Resource behavior decorators — compose versioning, audit trails, and cache invalidation onto CRUD operations. */
|
|
6
|
+
export declare const behavior: {
|
|
7
|
+
/** Applies multiple behaviors to a ResourceOperations set in order. */
|
|
8
|
+
compose: typeof withBehaviors;
|
|
9
|
+
/** Adds optimistic concurrency control via a version column — rejects stale updates. */
|
|
10
|
+
versioned: typeof applyVersioned;
|
|
11
|
+
/** Wraps operations to emit audit records on create/update/delete. */
|
|
12
|
+
audited: typeof applyAudited;
|
|
13
|
+
/** Wraps operations to invalidate a cache on mutations. Returns ops with an attached .cache handle. */
|
|
14
|
+
invalidate: typeof withInvalidation;
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/request/behavior/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAE9C,oHAAoH;AACpH,eAAO,MAAM,QAAQ;IACnB,uEAAuE;;IAEvE,wFAAwF;;IAExF,sEAAsE;;IAEtE,uGAAuG;;CAExG,CAAA"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { withBehaviors } from './compose.js';
|
|
2
|
+
import { applyVersioned } from './versioned.js';
|
|
3
|
+
import { applyAudited } from './audited.js';
|
|
4
|
+
import { withInvalidation } from './cached.js';
|
|
5
|
+
/** Resource behavior decorators — compose versioning, audit trails, and cache invalidation onto CRUD operations. */
|
|
6
|
+
export const behavior = {
|
|
7
|
+
/** Applies multiple behaviors to a ResourceOperations set in order. */
|
|
8
|
+
compose: withBehaviors,
|
|
9
|
+
/** Adds optimistic concurrency control via a version column — rejects stale updates. */
|
|
10
|
+
versioned: applyVersioned,
|
|
11
|
+
/** Wraps operations to emit audit records on create/update/delete. */
|
|
12
|
+
audited: applyAudited,
|
|
13
|
+
/** Wraps operations to invalidate a cache on mutations. Returns ops with an attached .cache handle. */
|
|
14
|
+
invalidate: withInvalidation,
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=namespace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../../src/request/behavior/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAE9C,oHAAoH;AACpH,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,uEAAuE;IACvE,OAAO,EAAE,aAAa;IACtB,wFAAwF;IACxF,SAAS,EAAE,cAAc;IACzB,sEAAsE;IACtE,OAAO,EAAE,YAAY;IACrB,uGAAuG;IACvG,UAAU,EAAE,gBAAgB;CAC7B,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { Audit } from '../../infra/audit/types.js';
|
|
2
|
+
import type { SQL, DB } from '../../data/db/types.js';
|
|
3
|
+
export interface VersionedBehaviorConfig {
|
|
4
|
+
readonly table: string;
|
|
5
|
+
readonly whereFromId?: (id: string) => SQL;
|
|
6
|
+
readonly softDelete?: boolean;
|
|
7
|
+
readonly beforeRevise?: (db: DB, auth: unknown, tenant: string, id: string, input: unknown) => Promise<void>;
|
|
8
|
+
}
|
|
9
|
+
export interface AuditedBehaviorConfig {
|
|
10
|
+
readonly audit: Audit;
|
|
11
|
+
readonly entityType?: string;
|
|
12
|
+
readonly actionPrefix?: string;
|
|
13
|
+
}
|
|
14
|
+
export interface InvalidationBehaviorConfig {
|
|
15
|
+
readonly ttlMs: number;
|
|
16
|
+
readonly database: string;
|
|
17
|
+
}
|
|
18
|
+
export interface BehaviorConfig {
|
|
19
|
+
readonly versioned?: VersionedBehaviorConfig;
|
|
20
|
+
readonly audited?: AuditedBehaviorConfig | Audit;
|
|
21
|
+
readonly cached?: InvalidationBehaviorConfig;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/request/behavior/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAA;AACvD,OAAO,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAErD,MAAM,WAAW,uBAAuB;IACtC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,GAAG,CAAA;IAC1C,QAAQ,CAAC,UAAU,CAAC,EAAE,OAAO,CAAA;IAC7B,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;CAC7G;AAED,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAA;IACrB,QAAQ,CAAC,UAAU,CAAC,EAAE,MAAM,CAAA;IAC5B,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAA;CAC/B;AAED,MAAM,WAAW,0BAA0B;IACzC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;CAC1B;AAED,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,SAAS,CAAC,EAAE,uBAAuB,CAAA;IAC5C,QAAQ,CAAC,OAAO,CAAC,EAAE,qBAAqB,GAAG,KAAK,CAAA;IAChD,QAAQ,CAAC,MAAM,CAAC,EAAE,0BAA0B,CAAA;CAC7C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/request/behavior/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ResourceOperations } from '../fixture/types.js';
|
|
2
|
+
import type { VersionedBehaviorConfig } from './types.js';
|
|
3
|
+
export declare function applyVersioned<TAuth>(ops: ResourceOperations<TAuth>, config: VersionedBehaviorConfig, _resourceName: string): ResourceOperations<TAuth>;
|
|
4
|
+
//# sourceMappingURL=versioned.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"versioned.d.ts","sourceRoot":"","sources":["../../../src/request/behavior/versioned.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAc,MAAM,qBAAqB,CAAA;AACzE,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAA;AAKzD,wBAAgB,cAAc,CAAC,KAAK,EAClC,GAAG,EAAE,kBAAkB,CAAC,KAAK,CAAC,EAC9B,MAAM,EAAE,uBAAuB,EAC/B,aAAa,EAAE,MAAM,GACpB,kBAAkB,CAAC,KAAK,CAAC,CAkC3B"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { sql } from '../../data/db/sql.js';
|
|
2
|
+
import { revise } from '../../data/temporal/revise.js';
|
|
3
|
+
export function applyVersioned(ops, config, _resourceName) {
|
|
4
|
+
const softDelete = config.softDelete !== false;
|
|
5
|
+
const buildWhere = config.whereFromId
|
|
6
|
+
?? ((id) => sql `id = ${id}::uuid`);
|
|
7
|
+
const result = { ...ops };
|
|
8
|
+
if (ops.update !== undefined) {
|
|
9
|
+
const originalUpdate = ops.update;
|
|
10
|
+
result['update'] = {
|
|
11
|
+
input: originalUpdate.input,
|
|
12
|
+
handler: async (db, auth, _tenant, id, input) => {
|
|
13
|
+
return db.transaction(async (tx) => {
|
|
14
|
+
await config.beforeRevise?.(db, auth, _tenant, id, input);
|
|
15
|
+
const userId = extractUserId(auth);
|
|
16
|
+
const opts = userId !== undefined
|
|
17
|
+
? { tx, table: config.table, where: sql `${buildWhere(id)} AND effective_to IS NULL`, data: input, userId }
|
|
18
|
+
: { tx, table: config.table, where: sql `${buildWhere(id)} AND effective_to IS NULL`, data: input };
|
|
19
|
+
return revise(opts);
|
|
20
|
+
});
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
if (ops.delete !== undefined && softDelete) {
|
|
25
|
+
result['delete'] = async (db, _auth, _tenant, id) => {
|
|
26
|
+
await db.execute(sql `UPDATE ${sql.identifier(config.table)} SET effective_to = now() WHERE ${buildWhere(id)} AND effective_to IS NULL`);
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
return result;
|
|
30
|
+
}
|
|
31
|
+
function extractUserId(auth) {
|
|
32
|
+
if (auth !== null && typeof auth === 'object' && 'userId' in auth) {
|
|
33
|
+
const userId = auth.userId;
|
|
34
|
+
if (typeof userId === 'string')
|
|
35
|
+
return userId;
|
|
36
|
+
}
|
|
37
|
+
return undefined;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=versioned.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"versioned.js","sourceRoot":"","sources":["../../../src/request/behavior/versioned.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,GAAG,EAAE,MAAM,sBAAsB,CAAA;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAA;AAEtD,MAAM,UAAU,cAAc,CAC5B,GAA8B,EAC9B,MAA+B,EAC/B,aAAqB;IAErB,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,KAAK,KAAK,CAAA;IAE9C,MAAM,UAAU,GAAG,MAAM,CAAC,WAAW;WAChC,CAAC,CAAC,EAAU,EAAE,EAAE,CAAC,GAAG,CAAA,QAAQ,EAAE,QAAQ,CAAC,CAAA;IAE5C,MAAM,MAAM,GAA4B,EAAE,GAAG,GAAG,EAAE,CAAA;IAElD,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,MAAM,cAAc,GAAG,GAAG,CAAC,MAAM,CAAA;QACjC,MAAM,CAAC,QAAQ,CAAC,GAAG;YACjB,KAAK,EAAE,cAAc,CAAC,KAAK;YAC3B,OAAO,EAAE,KAAK,EAAE,EAAM,EAAE,IAAW,EAAE,OAAe,EAAE,EAAc,EAAE,KAAc,EAAE,EAAE;gBACtF,OAAQ,EAAS,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE;oBACzC,MAAM,MAAM,CAAC,YAAY,EAAE,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,KAAK,CAAC,CAAA;oBACzD,MAAM,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,CAAA;oBAClC,MAAM,IAAI,GAAkB,MAAM,KAAK,SAAS;wBAC9C,CAAC,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,KAAK,EAAE,GAAG,CAAA,GAAG,UAAU,CAAC,EAAE,CAAC,2BAA2B,EAAE,IAAI,EAAE,KAAgC,EAAE,MAAM,EAAE;wBACrI,CAAC,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,KAAK,EAAE,GAAG,CAAA,GAAG,UAAU,CAAC,EAAE,CAAC,2BAA2B,EAAE,IAAI,EAAE,KAAgC,EAAE,CAAA;oBAC/H,OAAO,MAAM,CAAC,IAAI,CAAC,CAAA;gBACrB,CAAC,CAAC,CAAA;YACJ,CAAC;SACF,CAAA;IACH,CAAC;IAED,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,IAAI,UAAU,EAAE,CAAC;QAC3C,MAAM,CAAC,QAAQ,CAAC,GAAG,KAAK,EAAE,EAAM,EAAE,KAAY,EAAE,OAAe,EAAE,EAAc,EAAE,EAAE;YACjF,MAAM,EAAE,CAAC,OAAO,CACd,GAAG,CAAA,UAAU,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,mCAAmC,UAAU,CAAC,EAAE,CAAC,2BAA2B,CACtH,CAAA;QACH,CAAC,CAAA;IACH,CAAC;IAED,OAAO,MAAmC,CAAA;AAC5C,CAAC;AAED,SAAS,aAAa,CAAC,IAAa;IAClC,IAAI,IAAI,KAAK,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,QAAQ,IAAI,IAAI,EAAE,CAAC;QAClE,MAAM,MAAM,GAAI,IAA4B,CAAC,MAAM,CAAA;QACnD,IAAI,OAAO,MAAM,KAAK,QAAQ;YAAE,OAAO,MAAM,CAAA;IAC/C,CAAC;IACD,OAAO,SAAS,CAAA;AAClB,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { Manifold } from '../../core/pipework.js';
|
|
2
|
+
import type { Flow, RequestMetadata } from './types.js';
|
|
3
|
+
export interface CreateRequestContextOptions<TAuth = unknown> {
|
|
4
|
+
instance: Manifold;
|
|
5
|
+
requestId?: string;
|
|
6
|
+
auth?: TAuth | null;
|
|
7
|
+
tenant?: string | null;
|
|
8
|
+
metadata: RequestMetadata;
|
|
9
|
+
}
|
|
10
|
+
export declare function createRequestContext<TAuth = unknown>(options: CreateRequestContextOptions<TAuth>): Flow<TAuth>;
|
|
11
|
+
export interface CreateJobContextOptions<TAuth = unknown> {
|
|
12
|
+
instance: Manifold;
|
|
13
|
+
jobId?: string;
|
|
14
|
+
jobType?: string;
|
|
15
|
+
auth?: TAuth | null;
|
|
16
|
+
tenant?: string | null;
|
|
17
|
+
}
|
|
18
|
+
export declare function createJobContext<TAuth = unknown>(options: CreateJobContextOptions<TAuth>): Flow<TAuth>;
|
|
19
|
+
export interface CreateTestContextOptions {
|
|
20
|
+
auth?: unknown;
|
|
21
|
+
tenant?: string | null | undefined;
|
|
22
|
+
}
|
|
23
|
+
export declare function createTestContext(instance: Manifold, requestId?: string, options?: CreateTestContextOptions): Flow;
|
|
24
|
+
//# sourceMappingURL=create.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.d.ts","sourceRoot":"","sources":["../../../src/request/context/create.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAA;AACtD,OAAO,KAAK,EAAE,IAAI,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEvD,MAAM,WAAW,2BAA2B,CAAC,KAAK,GAAG,OAAO;IAC1D,QAAQ,EAAE,QAAQ,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,IAAI,CAAC,EAAE,KAAK,GAAG,IAAI,CAAA;IACnB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,QAAQ,EAAE,eAAe,CAAA;CAC1B;AAED,wBAAgB,oBAAoB,CAAC,KAAK,GAAG,OAAO,EAClD,OAAO,EAAE,2BAA2B,CAAC,KAAK,CAAC,GAC1C,IAAI,CAAC,KAAK,CAAC,CAWb;AAED,MAAM,WAAW,uBAAuB,CAAC,KAAK,GAAG,OAAO;IACtD,QAAQ,EAAE,QAAQ,CAAA;IAClB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,IAAI,CAAC,EAAE,KAAK,GAAG,IAAI,CAAA;IACnB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CACvB;AAED,wBAAgB,gBAAgB,CAAC,KAAK,GAAG,OAAO,EAC9C,OAAO,EAAE,uBAAuB,CAAC,KAAK,CAAC,GACtC,IAAI,CAAC,KAAK,CAAC,CAWb;AAED,MAAM,WAAW,wBAAwB;IACvC,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAA;CACnC;AAED,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,wBAAwB,GAAG,IAAI,CAWlH"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { randomUUID } from 'node:crypto';
|
|
2
|
+
export function createRequestContext(options) {
|
|
3
|
+
return {
|
|
4
|
+
instance: options.instance,
|
|
5
|
+
requestId: options.requestId ?? randomUUID(),
|
|
6
|
+
_nonce: randomUUID(),
|
|
7
|
+
auth: options.auth ?? null,
|
|
8
|
+
tenant: options.tenant ?? null,
|
|
9
|
+
metadata: options.metadata,
|
|
10
|
+
jobType: null,
|
|
11
|
+
transactions: new Map(),
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export function createJobContext(options) {
|
|
15
|
+
return {
|
|
16
|
+
instance: options.instance,
|
|
17
|
+
requestId: options.jobId ?? randomUUID(),
|
|
18
|
+
_nonce: randomUUID(),
|
|
19
|
+
auth: options.auth ?? null,
|
|
20
|
+
tenant: options.tenant ?? null,
|
|
21
|
+
metadata: null,
|
|
22
|
+
jobType: options.jobType ?? null,
|
|
23
|
+
transactions: new Map(),
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
export function createTestContext(instance, requestId, options) {
|
|
27
|
+
return {
|
|
28
|
+
instance,
|
|
29
|
+
requestId: requestId ?? randomUUID(),
|
|
30
|
+
_nonce: randomUUID(),
|
|
31
|
+
auth: options?.auth ?? null,
|
|
32
|
+
tenant: options?.tenant ?? null,
|
|
33
|
+
metadata: null,
|
|
34
|
+
jobType: null,
|
|
35
|
+
transactions: new Map(),
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=create.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/request/context/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAYxC,MAAM,UAAU,oBAAoB,CAClC,OAA2C;IAE3C,OAAO;QACL,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,SAAS,EAAE,OAAO,CAAC,SAAS,IAAI,UAAU,EAAE;QAC5C,MAAM,EAAE,UAAU,EAAE;QACpB,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,IAAI;QAC1B,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,IAAI;QAC9B,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,OAAO,EAAE,IAAI;QACb,YAAY,EAAE,IAAI,GAAG,EAAE;KACxB,CAAA;AACH,CAAC;AAUD,MAAM,UAAU,gBAAgB,CAC9B,OAAuC;IAEvC,OAAO;QACL,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,SAAS,EAAE,OAAO,CAAC,KAAK,IAAI,UAAU,EAAE;QACxC,MAAM,EAAE,UAAU,EAAE;QACpB,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,IAAI;QAC1B,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,IAAI;QAC9B,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,IAAI;QAChC,YAAY,EAAE,IAAI,GAAG,EAAE;KACxB,CAAA;AACH,CAAC;AAOD,MAAM,UAAU,iBAAiB,CAAC,QAAkB,EAAE,SAAkB,EAAE,OAAkC;IAC1G,OAAO;QACL,QAAQ;QACR,SAAS,EAAE,SAAS,IAAI,UAAU,EAAE;QACpC,MAAM,EAAE,UAAU,EAAE;QACpB,IAAI,EAAE,OAAO,EAAE,IAAI,IAAI,IAAI;QAC3B,MAAM,EAAE,OAAO,EAAE,MAAM,IAAI,IAAI;QAC/B,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,IAAI;QACb,YAAY,EAAE,IAAI,GAAG,EAAE;KACxB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { Flow, BoundTransaction } from './types.js';
|
|
2
|
+
import type { DB } from '../../data/db/index.js';
|
|
3
|
+
export declare function verifyTransactionBinding(ctx: Flow, bound: BoundTransaction, dbName: string): void;
|
|
4
|
+
export declare function bindTransaction(ctx: Flow, dbName: string, drizzle: DB): BoundTransaction;
|
|
5
|
+
//# sourceMappingURL=guard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"guard.d.ts","sourceRoot":"","sources":["../../../src/request/context/guard.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AACxD,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAGhD,wBAAgB,wBAAwB,CACtC,GAAG,EAAE,IAAI,EACT,KAAK,EAAE,gBAAgB,EACvB,MAAM,EAAE,MAAM,GACb,IAAI,CAgCN;AAED,wBAAgB,eAAe,CAC7B,GAAG,EAAE,IAAI,EACT,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,EAAE,GACV,gBAAgB,CAElB"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { InvariantViolation } from '../../invariants/assert.js';
|
|
2
|
+
export function verifyTransactionBinding(ctx, bound, dbName) {
|
|
3
|
+
if (bound.nonce !== ctx._nonce) {
|
|
4
|
+
throw new InvariantViolation('context-nonce-mismatch', {
|
|
5
|
+
message: `The transaction for database "${dbName}" was created in a different AsyncLocalStorage ` +
|
|
6
|
+
'context than the one currently active. This usually means Node.js swapped async contexts ' +
|
|
7
|
+
'between concurrent requests — a known ALS bug that can cause cross-tenant data leaks.',
|
|
8
|
+
transactionNonce: bound.nonce,
|
|
9
|
+
contextNonce: ctx._nonce,
|
|
10
|
+
database: dbName,
|
|
11
|
+
contextTenant: ctx.tenant,
|
|
12
|
+
requestId: ctx.requestId,
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
if (bound.tenant !== ctx.tenant) {
|
|
16
|
+
throw new InvariantViolation('tenant-context-mismatch', {
|
|
17
|
+
message: `The transaction for database "${dbName}" was created for tenant "${bound.tenant}" ` +
|
|
18
|
+
`but the current context has tenant "${ctx.tenant}". This indicates an AsyncLocalStorage ` +
|
|
19
|
+
'context swap that would cause writes to go to the wrong tenant.\n\n' +
|
|
20
|
+
' In tests, use withFlow({ tenant }, fn) to run tenant-scoped code:\n\n' +
|
|
21
|
+
" import { withFlow, asTenant } from 'pipework/test'\n\n" +
|
|
22
|
+
" withFlow({ auth: asTenant('tenant-1'), tenant: 'tenant-1' }, async () => {\n" +
|
|
23
|
+
' // pipe() and useTestDb() work correctly here\n' +
|
|
24
|
+
' })',
|
|
25
|
+
transactionTenant: bound.tenant,
|
|
26
|
+
contextTenant: ctx.tenant,
|
|
27
|
+
database: dbName,
|
|
28
|
+
requestId: ctx.requestId,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
export function bindTransaction(ctx, dbName, drizzle) {
|
|
33
|
+
return { drizzle, nonce: ctx._nonce, tenant: ctx.tenant };
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"guard.js","sourceRoot":"","sources":["../../../src/request/context/guard.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAA;AAE/D,MAAM,UAAU,wBAAwB,CACtC,GAAS,EACT,KAAuB,EACvB,MAAc;IAEd,IAAI,KAAK,CAAC,KAAK,KAAK,GAAG,CAAC,MAAM,EAAE,CAAC;QAC/B,MAAM,IAAI,kBAAkB,CAAC,wBAAwB,EAAE;YACrD,OAAO,EACL,iCAAiC,MAAM,iDAAiD;gBACxF,2FAA2F;gBAC3F,uFAAuF;YACzF,gBAAgB,EAAE,KAAK,CAAC,KAAK;YAC7B,YAAY,EAAE,GAAG,CAAC,MAAM;YACxB,QAAQ,EAAE,MAAM;YAChB,aAAa,EAAE,GAAG,CAAC,MAAM;YACzB,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC,CAAA;IACJ,CAAC;IAED,IAAI,KAAK,CAAC,MAAM,KAAK,GAAG,CAAC,MAAM,EAAE,CAAC;QAChC,MAAM,IAAI,kBAAkB,CAAC,yBAAyB,EAAE;YACtD,OAAO,EACL,iCAAiC,MAAM,6BAA6B,KAAK,CAAC,MAAM,IAAI;gBACpF,uCAAuC,GAAG,CAAC,MAAM,yCAAyC;gBAC1F,qEAAqE;gBACrE,yEAAyE;gBACzE,4DAA4D;gBAC5D,kFAAkF;gBAClF,uDAAuD;gBACvD,QAAQ;YACV,iBAAiB,EAAE,KAAK,CAAC,MAAM;YAC/B,aAAa,EAAE,GAAG,CAAC,MAAM;YACzB,QAAQ,EAAE,MAAM;YAChB,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC,CAAA;IACJ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAC7B,GAAS,EACT,MAAc,EACd,OAAW;IAEX,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,CAAA;AAC3D,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export type { Flow, RequestMetadata, BoundTransaction } from './types.js';
|
|
2
|
+
export { flowStorage, getContext, requireContext, runInContext } from './store.js';
|
|
3
|
+
export { createRequestContext, createJobContext, createTestContext, type CreateRequestContextOptions, type CreateJobContextOptions } from './create.js';
|
|
4
|
+
export { verifyTransactionBinding, bindTransaction } from './guard.js';
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/request/context/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,IAAI,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AACzE,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAClF,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,KAAK,2BAA2B,EAAE,KAAK,uBAAuB,EAAE,MAAM,aAAa,CAAA;AACvJ,OAAO,EAAE,wBAAwB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { flowStorage, getContext, requireContext, runInContext } from './store.js';
|
|
2
|
+
export { createRequestContext, createJobContext, createTestContext } from './create.js';
|
|
3
|
+
export { verifyTransactionBinding, bindTransaction } from './guard.js';
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/request/context/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAClF,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,iBAAiB,EAAkE,MAAM,aAAa,CAAA;AACvJ,OAAO,EAAE,wBAAwB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from 'node:async_hooks';
|
|
2
|
+
import type { Flow } from './types.js';
|
|
3
|
+
export declare const flowStorage: AsyncLocalStorage<Flow<unknown>>;
|
|
4
|
+
export declare function getContext<TAuth = unknown>(): Flow<TAuth> | undefined;
|
|
5
|
+
export declare function requireContext<TAuth = unknown>(): Flow<TAuth>;
|
|
6
|
+
export declare function runInContext<T>(ctx: Flow, fn: () => T): T;
|
|
7
|
+
//# sourceMappingURL=store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../src/request/context/store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AACpD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AAEtC,eAAO,MAAM,WAAW,kCAAgC,CAAA;AAExD,wBAAgB,UAAU,CAAC,KAAK,GAAG,OAAO,KAAK,IAAI,CAAC,KAAK,CAAC,GAAG,SAAS,CAErE;AAED,wBAAgB,cAAc,CAAC,KAAK,GAAG,OAAO,KAAK,IAAI,CAAC,KAAK,CAAC,CAU7D;AAED,wBAAgB,YAAY,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,CAEzD"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from 'node:async_hooks';
|
|
2
|
+
export const flowStorage = new AsyncLocalStorage();
|
|
3
|
+
export function getContext() {
|
|
4
|
+
return flowStorage.getStore();
|
|
5
|
+
}
|
|
6
|
+
export function requireContext() {
|
|
7
|
+
const ctx = flowStorage.getStore();
|
|
8
|
+
if (!ctx) {
|
|
9
|
+
throw new Error('[pipework] No active context. db() must be called within a request handler, job, or test.\n\n' +
|
|
10
|
+
' Hint: If you need a connection outside of a managed context (migrations, seeds),\n' +
|
|
11
|
+
' use instance.pool.getOrCreate(config.database("name")).drizzle instead.\n');
|
|
12
|
+
}
|
|
13
|
+
return ctx;
|
|
14
|
+
}
|
|
15
|
+
export function runInContext(ctx, fn) {
|
|
16
|
+
return flowStorage.run(ctx, fn);
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/request/context/store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAGpD,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,iBAAiB,EAAQ,CAAA;AAExD,MAAM,UAAU,UAAU;IACxB,OAAO,WAAW,CAAC,QAAQ,EAA6B,CAAA;AAC1D,CAAC;AAED,MAAM,UAAU,cAAc;IAC5B,MAAM,GAAG,GAAG,WAAW,CAAC,QAAQ,EAA6B,CAAA;IAC7D,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,MAAM,IAAI,KAAK,CACb,+FAA+F;YAC/F,sFAAsF;YACtF,6EAA6E,CAC9E,CAAA;IACH,CAAC;IACD,OAAO,GAAG,CAAA;AACZ,CAAC;AAED,MAAM,UAAU,YAAY,CAAI,GAAS,EAAE,EAAW;IACpD,OAAO,WAAW,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;AACjC,CAAC"}
|