pipework 0.7.12 → 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 +5 -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.js +1 -1
- 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.js +1 -1
- 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.js +1 -1
- 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/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/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/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/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 +21 -21
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { sql } from '../../data/db/sql.js';
|
|
2
|
+
import { PipelineResumeError, PipelineStepError } from './errors.js';
|
|
3
|
+
export async function resumePipeline(db, config, runId, stepOutput) {
|
|
4
|
+
const [runRow] = await db.execute(sql `
|
|
5
|
+
UPDATE pipework_pipeline_runs
|
|
6
|
+
SET status = 'running'
|
|
7
|
+
WHERE id = ${runId}::uuid AND status = 'waiting'
|
|
8
|
+
RETURNING id, current_step, input, tenant_id, metadata, started_at
|
|
9
|
+
`);
|
|
10
|
+
if (runRow === undefined) {
|
|
11
|
+
const [existingRow] = await db.execute(sql `
|
|
12
|
+
SELECT status FROM pipework_pipeline_runs WHERE id = ${runId}::uuid
|
|
13
|
+
`);
|
|
14
|
+
if (existingRow === undefined) {
|
|
15
|
+
throw new PipelineResumeError(runId, 'Pipeline run not found.');
|
|
16
|
+
}
|
|
17
|
+
throw new PipelineResumeError(runId, `Expected status "waiting" but found "${String(existingRow['status'])}".`);
|
|
18
|
+
}
|
|
19
|
+
const currentStep = Number(runRow['current_step']);
|
|
20
|
+
const input = runRow['input'];
|
|
21
|
+
const tenant = String(runRow['tenant_id']);
|
|
22
|
+
const metadata = runRow['metadata'] ?? {};
|
|
23
|
+
const startedAt = new Date(String(runRow['started_at']));
|
|
24
|
+
await db.execute(sql `
|
|
25
|
+
UPDATE pipework_pipeline_steps SET status = 'completed', output = ${JSON.stringify(stepOutput ?? null)}::jsonb, completed_at = now()
|
|
26
|
+
WHERE run_id = ${runId}::uuid AND step_index = ${currentStep}
|
|
27
|
+
`);
|
|
28
|
+
let lastOutput = stepOutput;
|
|
29
|
+
for (let i = currentStep + 1; i < config.steps.length; i++) {
|
|
30
|
+
const step = config.steps[i];
|
|
31
|
+
if (step.async === true) {
|
|
32
|
+
await db.execute(sql `
|
|
33
|
+
UPDATE pipework_pipeline_runs SET status = 'waiting', current_step = ${i}
|
|
34
|
+
WHERE id = ${runId}::uuid
|
|
35
|
+
`);
|
|
36
|
+
return {
|
|
37
|
+
id: runId,
|
|
38
|
+
pipelineName: config.name,
|
|
39
|
+
status: 'waiting',
|
|
40
|
+
currentStep: i,
|
|
41
|
+
input,
|
|
42
|
+
startedAt,
|
|
43
|
+
completedAt: null,
|
|
44
|
+
error: null,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
await db.execute(sql `
|
|
48
|
+
UPDATE pipework_pipeline_steps SET status = 'running', started_at = now()
|
|
49
|
+
WHERE run_id = ${runId}::uuid AND step_index = ${i}
|
|
50
|
+
`);
|
|
51
|
+
try {
|
|
52
|
+
const stepCtx = {
|
|
53
|
+
db,
|
|
54
|
+
input: lastOutput,
|
|
55
|
+
runId,
|
|
56
|
+
stepIndex: i,
|
|
57
|
+
tenant,
|
|
58
|
+
metadata,
|
|
59
|
+
};
|
|
60
|
+
lastOutput = await step.handler(stepCtx);
|
|
61
|
+
await db.execute(sql `
|
|
62
|
+
UPDATE pipework_pipeline_steps SET status = 'completed', output = ${JSON.stringify(lastOutput ?? null)}::jsonb, completed_at = now()
|
|
63
|
+
WHERE run_id = ${runId}::uuid AND step_index = ${i}
|
|
64
|
+
`);
|
|
65
|
+
await db.execute(sql `
|
|
66
|
+
UPDATE pipework_pipeline_runs SET current_step = ${i + 1}
|
|
67
|
+
WHERE id = ${runId}::uuid
|
|
68
|
+
`);
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
const errorJson = error instanceof Error
|
|
72
|
+
? { message: error.message, stack: error.stack }
|
|
73
|
+
: { message: String(error) };
|
|
74
|
+
await db.execute(sql `
|
|
75
|
+
UPDATE pipework_pipeline_steps SET status = 'failed', error = ${JSON.stringify(errorJson)}::jsonb, completed_at = now()
|
|
76
|
+
WHERE run_id = ${runId}::uuid AND step_index = ${i}
|
|
77
|
+
`);
|
|
78
|
+
await db.execute(sql `
|
|
79
|
+
UPDATE pipework_pipeline_runs SET status = 'failed', error = ${JSON.stringify(errorJson)}::jsonb, completed_at = now()
|
|
80
|
+
WHERE id = ${runId}::uuid
|
|
81
|
+
`);
|
|
82
|
+
throw new PipelineStepError(config.name, step.name, i, error);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
await db.execute(sql `
|
|
86
|
+
UPDATE pipework_pipeline_runs SET status = 'completed', current_step = ${config.steps.length}, completed_at = now()
|
|
87
|
+
WHERE id = ${runId}::uuid
|
|
88
|
+
`);
|
|
89
|
+
return {
|
|
90
|
+
id: runId,
|
|
91
|
+
pipelineName: config.name,
|
|
92
|
+
status: 'completed',
|
|
93
|
+
currentStep: config.steps.length,
|
|
94
|
+
input,
|
|
95
|
+
startedAt,
|
|
96
|
+
completedAt: new Date(),
|
|
97
|
+
error: null,
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
//# sourceMappingURL=resume.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resume.js","sourceRoot":"","sources":["../../../src/async/pipeline/resume.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import type { DB } from '../../data/db/index.js';
|
|
2
|
+
export interface StepDefinition<TInput = unknown, TOutput = unknown> {
|
|
3
|
+
readonly name: string;
|
|
4
|
+
readonly async?: boolean;
|
|
5
|
+
readonly handler: (ctx: StepContext<TInput>) => Promise<TOutput>;
|
|
6
|
+
}
|
|
7
|
+
export interface StepContext<TInput = unknown> {
|
|
8
|
+
readonly db: DB;
|
|
9
|
+
readonly input: TInput;
|
|
10
|
+
readonly runId: string;
|
|
11
|
+
readonly stepIndex: number;
|
|
12
|
+
readonly tenant: string;
|
|
13
|
+
readonly metadata: Record<string, unknown>;
|
|
14
|
+
}
|
|
15
|
+
export interface PipelineConfig {
|
|
16
|
+
readonly name: string;
|
|
17
|
+
readonly database: string;
|
|
18
|
+
readonly steps: readonly StepDefinition[];
|
|
19
|
+
}
|
|
20
|
+
export type PipelineStatus = 'running' | 'waiting' | 'completed' | 'failed';
|
|
21
|
+
export type StepStatus = 'pending' | 'running' | 'completed' | 'failed';
|
|
22
|
+
export interface PipelineRun {
|
|
23
|
+
readonly id: string;
|
|
24
|
+
readonly pipelineName: string;
|
|
25
|
+
readonly status: PipelineStatus;
|
|
26
|
+
readonly currentStep: number;
|
|
27
|
+
readonly input: unknown;
|
|
28
|
+
readonly startedAt: Date;
|
|
29
|
+
readonly completedAt: Date | null;
|
|
30
|
+
readonly error: unknown | null;
|
|
31
|
+
}
|
|
32
|
+
export interface StepRunResult {
|
|
33
|
+
readonly stepName: string;
|
|
34
|
+
readonly status: StepStatus;
|
|
35
|
+
readonly output: unknown | null;
|
|
36
|
+
readonly startedAt: Date | null;
|
|
37
|
+
readonly completedAt: Date | null;
|
|
38
|
+
readonly error: unknown | null;
|
|
39
|
+
}
|
|
40
|
+
export interface PipelineExecuteContext {
|
|
41
|
+
readonly tenant: string;
|
|
42
|
+
readonly metadata?: Record<string, unknown>;
|
|
43
|
+
}
|
|
44
|
+
export interface Pipeline {
|
|
45
|
+
execute(db: DB, input: unknown, context: PipelineExecuteContext): Promise<PipelineRun>;
|
|
46
|
+
resume(db: DB, runId: string, stepOutput: unknown): Promise<PipelineRun>;
|
|
47
|
+
getStatus(db: DB, runId: string): Promise<PipelineRun | null>;
|
|
48
|
+
readonly definition: PipelineConfig;
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/async/pipeline/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAEhD,MAAM,WAAW,cAAc,CAAC,MAAM,GAAG,OAAO,EAAE,OAAO,GAAG,OAAO;IACjE,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,KAAK,CAAC,EAAE,OAAO,CAAA;IACxB,QAAQ,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,WAAW,CAAC,MAAM,CAAC,KAAK,OAAO,CAAC,OAAO,CAAC,CAAA;CACjE;AAED,MAAM,WAAW,WAAW,CAAC,MAAM,GAAG,OAAO;IAC3C,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAA;IACf,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAA;IAC1B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;IACvB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAC3C;AAED,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,KAAK,EAAE,SAAS,cAAc,EAAE,CAAA;CAC1C;AAED,MAAM,MAAM,cAAc,GAAG,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,CAAA;AAC3E,MAAM,MAAM,UAAU,GAAG,SAAS,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,CAAA;AAEvE,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAA;IAC/B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAA;IAC5B,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAA;IACvB,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAA;IACxB,QAAQ,CAAC,WAAW,EAAE,IAAI,GAAG,IAAI,CAAA;IACjC,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI,CAAA;CAC/B;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,MAAM,EAAE,UAAU,CAAA;IAC3B,QAAQ,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI,CAAA;IAC/B,QAAQ,CAAC,SAAS,EAAE,IAAI,GAAG,IAAI,CAAA;IAC/B,QAAQ,CAAC,WAAW,EAAE,IAAI,GAAG,IAAI,CAAA;IACjC,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI,CAAA;CAC/B;AAED,MAAM,WAAW,sBAAsB;IACrC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;IACvB,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAC5C;AAED,MAAM,WAAW,QAAQ;IACvB,OAAO,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,WAAW,CAAC,CAAA;IACtF,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC,CAAA;IACxE,SAAS,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAA;IAC7D,QAAQ,CAAC,UAAU,EAAE,cAAc,CAAA;CACpC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/async/pipeline/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"define.d.ts","sourceRoot":"","sources":["../../../src/async/state-machine/define.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,YAAY,EAAuC,MAAM,YAAY,CAAA;AAIvG,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,kBAAkB,GAAG,YAAY,CAwB3E"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { InvalidStateMachineError } from './errors.js';
|
|
2
|
+
import { buildTransitionMap, getValidTargets, attemptTransition, evaluateGuard } from './transition.js';
|
|
3
|
+
export function defineStateMachine(config) {
|
|
4
|
+
validate(config);
|
|
5
|
+
const transitionMap = buildTransitionMap(config.transitions);
|
|
6
|
+
return {
|
|
7
|
+
validTargets(from) {
|
|
8
|
+
return getValidTargets(transitionMap, from);
|
|
9
|
+
},
|
|
10
|
+
hasTransition(from, to) {
|
|
11
|
+
return getValidTargets(transitionMap, from).includes(to);
|
|
12
|
+
},
|
|
13
|
+
async canTransition(context) {
|
|
14
|
+
return evaluateGuard(transitionMap, context);
|
|
15
|
+
},
|
|
16
|
+
async transition(context) {
|
|
17
|
+
return attemptTransition(context, transitionMap);
|
|
18
|
+
},
|
|
19
|
+
definition: config,
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
function validate(config) {
|
|
23
|
+
if (config.states.length === 0) {
|
|
24
|
+
throw new InvalidStateMachineError('Must define at least one state.');
|
|
25
|
+
}
|
|
26
|
+
const stateSet = new Set(config.states);
|
|
27
|
+
if (stateSet.size !== config.states.length) {
|
|
28
|
+
const dupes = config.states.filter((s, i) => config.states.indexOf(s) !== i);
|
|
29
|
+
throw new InvalidStateMachineError(`Duplicate states: ${dupes.join(', ')}.`);
|
|
30
|
+
}
|
|
31
|
+
if (config.initial !== undefined && !stateSet.has(config.initial)) {
|
|
32
|
+
throw new InvalidStateMachineError(`Initial state "${config.initial}" is not in the states list.`);
|
|
33
|
+
}
|
|
34
|
+
for (const t of config.transitions) {
|
|
35
|
+
if (!stateSet.has(t.from)) {
|
|
36
|
+
throw new InvalidStateMachineError(`Transition references unknown source state "${t.from}".`);
|
|
37
|
+
}
|
|
38
|
+
const targets = typeof t.to === 'string' ? [t.to] : t.to;
|
|
39
|
+
for (const target of targets) {
|
|
40
|
+
if (!stateSet.has(target)) {
|
|
41
|
+
throw new InvalidStateMachineError(`Transition from "${t.from}" references unknown target state "${target}".`);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=define.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"define.js","sourceRoot":"","sources":["../../../src/async/state-machine/define.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAA;AACtD,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAEvG,MAAM,UAAU,kBAAkB,CAAC,MAA0B;IAC3D,QAAQ,CAAC,MAAM,CAAC,CAAA;IAEhB,MAAM,aAAa,GAAG,kBAAkB,CAAC,MAAM,CAAC,WAAW,CAAC,CAAA;IAE5D,OAAO;QACL,YAAY,CAAC,IAAY;YACvB,OAAO,eAAe,CAAC,aAAa,EAAE,IAAI,CAAC,CAAA;QAC7C,CAAC;QAED,aAAa,CAAC,IAAY,EAAE,EAAU;YACpC,OAAO,eAAe,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAC1D,CAAC;QAED,KAAK,CAAC,aAAa,CAAC,OAA0B;YAC5C,OAAO,aAAa,CAAC,aAAa,EAAE,OAAO,CAAC,CAAA;QAC9C,CAAC;QAED,KAAK,CAAC,UAAU,CAAC,OAA0B;YACzC,OAAO,iBAAiB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAA;QAClD,CAAC;QAED,UAAU,EAAE,MAAM;KACnB,CAAA;AACH,CAAC;AAED,SAAS,QAAQ,CAAC,MAA0B;IAC1C,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC/B,MAAM,IAAI,wBAAwB,CAAC,iCAAiC,CAAC,CAAA;IACvE,CAAC;IAED,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAEvC,IAAI,QAAQ,CAAC,IAAI,KAAK,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;QAC3C,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAA;QAC5E,MAAM,IAAI,wBAAwB,CAAC,qBAAqB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IAC9E,CAAC;IAED,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QAClE,MAAM,IAAI,wBAAwB,CAChC,kBAAkB,MAAM,CAAC,OAAO,8BAA8B,CAC/D,CAAA;IACH,CAAC;IAED,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,MAAM,IAAI,wBAAwB,CAChC,+CAA+C,CAAC,CAAC,IAAI,IAAI,CAC1D,CAAA;QACH,CAAC;QACD,MAAM,OAAO,GAAG,OAAO,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;QACxD,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC1B,MAAM,IAAI,wBAAwB,CAChC,oBAAoB,CAAC,CAAC,IAAI,sCAAsC,MAAM,IAAI,CAC3E,CAAA;YACH,CAAC;QACH,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { PipeworkError } from '../../core/errors/base.js';
|
|
2
|
+
export declare class InvalidTransitionError extends PipeworkError {
|
|
3
|
+
readonly code: "INVALID_TRANSITION";
|
|
4
|
+
readonly httpStatus: 409;
|
|
5
|
+
constructor(entityType: string, from: string, to: string, validTargets: readonly string[]);
|
|
6
|
+
}
|
|
7
|
+
export declare class InvalidStateMachineError extends PipeworkError {
|
|
8
|
+
readonly code: "INVALID_STATE_MACHINE";
|
|
9
|
+
readonly httpStatus: 500;
|
|
10
|
+
constructor(message: string);
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../../src/async/state-machine/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAA;AAEzD,qBAAa,sBAAuB,SAAQ,aAAa;IACvD,QAAQ,CAAC,IAAI,EAAG,oBAAoB,CAAS;IAC7C,QAAQ,CAAC,UAAU,EAAG,GAAG,CAAS;gBAGhC,UAAU,EAAE,MAAM,EAClB,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,MAAM,EACV,YAAY,EAAE,SAAS,MAAM,EAAE;CASlC;AAED,qBAAa,wBAAyB,SAAQ,aAAa;IACzD,QAAQ,CAAC,IAAI,EAAG,uBAAuB,CAAS;IAChD,QAAQ,CAAC,UAAU,EAAG,GAAG,CAAS;gBAEtB,OAAO,EAAE,MAAM;CAG5B"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { PipeworkError } from '../../core/errors/base.js';
|
|
2
|
+
export class InvalidTransitionError extends PipeworkError {
|
|
3
|
+
code = 'INVALID_TRANSITION';
|
|
4
|
+
httpStatus = 409;
|
|
5
|
+
constructor(entityType, from, to, validTargets) {
|
|
6
|
+
const targets = validTargets.length > 0
|
|
7
|
+
? `Valid targets from "${from}": ${validTargets.join(', ')}.`
|
|
8
|
+
: `No transitions defined from "${from}".`;
|
|
9
|
+
super(`Cannot transition ${entityType} from "${from}" to "${to}". ${targets}`);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export class InvalidStateMachineError extends PipeworkError {
|
|
13
|
+
code = 'INVALID_STATE_MACHINE';
|
|
14
|
+
httpStatus = 500;
|
|
15
|
+
constructor(message) {
|
|
16
|
+
super(`[pipework] Invalid state machine definition: ${message}`);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../../src/async/state-machine/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAA;AAEzD,MAAM,OAAO,sBAAuB,SAAQ,aAAa;IAC9C,IAAI,GAAG,oBAA6B,CAAA;IACpC,UAAU,GAAG,GAAY,CAAA;IAElC,YACE,UAAkB,EAClB,IAAY,EACZ,EAAU,EACV,YAA+B;QAE/B,MAAM,OAAO,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC;YACrC,CAAC,CAAC,uBAAuB,IAAI,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG;YAC7D,CAAC,CAAC,gCAAgC,IAAI,IAAI,CAAA;QAC5C,KAAK,CACH,qBAAqB,UAAU,UAAU,IAAI,SAAS,EAAE,MAAM,OAAO,EAAE,CACxE,CAAA;IACH,CAAC;CACF;AAED,MAAM,OAAO,wBAAyB,SAAQ,aAAa;IAChD,IAAI,GAAG,uBAAgC,CAAA;IACvC,UAAU,GAAG,GAAY,CAAA;IAElC,YAAY,OAAe;QACzB,KAAK,CAAC,gDAAgD,OAAO,EAAE,CAAC,CAAA;IAClE,CAAC;CACF"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { defineStateMachine } from './define.js';
|
|
2
|
+
export { InvalidTransitionError, InvalidStateMachineError } from './errors.js';
|
|
3
|
+
export type { StateMachineConfig, TransitionDef, TransitionContext, TransitionResult, StateMachine } from './types.js';
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/async/state-machine/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EAAE,sBAAsB,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAA;AAC9E,YAAY,EAAE,kBAAkB,EAAE,aAAa,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/async/state-machine/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EAAE,sBAAsB,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { defineStateMachine } from './define.js';
|
|
2
|
+
import { InvalidTransitionError, InvalidStateMachineError } from './errors.js';
|
|
3
|
+
/** State machine namespace — define valid transitions with guards and side effects. */
|
|
4
|
+
export declare const state: {
|
|
5
|
+
/** Defines a state machine from states, transitions, guards, and effects. Returns a StateMachine with transition/canTransition. */
|
|
6
|
+
define: typeof defineStateMachine;
|
|
7
|
+
/** Thrown when a transition is not allowed from the current state. */
|
|
8
|
+
InvalidTransitionError: typeof InvalidTransitionError;
|
|
9
|
+
/** Thrown when the state machine definition is internally inconsistent. */
|
|
10
|
+
InvalidStateMachineError: typeof InvalidStateMachineError;
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/async/state-machine/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EAAE,sBAAsB,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAA;AAE9E,uFAAuF;AACvF,eAAO,MAAM,KAAK;IAChB,mIAAmI;;IAEnI,sEAAsE;;IAEtE,2EAA2E;;CAE5E,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { defineStateMachine } from './define.js';
|
|
2
|
+
import { InvalidTransitionError, InvalidStateMachineError } from './errors.js';
|
|
3
|
+
/** State machine namespace — define valid transitions with guards and side effects. */
|
|
4
|
+
export const state = {
|
|
5
|
+
/** Defines a state machine from states, transitions, guards, and effects. Returns a StateMachine with transition/canTransition. */
|
|
6
|
+
define: defineStateMachine,
|
|
7
|
+
/** Thrown when a transition is not allowed from the current state. */
|
|
8
|
+
InvalidTransitionError,
|
|
9
|
+
/** Thrown when the state machine definition is internally inconsistent. */
|
|
10
|
+
InvalidStateMachineError,
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=namespace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../../src/async/state-machine/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EAAE,sBAAsB,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAA;AAE9E,uFAAuF;AACvF,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,mIAAmI;IACnI,MAAM,EAAE,kBAAkB;IAC1B,sEAAsE;IACtE,sBAAsB;IACtB,2EAA2E;IAC3E,wBAAwB;CACzB,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { TransitionDef, TransitionContext, TransitionResult } from './types.js';
|
|
2
|
+
export declare function buildTransitionMap(transitions: readonly TransitionDef[]): Map<string, TransitionDef[]>;
|
|
3
|
+
export declare function getValidTargets(transitionMap: Map<string, TransitionDef[]>, from: string): string[];
|
|
4
|
+
export declare function findMatchingDef(transitionMap: Map<string, TransitionDef[]>, from: string, to: string): TransitionDef | undefined;
|
|
5
|
+
export declare function evaluateGuard(transitionMap: Map<string, TransitionDef[]>, context: TransitionContext): Promise<boolean>;
|
|
6
|
+
export declare function attemptTransition(context: TransitionContext, transitionMap: Map<string, TransitionDef[]>): Promise<TransitionResult>;
|
|
7
|
+
//# sourceMappingURL=transition.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transition.d.ts","sourceRoot":"","sources":["../../../src/async/state-machine/transition.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AAGpF,wBAAgB,kBAAkB,CAAC,WAAW,EAAE,SAAS,aAAa,EAAE,GAAG,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,CAQtG;AAED,wBAAgB,eAAe,CAAC,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAWnG;AAED,wBAAgB,eAAe,CAC7B,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,EAC3C,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,MAAM,GACT,aAAa,GAAG,SAAS,CAK3B;AAED,wBAAsB,aAAa,CACjC,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,EAC3C,OAAO,EAAE,iBAAiB,GACzB,OAAO,CAAC,OAAO,CAAC,CAalB;AAED,wBAAsB,iBAAiB,CACrC,OAAO,EAAE,iBAAiB,EAC1B,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,GAC1C,OAAO,CAAC,gBAAgB,CAAC,CA+B3B"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { InvalidTransitionError } from './errors.js';
|
|
2
|
+
export function buildTransitionMap(transitions) {
|
|
3
|
+
const map = new Map();
|
|
4
|
+
for (const t of transitions) {
|
|
5
|
+
const existing = map.get(t.from) ?? [];
|
|
6
|
+
existing.push(t);
|
|
7
|
+
map.set(t.from, existing);
|
|
8
|
+
}
|
|
9
|
+
return map;
|
|
10
|
+
}
|
|
11
|
+
export function getValidTargets(transitionMap, from) {
|
|
12
|
+
const defs = transitionMap.get(from) ?? [];
|
|
13
|
+
const targets = [];
|
|
14
|
+
for (const def of defs) {
|
|
15
|
+
if (typeof def.to === 'string') {
|
|
16
|
+
targets.push(def.to);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
targets.push(...def.to);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
return targets;
|
|
23
|
+
}
|
|
24
|
+
export function findMatchingDef(transitionMap, from, to) {
|
|
25
|
+
const defs = transitionMap.get(from) ?? [];
|
|
26
|
+
return defs.find(d => typeof d.to === 'string' ? d.to === to : d.to.includes(to));
|
|
27
|
+
}
|
|
28
|
+
export async function evaluateGuard(transitionMap, context) {
|
|
29
|
+
const validTargets = getValidTargets(transitionMap, context.from);
|
|
30
|
+
if (!validTargets.includes(context.to)) {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
const matchingDef = findMatchingDef(transitionMap, context.from, context.to);
|
|
34
|
+
if (matchingDef?.guard !== undefined) {
|
|
35
|
+
return matchingDef.guard(context);
|
|
36
|
+
}
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
39
|
+
export async function attemptTransition(context, transitionMap) {
|
|
40
|
+
const validTargets = getValidTargets(transitionMap, context.from);
|
|
41
|
+
if (!validTargets.includes(context.to)) {
|
|
42
|
+
throw new InvalidTransitionError(context.entityType, context.from, context.to, validTargets);
|
|
43
|
+
}
|
|
44
|
+
const matchingDef = findMatchingDef(transitionMap, context.from, context.to);
|
|
45
|
+
if (matchingDef?.guard !== undefined) {
|
|
46
|
+
const allowed = await matchingDef.guard(context);
|
|
47
|
+
if (!allowed) {
|
|
48
|
+
throw new InvalidTransitionError(context.entityType, context.from, context.to, validTargets);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
from: context.from,
|
|
53
|
+
to: context.to,
|
|
54
|
+
entityId: context.entityId,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=transition.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transition.js","sourceRoot":"","sources":["../../../src/async/state-machine/transition.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { Audit } from '../../infra/audit/types.js';
|
|
2
|
+
export interface TransitionDef {
|
|
3
|
+
readonly from: string;
|
|
4
|
+
readonly to: string | readonly string[];
|
|
5
|
+
readonly guard?: (context: TransitionContext) => boolean | Promise<boolean>;
|
|
6
|
+
}
|
|
7
|
+
export interface StateMachineConfig {
|
|
8
|
+
readonly states: readonly string[];
|
|
9
|
+
readonly transitions: readonly TransitionDef[];
|
|
10
|
+
readonly initial?: string;
|
|
11
|
+
readonly audit?: Audit;
|
|
12
|
+
}
|
|
13
|
+
export interface TransitionContext {
|
|
14
|
+
readonly entityId: string;
|
|
15
|
+
readonly entityType: string;
|
|
16
|
+
readonly from: string;
|
|
17
|
+
readonly to: string;
|
|
18
|
+
readonly userId?: string;
|
|
19
|
+
readonly metadata?: Record<string, unknown>;
|
|
20
|
+
}
|
|
21
|
+
export interface TransitionResult {
|
|
22
|
+
readonly from: string;
|
|
23
|
+
readonly to: string;
|
|
24
|
+
readonly entityId: string;
|
|
25
|
+
}
|
|
26
|
+
export interface StateMachine {
|
|
27
|
+
validTargets(from: string): readonly string[];
|
|
28
|
+
hasTransition(from: string, to: string): boolean;
|
|
29
|
+
canTransition(context: TransitionContext): Promise<boolean>;
|
|
30
|
+
transition(context: TransitionContext): Promise<TransitionResult>;
|
|
31
|
+
readonly definition: StateMachineConfig;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/async/state-machine/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAA;AAEvD,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,MAAM,EAAE,CAAA;IACvC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAA;CAC5E;AAED,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,MAAM,EAAE,SAAS,MAAM,EAAE,CAAA;IAClC,QAAQ,CAAC,WAAW,EAAE,SAAS,aAAa,EAAE,CAAA;IAC9C,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,KAAK,CAAC,EAAE,KAAK,CAAA;CACvB;AAED,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAA;IAC3B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;IACxB,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAC5C;AAED,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;CAC1B;AAED,MAAM,WAAW,YAAY;IAC3B,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,MAAM,EAAE,CAAA;IAC7C,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAA;IAChD,aAAa,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,OAAO,CAAC,CAAA;IAC3D,UAAU,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAA;IACjE,QAAQ,CAAC,UAAU,EAAE,kBAAkB,CAAA;CACxC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/async/state-machine/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { AuthStrategy, AuthRequest, AuthContext } from './types.js';
|
|
2
|
+
/** Post-authentication hook — enrich the resolved auth with additional data (roles, permissions, etc.). */
|
|
3
|
+
export interface AuthEnricher<TAuth> {
|
|
4
|
+
readonly name: string;
|
|
5
|
+
enrich(auth: TAuth): Promise<TAuth>;
|
|
6
|
+
}
|
|
7
|
+
/** Resolves tenant ID from auth context — called after authentication in the chain. */
|
|
8
|
+
export interface TenantResolver<TAuth> {
|
|
9
|
+
resolve(auth: TAuth): string;
|
|
10
|
+
}
|
|
11
|
+
/** Configuration for the auth chain — strategies, enrichers, tenant resolver. */
|
|
12
|
+
export interface AuthChainConfig<TAuth> {
|
|
13
|
+
readonly strategies: readonly AuthStrategy<TAuth>[];
|
|
14
|
+
readonly enrichers?: readonly AuthEnricher<TAuth>[];
|
|
15
|
+
readonly tenantResolver?: TenantResolver<TAuth>;
|
|
16
|
+
}
|
|
17
|
+
/** Result of running the auth chain — resolved auth and tenant (both nullable for public routes). */
|
|
18
|
+
export interface AuthChainResult<TAuth> {
|
|
19
|
+
readonly auth: TAuth | null;
|
|
20
|
+
readonly tenant: string | null;
|
|
21
|
+
}
|
|
22
|
+
/** Executes the auth chain: tries strategies in order, enriches, resolves tenant. */
|
|
23
|
+
export declare function runAuthChain<TAuth>(config: AuthChainConfig<TAuth>, request: AuthRequest, options: {
|
|
24
|
+
optional: boolean;
|
|
25
|
+
}, context: AuthContext): Promise<AuthChainResult<TAuth>>;
|
|
26
|
+
//# sourceMappingURL=chain.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chain.d.ts","sourceRoot":"","sources":["../../../src/auth/auth/chain.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AAGxE,2GAA2G;AAC3G,MAAM,WAAW,YAAY,CAAC,KAAK;IACjC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,MAAM,CAAC,IAAI,EAAE,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAA;CACpC;AAED,uFAAuF;AACvF,MAAM,WAAW,cAAc,CAAC,KAAK;IACnC,OAAO,CAAC,IAAI,EAAE,KAAK,GAAG,MAAM,CAAA;CAC7B;AAED,iFAAiF;AACjF,MAAM,WAAW,eAAe,CAAC,KAAK;IACpC,QAAQ,CAAC,UAAU,EAAE,SAAS,YAAY,CAAC,KAAK,CAAC,EAAE,CAAA;IACnD,QAAQ,CAAC,SAAS,CAAC,EAAE,SAAS,YAAY,CAAC,KAAK,CAAC,EAAE,CAAA;IACnD,QAAQ,CAAC,cAAc,CAAC,EAAE,cAAc,CAAC,KAAK,CAAC,CAAA;CAChD;AAED,qGAAqG;AACrG,MAAM,WAAW,eAAe,CAAC,KAAK;IACpC,QAAQ,CAAC,IAAI,EAAE,KAAK,GAAG,IAAI,CAAA;IAC3B,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;CAC/B;AAED,qFAAqF;AACrF,wBAAsB,YAAY,CAAC,KAAK,EACtC,MAAM,EAAE,eAAe,CAAC,KAAK,CAAC,EAC9B,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE;IAAE,QAAQ,EAAE,OAAO,CAAA;CAAE,EAC9B,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAqCjC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { UnauthorizedError } from '../../core/errors/index.js';
|
|
2
|
+
/** Executes the auth chain: tries strategies in order, enriches, resolves tenant. */
|
|
3
|
+
export async function runAuthChain(config, request, options, context) {
|
|
4
|
+
let extracted = null;
|
|
5
|
+
let matchedStrategy = null;
|
|
6
|
+
for (const strategy of config.strategies) {
|
|
7
|
+
extracted = await strategy.extract(request, context);
|
|
8
|
+
if (extracted !== null) {
|
|
9
|
+
matchedStrategy = strategy;
|
|
10
|
+
break;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
if (extracted === null) {
|
|
14
|
+
if (options.optional)
|
|
15
|
+
return { auth: null, tenant: null };
|
|
16
|
+
throw new UnauthorizedError();
|
|
17
|
+
}
|
|
18
|
+
let auth;
|
|
19
|
+
try {
|
|
20
|
+
auth = await matchedStrategy.verify(extracted, context);
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
23
|
+
if (error instanceof UnauthorizedError)
|
|
24
|
+
throw error;
|
|
25
|
+
throw new UnauthorizedError('Authentication failed', {
|
|
26
|
+
strategy: matchedStrategy.name,
|
|
27
|
+
cause: error instanceof Error ? error.message : String(error),
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
if (config.enrichers) {
|
|
31
|
+
for (const enricher of config.enrichers) {
|
|
32
|
+
auth = await enricher.enrich(auth);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
const tenant = config.tenantResolver ? config.tenantResolver.resolve(auth) : extractTenant(auth);
|
|
36
|
+
return { auth, tenant };
|
|
37
|
+
}
|
|
38
|
+
function extractTenant(auth) {
|
|
39
|
+
if (auth !== null && typeof auth === 'object' && 'tenantId' in auth) {
|
|
40
|
+
const tenantId = auth.tenantId;
|
|
41
|
+
if (typeof tenantId === 'string')
|
|
42
|
+
return tenantId;
|
|
43
|
+
}
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=chain.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chain.js","sourceRoot":"","sources":["../../../src/auth/auth/chain.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAA;AA0B9D,qFAAqF;AACrF,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,MAA8B,EAC9B,OAAoB,EACpB,OAA8B,EAC9B,OAAoB;IAEpB,IAAI,SAAS,GAAiB,IAAI,CAAA;IAClC,IAAI,eAAe,GAA+B,IAAI,CAAA;IAEtD,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;QACzC,SAAS,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;QACpD,IAAI,SAAS,KAAK,IAAI,EAAE,CAAC;YACvB,eAAe,GAAG,QAAQ,CAAA;YAC1B,MAAK;QACP,CAAC;IACH,CAAC;IAED,IAAI,SAAS,KAAK,IAAI,EAAE,CAAC;QACvB,IAAI,OAAO,CAAC,QAAQ;YAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAA;QACzD,MAAM,IAAI,iBAAiB,EAAE,CAAA;IAC/B,CAAC;IAED,IAAI,IAAW,CAAA;IACf,IAAI,CAAC;QACH,IAAI,GAAG,MAAM,eAAgB,CAAC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;IAC1D,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,YAAY,iBAAiB;YAAE,MAAM,KAAK,CAAA;QACnD,MAAM,IAAI,iBAAiB,CAAC,uBAAuB,EAAE;YACnD,QAAQ,EAAE,eAAgB,CAAC,IAAI;YAC/B,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;SAC9D,CAAC,CAAA;IACJ,CAAC;IAED,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;QACrB,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;YACxC,IAAI,GAAG,MAAM,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QACpC,CAAC;IACH,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,CAAA;IAEhG,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAA;AACzB,CAAC;AAED,SAAS,aAAa,CAAC,IAAa;IAClC,IAAI,IAAI,KAAK,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,UAAU,IAAI,IAAI,EAAE,CAAC;QACpE,MAAM,QAAQ,GAAI,IAA8B,CAAC,QAAQ,CAAA;QACzD,IAAI,OAAO,QAAQ,KAAK,QAAQ;YAAE,OAAO,QAAQ,CAAA;IACnD,CAAC;IACD,OAAO,IAAI,CAAA;AACb,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/** Cookie configuration for token delivery — name, domain, path, secure, sameSite, httpOnly. */
|
|
2
|
+
export interface CookieConfig {
|
|
3
|
+
readonly name?: string;
|
|
4
|
+
readonly secure?: 'auto' | boolean;
|
|
5
|
+
readonly sameSite?: 'strict' | 'lax' | 'none';
|
|
6
|
+
readonly path?: string;
|
|
7
|
+
}
|
|
8
|
+
/** CookieConfig with all defaults resolved — every field is required. */
|
|
9
|
+
export interface ResolvedCookieConfig {
|
|
10
|
+
readonly name: string;
|
|
11
|
+
readonly secure: boolean;
|
|
12
|
+
readonly sameSite: string;
|
|
13
|
+
readonly path: string;
|
|
14
|
+
readonly httpOnly: true;
|
|
15
|
+
}
|
|
16
|
+
/** Resolves a partial CookieConfig into a ResolvedCookieConfig with secure defaults. */
|
|
17
|
+
export declare function resolveCookieConfig(cookie: CookieConfig, env: string): ResolvedCookieConfig;
|
|
18
|
+
/** Builds a Set-Cookie header string from name, value, and resolved config. */
|
|
19
|
+
export declare function buildSetCookieHeader(resolved: ResolvedCookieConfig, value: string, maxAge: number): string;
|
|
20
|
+
/** Builds a Set-Cookie header that expires (clears) a cookie. */
|
|
21
|
+
export declare function buildClearCookieHeader(resolved: ResolvedCookieConfig): string;
|
|
22
|
+
/** Parses a Cookie header string into a Record of key-value pairs. */
|
|
23
|
+
export declare function parseCookieHeader(header: string | undefined, name: string): string | undefined;
|
|
24
|
+
//# sourceMappingURL=cookie.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cookie.d.ts","sourceRoot":"","sources":["../../../src/auth/auth/cookie.ts"],"names":[],"mappings":"AAAA,gGAAgG;AAChG,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAA;IAClC,QAAQ,CAAC,QAAQ,CAAC,EAAE,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAA;IAC7C,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CACvB;AAED,yEAAyE;AACzE,MAAM,WAAW,oBAAoB;IACnC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,MAAM,EAAE,OAAO,CAAA;IACxB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,QAAQ,EAAE,IAAI,CAAA;CACxB;AAED,wFAAwF;AACxF,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,YAAY,EAAE,GAAG,EAAE,MAAM,GAAG,oBAAoB,CAY3F;AAED,+EAA+E;AAC/E,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,oBAAoB,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAU1G;AAED,iEAAiE;AACjE,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,oBAAoB,GAAG,MAAM,CAU7E;AAED,sEAAsE;AACtE,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAY9F"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/** Resolves a partial CookieConfig into a ResolvedCookieConfig with secure defaults. */
|
|
2
|
+
export function resolveCookieConfig(cookie, env) {
|
|
3
|
+
const secure = cookie.secure === 'auto' || cookie.secure === undefined
|
|
4
|
+
? env === 'production'
|
|
5
|
+
: cookie.secure;
|
|
6
|
+
return {
|
|
7
|
+
name: cookie.name ?? '__pipework_refresh',
|
|
8
|
+
secure,
|
|
9
|
+
sameSite: cookie.sameSite ?? 'strict',
|
|
10
|
+
path: cookie.path ?? '/',
|
|
11
|
+
httpOnly: true,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
/** Builds a Set-Cookie header string from name, value, and resolved config. */
|
|
15
|
+
export function buildSetCookieHeader(resolved, value, maxAge) {
|
|
16
|
+
const parts = [
|
|
17
|
+
`${resolved.name}=${encodeURIComponent(value)}`,
|
|
18
|
+
`HttpOnly`,
|
|
19
|
+
`Path=${resolved.path}`,
|
|
20
|
+
`Max-Age=${maxAge}`,
|
|
21
|
+
`SameSite=${capitalize(resolved.sameSite)}`,
|
|
22
|
+
];
|
|
23
|
+
if (resolved.secure)
|
|
24
|
+
parts.push('Secure');
|
|
25
|
+
return parts.join('; ');
|
|
26
|
+
}
|
|
27
|
+
/** Builds a Set-Cookie header that expires (clears) a cookie. */
|
|
28
|
+
export function buildClearCookieHeader(resolved) {
|
|
29
|
+
const parts = [
|
|
30
|
+
`${resolved.name}=`,
|
|
31
|
+
`HttpOnly`,
|
|
32
|
+
`Path=${resolved.path}`,
|
|
33
|
+
`Max-Age=0`,
|
|
34
|
+
`SameSite=${capitalize(resolved.sameSite)}`,
|
|
35
|
+
];
|
|
36
|
+
if (resolved.secure)
|
|
37
|
+
parts.push('Secure');
|
|
38
|
+
return parts.join('; ');
|
|
39
|
+
}
|
|
40
|
+
/** Parses a Cookie header string into a Record of key-value pairs. */
|
|
41
|
+
export function parseCookieHeader(header, name) {
|
|
42
|
+
if (header === undefined)
|
|
43
|
+
return undefined;
|
|
44
|
+
for (const pair of header.split(';')) {
|
|
45
|
+
const trimmed = pair.trim();
|
|
46
|
+
const eqIdx = trimmed.indexOf('=');
|
|
47
|
+
if (eqIdx === -1)
|
|
48
|
+
continue;
|
|
49
|
+
const key = trimmed.slice(0, eqIdx).trim();
|
|
50
|
+
if (key === name) {
|
|
51
|
+
return decodeURIComponent(trimmed.slice(eqIdx + 1).trim());
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return undefined;
|
|
55
|
+
}
|
|
56
|
+
function capitalize(s) {
|
|
57
|
+
return s.charAt(0).toUpperCase() + s.slice(1);
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=cookie.js.map
|