pipework 0.7.12 → 0.7.17
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 +24 -0
- package/README.md +3 -2
- package/REFERENCE.md +327 -296
- package/dist/REFERENCE.md +396 -431
- 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.d.ts +2 -1
- package/dist/cli/commands/check.d.ts.map +1 -1
- package/dist/cli/commands/check.js +53 -18
- 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.d.ts.map +1 -1
- package/dist/cli/commands/migrate.js +5 -8
- 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/scope.d.ts +12 -0
- package/dist/cli/commands/scope.d.ts.map +1 -0
- package/dist/cli/commands/scope.js +25 -0
- package/dist/cli/commands/scope.js.map +1 -0
- 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 +3 -0
- package/dist/cli/commands/test.d.ts.map +1 -1
- package/dist/cli/commands/test.js +66 -2
- 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 +22 -3
- package/dist/cli/index.js.map +1 -1
- package/dist/config/discover.d.ts.map +1 -1
- package/dist/config/discover.js +0 -14
- package/dist/config/discover.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 +174 -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 +407 -0
- package/dist/core/config/schema.d.ts.map +1 -0
- package/dist/core/config/schema.js +107 -0
- package/dist/core/config/schema.js.map +1 -0
- package/dist/core/config/ts-register.d.ts.map +1 -0
- package/dist/core/config/ts-register.js.map +1 -0
- package/dist/core/config/ts-resolve-hooks.d.ts.map +1 -0
- package/dist/{config → core/config}/ts-resolve-hooks.js +2 -1
- 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.map +1 -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.map +1 -0
- package/dist/{db → data/db}/excluded.js +2 -2
- 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.map +1 -0
- package/dist/data/jsonb/index.js.map +1 -0
- package/dist/data/jsonb/namespace.d.ts.map +1 -0
- package/dist/data/jsonb/namespace.js.map +1 -0
- package/dist/data/jsonb/query.d.ts.map +1 -0
- package/dist/data/jsonb/query.js.map +1 -0
- package/dist/data/migrate/apply.d.ts +8 -0
- package/dist/data/migrate/apply.d.ts.map +1 -0
- package/dist/data/migrate/apply.js +91 -0
- package/dist/data/migrate/apply.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/diff.d.ts +118 -0
- package/dist/data/migrate/diff.d.ts.map +1 -0
- package/dist/data/migrate/diff.js +215 -0
- package/dist/data/migrate/diff.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 +142 -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 +55 -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/migrate/snapshot.d.ts +87 -0
- package/dist/data/migrate/snapshot.d.ts.map +1 -0
- package/dist/data/migrate/snapshot.js +204 -0
- package/dist/data/migrate/snapshot.js.map +1 -0
- package/dist/data/migrate/sql-emit.d.ts +3 -0
- package/dist/data/migrate/sql-emit.d.ts.map +1 -0
- package/dist/data/migrate/sql-emit.js +220 -0
- package/dist/data/migrate/sql-emit.js.map +1 -0
- package/dist/data/query/alias.d.ts +32 -0
- package/dist/data/query/alias.d.ts.map +1 -0
- package/dist/data/query/alias.js +101 -0
- package/dist/data/query/alias.js.map +1 -0
- package/dist/data/query/batch.d.ts +7 -0
- package/dist/data/query/batch.d.ts.map +1 -0
- package/dist/data/query/batch.js +2 -0
- package/dist/data/query/batch.js.map +1 -0
- package/dist/data/query/cache/core/cache.d.ts +37 -0
- package/dist/data/query/cache/core/cache.d.ts.map +1 -0
- package/dist/data/query/cache/core/cache.js +29 -0
- package/dist/data/query/cache/core/cache.js.map +1 -0
- package/dist/data/query/cache/core/index.d.ts +2 -0
- package/dist/data/query/cache/core/index.d.ts.map +1 -0
- package/dist/data/query/cache/core/index.js +2 -0
- package/dist/data/query/cache/core/index.js.map +1 -0
- package/dist/data/query/cache/core/types.d.ts +34 -0
- package/dist/data/query/cache/core/types.d.ts.map +1 -0
- package/dist/data/query/cache/core/types.js +2 -0
- package/dist/data/query/cache/core/types.js.map +1 -0
- package/dist/data/query/casing.d.ts +17 -0
- package/dist/data/query/casing.d.ts.map +1 -0
- package/dist/data/query/casing.js +62 -0
- package/dist/data/query/casing.js.map +1 -0
- package/dist/data/query/column-builder.d.ts +241 -0
- package/dist/data/query/column-builder.d.ts.map +1 -0
- package/dist/data/query/column-builder.js +105 -0
- package/dist/data/query/column-builder.js.map +1 -0
- package/dist/data/query/column.d.ts +70 -0
- package/dist/data/query/column.d.ts.map +1 -0
- package/dist/data/query/column.js +57 -0
- package/dist/data/query/column.js.map +1 -0
- package/dist/data/query/entity.d.ts +8 -0
- package/dist/data/query/entity.d.ts.map +1 -0
- package/dist/data/query/entity.js +25 -0
- package/dist/data/query/entity.js.map +1 -0
- package/dist/data/query/errors.d.ts +19 -0
- package/dist/data/query/errors.d.ts.map +1 -0
- package/dist/data/query/errors.js +31 -0
- package/dist/data/query/errors.js.map +1 -0
- package/dist/data/query/index.d.ts +15 -0
- package/dist/data/query/index.d.ts.map +1 -0
- package/dist/data/query/index.js +15 -0
- package/dist/data/query/index.js.map +1 -0
- package/dist/data/query/logger.d.ts +24 -0
- package/dist/data/query/logger.d.ts.map +1 -0
- package/dist/data/query/logger.js +33 -0
- package/dist/data/query/logger.js.map +1 -0
- package/dist/data/query/operations.d.ts +25 -0
- package/dist/data/query/operations.d.ts.map +1 -0
- package/dist/data/query/operations.js +2 -0
- package/dist/data/query/operations.js.map +1 -0
- package/dist/data/query/pg-core/alias.d.ts +5 -0
- package/dist/data/query/pg-core/alias.d.ts.map +1 -0
- package/dist/data/query/pg-core/alias.js +5 -0
- package/dist/data/query/pg-core/alias.js.map +1 -0
- package/dist/data/query/pg-core/checks.d.ts +21 -0
- package/dist/data/query/pg-core/checks.d.ts.map +1 -0
- package/dist/data/query/pg-core/checks.js +30 -0
- package/dist/data/query/pg-core/checks.js.map +1 -0
- package/dist/data/query/pg-core/columns/all.d.ts +68 -0
- package/dist/data/query/pg-core/columns/all.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/all.js +69 -0
- package/dist/data/query/pg-core/columns/all.js.map +1 -0
- package/dist/data/query/pg-core/columns/bigint.d.ts +54 -0
- package/dist/data/query/pg-core/columns/bigint.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/bigint.js +54 -0
- package/dist/data/query/pg-core/columns/bigint.js.map +1 -0
- package/dist/data/query/pg-core/columns/bigserial.d.ts +53 -0
- package/dist/data/query/pg-core/columns/bigserial.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/bigserial.js +56 -0
- package/dist/data/query/pg-core/columns/bigserial.js.map +1 -0
- package/dist/data/query/pg-core/columns/boolean.d.ts +28 -0
- package/dist/data/query/pg-core/columns/boolean.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/boolean.js +22 -0
- package/dist/data/query/pg-core/columns/boolean.js.map +1 -0
- package/dist/data/query/pg-core/columns/char.d.ts +53 -0
- package/dist/data/query/pg-core/columns/char.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/char.js +28 -0
- package/dist/data/query/pg-core/columns/char.js.map +1 -0
- package/dist/data/query/pg-core/columns/cidr.d.ts +28 -0
- package/dist/data/query/pg-core/columns/cidr.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/cidr.js +22 -0
- package/dist/data/query/pg-core/columns/cidr.js.map +1 -0
- package/dist/data/query/pg-core/columns/common.d.ts +167 -0
- package/dist/data/query/pg-core/columns/common.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/common.js +190 -0
- package/dist/data/query/pg-core/columns/common.js.map +1 -0
- package/dist/data/query/pg-core/columns/custom.d.ts +160 -0
- package/dist/data/query/pg-core/columns/custom.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/custom.js +46 -0
- package/dist/data/query/pg-core/columns/custom.js.map +1 -0
- package/dist/data/query/pg-core/columns/date.common.d.ts +8 -0
- package/dist/data/query/pg-core/columns/date.common.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/date.common.js +10 -0
- package/dist/data/query/pg-core/columns/date.common.js.map +1 -0
- package/dist/data/query/pg-core/columns/date.d.ts +57 -0
- package/dist/data/query/pg-core/columns/date.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/date.js +57 -0
- package/dist/data/query/pg-core/columns/date.js.map +1 -0
- package/dist/data/query/pg-core/columns/double-precision.d.ts +29 -0
- package/dist/data/query/pg-core/columns/double-precision.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/double-precision.js +28 -0
- package/dist/data/query/pg-core/columns/double-precision.js.map +1 -0
- package/dist/data/query/pg-core/columns/enum.d.ts +102 -0
- package/dist/data/query/pg-core/columns/enum.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/enum.js +78 -0
- package/dist/data/query/pg-core/columns/enum.js.map +1 -0
- package/dist/data/query/pg-core/columns/index.d.ts +36 -0
- package/dist/data/query/pg-core/columns/index.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/index.js +36 -0
- package/dist/data/query/pg-core/columns/index.js.map +1 -0
- package/dist/data/query/pg-core/columns/inet.d.ts +28 -0
- package/dist/data/query/pg-core/columns/inet.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/inet.js +22 -0
- package/dist/data/query/pg-core/columns/inet.js.map +1 -0
- package/dist/data/query/pg-core/columns/int.common.d.ts +16 -0
- package/dist/data/query/pg-core/columns/int.common.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/int.common.js +42 -0
- package/dist/data/query/pg-core/columns/int.common.js.map +1 -0
- package/dist/data/query/pg-core/columns/integer.d.ts +30 -0
- package/dist/data/query/pg-core/columns/integer.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/integer.js +29 -0
- package/dist/data/query/pg-core/columns/integer.js.map +1 -0
- package/dist/data/query/pg-core/columns/interval.d.ts +40 -0
- package/dist/data/query/pg-core/columns/interval.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/interval.js +29 -0
- package/dist/data/query/pg-core/columns/interval.js.map +1 -0
- package/dist/data/query/pg-core/columns/json.d.ts +33 -0
- package/dist/data/query/pg-core/columns/json.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/json.js +39 -0
- package/dist/data/query/pg-core/columns/json.js.map +1 -0
- package/dist/data/query/pg-core/columns/jsonb.d.ts +33 -0
- package/dist/data/query/pg-core/columns/jsonb.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/jsonb.js +39 -0
- package/dist/data/query/pg-core/columns/jsonb.js.map +1 -0
- package/dist/data/query/pg-core/columns/line.d.ts +69 -0
- package/dist/data/query/pg-core/columns/line.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/line.js +57 -0
- package/dist/data/query/pg-core/columns/line.js.map +1 -0
- package/dist/data/query/pg-core/columns/macaddr.d.ts +28 -0
- package/dist/data/query/pg-core/columns/macaddr.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/macaddr.js +22 -0
- package/dist/data/query/pg-core/columns/macaddr.js.map +1 -0
- package/dist/data/query/pg-core/columns/macaddr8.d.ts +28 -0
- package/dist/data/query/pg-core/columns/macaddr8.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/macaddr8.js +22 -0
- package/dist/data/query/pg-core/columns/macaddr8.js.map +1 -0
- package/dist/data/query/pg-core/columns/numeric.d.ts +112 -0
- package/dist/data/query/pg-core/columns/numeric.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/numeric.js +126 -0
- package/dist/data/query/pg-core/columns/numeric.js.map +1 -0
- package/dist/data/query/pg-core/columns/point.d.ts +72 -0
- package/dist/data/query/pg-core/columns/point.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/point.js +63 -0
- package/dist/data/query/pg-core/columns/point.js.map +1 -0
- package/dist/data/query/pg-core/columns/postgis_extension/geometry.d.ts +68 -0
- package/dist/data/query/pg-core/columns/postgis_extension/geometry.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/postgis_extension/geometry.js +57 -0
- package/dist/data/query/pg-core/columns/postgis_extension/geometry.js.map +1 -0
- package/dist/data/query/pg-core/columns/postgis_extension/utils.d.ts +2 -0
- package/dist/data/query/pg-core/columns/postgis_extension/utils.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/postgis_extension/utils.js +39 -0
- package/dist/data/query/pg-core/columns/postgis_extension/utils.js.map +1 -0
- package/dist/data/query/pg-core/columns/real.d.ts +34 -0
- package/dist/data/query/pg-core/columns/real.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/real.js +32 -0
- package/dist/data/query/pg-core/columns/real.js.map +1 -0
- package/dist/data/query/pg-core/columns/serial.d.ts +28 -0
- package/dist/data/query/pg-core/columns/serial.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/serial.js +24 -0
- package/dist/data/query/pg-core/columns/serial.js.map +1 -0
- package/dist/data/query/pg-core/columns/smallint.d.ts +30 -0
- package/dist/data/query/pg-core/columns/smallint.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/smallint.js +29 -0
- package/dist/data/query/pg-core/columns/smallint.js.map +1 -0
- package/dist/data/query/pg-core/columns/smallserial.d.ts +28 -0
- package/dist/data/query/pg-core/columns/smallserial.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/smallserial.js +24 -0
- package/dist/data/query/pg-core/columns/smallserial.js.map +1 -0
- package/dist/data/query/pg-core/columns/text.d.ts +38 -0
- package/dist/data/query/pg-core/columns/text.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/text.js +26 -0
- package/dist/data/query/pg-core/columns/text.js.map +1 -0
- package/dist/data/query/pg-core/columns/time.d.ts +45 -0
- package/dist/data/query/pg-core/columns/time.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/time.js +39 -0
- package/dist/data/query/pg-core/columns/time.js.map +1 -0
- package/dist/data/query/pg-core/columns/timestamp.d.ts +76 -0
- package/dist/data/query/pg-core/columns/timestamp.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/timestamp.js +83 -0
- package/dist/data/query/pg-core/columns/timestamp.js.map +1 -0
- package/dist/data/query/pg-core/columns/uuid.d.ts +32 -0
- package/dist/data/query/pg-core/columns/uuid.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/uuid.js +29 -0
- package/dist/data/query/pg-core/columns/uuid.js.map +1 -0
- package/dist/data/query/pg-core/columns/varchar.d.ts +53 -0
- package/dist/data/query/pg-core/columns/varchar.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/varchar.js +28 -0
- package/dist/data/query/pg-core/columns/varchar.js.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/bit.d.ts +45 -0
- package/dist/data/query/pg-core/columns/vector_extension/bit.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/bit.js +26 -0
- package/dist/data/query/pg-core/columns/vector_extension/bit.js.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/halfvec.d.ts +49 -0
- package/dist/data/query/pg-core/columns/vector_extension/halfvec.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/halfvec.js +35 -0
- package/dist/data/query/pg-core/columns/vector_extension/halfvec.js.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/sparsevec.d.ts +36 -0
- package/dist/data/query/pg-core/columns/vector_extension/sparsevec.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/sparsevec.js +26 -0
- package/dist/data/query/pg-core/columns/vector_extension/sparsevec.js.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/vector.d.ts +49 -0
- package/dist/data/query/pg-core/columns/vector_extension/vector.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/vector.js +35 -0
- package/dist/data/query/pg-core/columns/vector_extension/vector.js.map +1 -0
- package/dist/data/query/pg-core/db.d.ts +292 -0
- package/dist/data/query/pg-core/db.d.ts.map +1 -0
- package/dist/data/query/pg-core/db.js +377 -0
- package/dist/data/query/pg-core/db.js.map +1 -0
- package/dist/data/query/pg-core/dialect.d.ts +66 -0
- package/dist/data/query/pg-core/dialect.d.ts.map +1 -0
- package/dist/data/query/pg-core/dialect.js +1099 -0
- package/dist/data/query/pg-core/dialect.js.map +1 -0
- package/dist/data/query/pg-core/expressions.d.ts +9 -0
- package/dist/data/query/pg-core/expressions.d.ts.map +1 -0
- package/dist/data/query/pg-core/expressions.js +18 -0
- package/dist/data/query/pg-core/expressions.js.map +1 -0
- package/dist/data/query/pg-core/foreign-keys.d.ts +57 -0
- package/dist/data/query/pg-core/foreign-keys.d.ts.map +1 -0
- package/dist/data/query/pg-core/foreign-keys.js +70 -0
- package/dist/data/query/pg-core/foreign-keys.js.map +1 -0
- package/dist/data/query/pg-core/index.d.ts +22 -0
- package/dist/data/query/pg-core/index.d.ts.map +1 -0
- package/dist/data/query/pg-core/index.js +22 -0
- package/dist/data/query/pg-core/index.js.map +1 -0
- package/dist/data/query/pg-core/indexes.d.ts +84 -0
- package/dist/data/query/pg-core/indexes.d.ts.map +1 -0
- package/dist/data/query/pg-core/indexes.js +100 -0
- package/dist/data/query/pg-core/indexes.js.map +1 -0
- package/dist/data/query/pg-core/policies.d.ts +27 -0
- package/dist/data/query/pg-core/policies.d.ts.map +1 -0
- package/dist/data/query/pg-core/policies.js +30 -0
- package/dist/data/query/pg-core/policies.js.map +1 -0
- package/dist/data/query/pg-core/primary-keys.d.ts +37 -0
- package/dist/data/query/pg-core/primary-keys.d.ts.map +1 -0
- package/dist/data/query/pg-core/primary-keys.js +38 -0
- package/dist/data/query/pg-core/primary-keys.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/count.d.ts +30 -0
- package/dist/data/query/pg-core/query-builders/count.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/count.js +45 -0
- package/dist/data/query/pg-core/query-builders/count.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/delete.d.ts +115 -0
- package/dist/data/query/pg-core/query-builders/delete.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/delete.js +103 -0
- package/dist/data/query/pg-core/query-builders/delete.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/index.d.ts +8 -0
- package/dist/data/query/pg-core/query-builders/index.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/index.js +8 -0
- package/dist/data/query/pg-core/query-builders/index.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/insert.d.ts +189 -0
- package/dist/data/query/pg-core/query-builders/insert.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/insert.js +201 -0
- package/dist/data/query/pg-core/query-builders/insert.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/query-builder.d.ts +38 -0
- package/dist/data/query/pg-core/query-builders/query-builder.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/query-builder.js +83 -0
- package/dist/data/query/pg-core/query-builders/query-builder.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/query.d.ts +56 -0
- package/dist/data/query/pg-core/query-builders/query.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/query.js +104 -0
- package/dist/data/query/pg-core/query-builders/query.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/raw.d.ts +27 -0
- package/dist/data/query/pg-core/query-builders/raw.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/raw.js +34 -0
- package/dist/data/query/pg-core/query-builders/raw.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/refresh-materialized-view.d.ts +38 -0
- package/dist/data/query/pg-core/query-builders/refresh-materialized-view.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/refresh-materialized-view.js +58 -0
- package/dist/data/query/pg-core/query-builders/refresh-materialized-view.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/select.d.ts +811 -0
- package/dist/data/query/pg-core/query-builders/select.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/select.js +993 -0
- package/dist/data/query/pg-core/query-builders/select.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/select.types.d.ts +141 -0
- package/dist/data/query/pg-core/query-builders/select.types.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/select.types.js +2 -0
- package/dist/data/query/pg-core/query-builders/select.types.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/update.d.ts +183 -0
- package/dist/data/query/pg-core/query-builders/update.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/update.js +210 -0
- package/dist/data/query/pg-core/query-builders/update.js.map +1 -0
- package/dist/data/query/pg-core/roles.d.ts +22 -0
- package/dist/data/query/pg-core/roles.d.ts.map +1 -0
- package/dist/data/query/pg-core/roles.js +29 -0
- package/dist/data/query/pg-core/roles.js.map +1 -0
- package/dist/data/query/pg-core/schema.d.ts +23 -0
- package/dist/data/query/pg-core/schema.d.ts.map +1 -0
- package/dist/data/query/pg-core/schema.js +46 -0
- package/dist/data/query/pg-core/schema.js.map +1 -0
- package/dist/data/query/pg-core/sequence.d.ts +21 -0
- package/dist/data/query/pg-core/sequence.d.ts.map +1 -0
- package/dist/data/query/pg-core/sequence.js +23 -0
- package/dist/data/query/pg-core/sequence.js.map +1 -0
- package/dist/data/query/pg-core/session.d.ts +94 -0
- package/dist/data/query/pg-core/session.d.ts.map +1 -0
- package/dist/data/query/pg-core/session.js +169 -0
- package/dist/data/query/pg-core/session.js.map +1 -0
- package/dist/data/query/pg-core/subquery.d.ts +19 -0
- package/dist/data/query/pg-core/subquery.d.ts.map +1 -0
- package/dist/data/query/pg-core/subquery.js +2 -0
- package/dist/data/query/pg-core/subquery.js.map +1 -0
- package/dist/data/query/pg-core/table.d.ts +129 -0
- package/dist/data/query/pg-core/table.d.ts.map +1 -0
- package/dist/data/query/pg-core/table.js +62 -0
- package/dist/data/query/pg-core/table.js.map +1 -0
- package/dist/data/query/pg-core/unique-constraint.d.ts +34 -0
- package/dist/data/query/pg-core/unique-constraint.d.ts.map +1 -0
- package/dist/data/query/pg-core/unique-constraint.js +56 -0
- package/dist/data/query/pg-core/unique-constraint.js.map +1 -0
- package/dist/data/query/pg-core/utils/array.d.ts +4 -0
- package/dist/data/query/pg-core/utils/array.d.ts.map +1 -0
- package/dist/data/query/pg-core/utils/array.js +75 -0
- package/dist/data/query/pg-core/utils/array.js.map +1 -0
- package/dist/data/query/pg-core/utils/index.d.ts +2 -0
- package/dist/data/query/pg-core/utils/index.d.ts.map +1 -0
- package/dist/data/query/pg-core/utils/index.js +2 -0
- package/dist/data/query/pg-core/utils/index.js.map +1 -0
- package/dist/data/query/pg-core/utils.d.ts +56 -0
- package/dist/data/query/pg-core/utils.d.ts.map +1 -0
- package/dist/data/query/pg-core/utils.js +88 -0
- package/dist/data/query/pg-core/utils.js.map +1 -0
- package/dist/data/query/pg-core/view-base.d.ts +9 -0
- package/dist/data/query/pg-core/view-base.d.ts.map +1 -0
- package/dist/data/query/pg-core/view-base.js +6 -0
- package/dist/data/query/pg-core/view-base.js.map +1 -0
- package/dist/data/query/pg-core/view-common.d.ts +2 -0
- package/dist/data/query/pg-core/view-common.d.ts.map +1 -0
- package/dist/data/query/pg-core/view-common.js +2 -0
- package/dist/data/query/pg-core/view-common.js.map +1 -0
- package/dist/data/query/pg-core/view.d.ts +161 -0
- package/dist/data/query/pg-core/view.d.ts.map +1 -0
- package/dist/data/query/pg-core/view.js +243 -0
- package/dist/data/query/pg-core/view.js.map +1 -0
- package/dist/data/query/postgres-js/driver.d.ts +30 -0
- package/dist/data/query/postgres-js/driver.d.ts.map +1 -0
- package/dist/data/query/postgres-js/driver.js +77 -0
- package/dist/data/query/postgres-js/driver.js.map +1 -0
- package/dist/data/query/postgres-js/index.d.ts +3 -0
- package/dist/data/query/postgres-js/index.d.ts.map +1 -0
- package/dist/data/query/postgres-js/index.js +3 -0
- package/dist/data/query/postgres-js/index.js.map +1 -0
- package/dist/data/query/postgres-js/session.d.ts +67 -0
- package/dist/data/query/postgres-js/session.d.ts.map +1 -0
- package/dist/data/query/postgres-js/session.js +139 -0
- package/dist/data/query/postgres-js/session.js.map +1 -0
- package/dist/data/query/primary-key.d.ts +11 -0
- package/dist/data/query/primary-key.d.ts.map +1 -0
- package/dist/data/query/primary-key.js +11 -0
- package/dist/data/query/primary-key.js.map +1 -0
- package/dist/data/query/query-builders/query-builder.d.ts +14 -0
- package/dist/data/query/query-builders/query-builder.d.ts.map +1 -0
- package/dist/data/query/query-builders/query-builder.js +9 -0
- package/dist/data/query/query-builders/query-builder.js.map +1 -0
- package/dist/data/query/query-builders/select.types.d.ts +59 -0
- package/dist/data/query/query-builders/select.types.d.ts.map +1 -0
- package/dist/data/query/query-builders/select.types.js +2 -0
- package/dist/data/query/query-builders/select.types.js.map +1 -0
- package/dist/data/query/query-promise.d.ts +10 -0
- package/dist/data/query/query-promise.d.ts.map +1 -0
- package/dist/data/query/query-promise.js +21 -0
- package/dist/data/query/query-promise.js.map +1 -0
- package/dist/data/query/relations.d.ts +216 -0
- package/dist/data/query/relations.d.ts.map +1 -0
- package/dist/data/query/relations.js +257 -0
- package/dist/data/query/relations.js.map +1 -0
- package/dist/data/query/runnable-query.d.ts +11 -0
- package/dist/data/query/runnable-query.d.ts.map +1 -0
- package/dist/data/query/runnable-query.js +2 -0
- package/dist/data/query/runnable-query.js.map +1 -0
- package/dist/data/query/selection-proxy.d.ts +10 -0
- package/dist/data/query/selection-proxy.d.ts.map +1 -0
- package/dist/data/query/selection-proxy.js +62 -0
- package/dist/data/query/selection-proxy.js.map +1 -0
- package/dist/data/query/session.d.ts +8 -0
- package/dist/data/query/session.d.ts.map +1 -0
- package/dist/data/query/session.js +2 -0
- package/dist/data/query/session.js.map +1 -0
- package/dist/data/query/sql/expressions/conditions.d.ts +454 -0
- package/dist/data/query/sql/expressions/conditions.d.ts.map +1 -0
- package/dist/data/query/sql/expressions/conditions.js +393 -0
- package/dist/data/query/sql/expressions/conditions.js.map +1 -0
- package/dist/data/query/sql/expressions/index.d.ts +3 -0
- package/dist/data/query/sql/expressions/index.d.ts.map +1 -0
- package/dist/data/query/sql/expressions/index.js +3 -0
- package/dist/data/query/sql/expressions/index.js.map +1 -0
- package/dist/data/query/sql/expressions/select.d.ts +39 -0
- package/dist/data/query/sql/expressions/select.d.ts.map +1 -0
- package/dist/data/query/sql/expressions/select.js +42 -0
- package/dist/data/query/sql/expressions/select.js.map +1 -0
- package/dist/data/query/sql/functions/aggregate.d.ts +105 -0
- package/dist/data/query/sql/functions/aggregate.d.ts.map +1 -0
- package/dist/data/query/sql/functions/aggregate.js +122 -0
- package/dist/data/query/sql/functions/aggregate.js.map +1 -0
- package/dist/data/query/sql/functions/index.d.ts +3 -0
- package/dist/data/query/sql/functions/index.d.ts.map +1 -0
- package/dist/data/query/sql/functions/index.js +3 -0
- package/dist/data/query/sql/functions/index.js.map +1 -0
- package/dist/data/query/sql/functions/vector.d.ts +121 -0
- package/dist/data/query/sql/functions/vector.d.ts.map +1 -0
- package/dist/data/query/sql/functions/vector.js +152 -0
- package/dist/data/query/sql/functions/vector.js.map +1 -0
- package/dist/data/query/sql/index.d.ts +4 -0
- package/dist/data/query/sql/index.d.ts.map +1 -0
- package/dist/data/query/sql/index.js +4 -0
- package/dist/data/query/sql/index.js.map +1 -0
- package/dist/data/query/sql/sql.d.ts +254 -0
- package/dist/data/query/sql/sql.d.ts.map +1 -0
- package/dist/data/query/sql/sql.js +478 -0
- package/dist/data/query/sql/sql.js.map +1 -0
- package/dist/data/query/subquery.d.ts +21 -0
- package/dist/data/query/subquery.d.ts.map +1 -0
- package/dist/data/query/subquery.js +18 -0
- package/dist/data/query/subquery.js.map +1 -0
- package/dist/data/query/table.d.ts +142 -0
- package/dist/data/query/table.d.ts.map +1 -0
- package/dist/data/query/table.js +73 -0
- package/dist/data/query/table.js.map +1 -0
- package/dist/data/query/table.utils.d.ts +3 -0
- package/dist/data/query/table.utils.d.ts.map +1 -0
- package/dist/data/query/table.utils.js +3 -0
- package/dist/data/query/table.utils.js.map +1 -0
- package/dist/data/query/tracing-utils.d.ts +2 -0
- package/dist/data/query/tracing-utils.d.ts.map +1 -0
- package/dist/data/query/tracing-utils.js +4 -0
- package/dist/data/query/tracing-utils.js.map +1 -0
- package/dist/data/query/tracing.d.ts +10 -0
- package/dist/data/query/tracing.d.ts.map +1 -0
- package/dist/data/query/tracing.js +7 -0
- package/dist/data/query/tracing.js.map +1 -0
- package/dist/data/query/utils.d.ts +81 -0
- package/dist/data/query/utils.d.ts.map +1 -0
- package/dist/data/query/utils.js +193 -0
- package/dist/data/query/utils.js.map +1 -0
- package/dist/data/query/version.d.ts +3 -0
- package/dist/data/query/version.d.ts.map +1 -0
- package/dist/data/query/version.js +5 -0
- package/dist/data/query/version.js.map +1 -0
- package/dist/data/query/view-common.d.ts +2 -0
- package/dist/data/query/view-common.d.ts.map +1 -0
- package/dist/data/query/view-common.js +2 -0
- package/dist/data/query/view-common.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/index.d.ts +0 -1
- package/dist/db/index.d.ts.map +1 -1
- package/dist/db/index.js +0 -1
- package/dist/db/index.js.map +1 -1
- package/dist/db/namespace.d.ts +0 -5
- package/dist/db/namespace.d.ts.map +1 -1
- package/dist/db/namespace.js +0 -5
- package/dist/db/namespace.js.map +1 -1
- package/dist/domain/define.d.ts.map +1 -1
- package/dist/domain/define.js.map +1 -1
- package/dist/domain/field.d.ts +2 -4
- 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 +9 -37
- package/dist/domain/types.d.ts.map +1 -1
- package/dist/drizzle/index.d.ts +3 -0
- package/dist/drizzle/index.d.ts.map +1 -0
- package/dist/drizzle/index.js +3 -0
- package/dist/drizzle/index.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/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 +2 -9
- package/dist/logging/proxy.js.map +1 -1
- package/dist/logging/types.d.ts +0 -7
- 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/resource/batch.d.ts +17 -0
- package/dist/resource/batch.d.ts.map +1 -0
- package/dist/resource/batch.js +47 -0
- package/dist/resource/batch.js.map +1 -0
- package/dist/resource/builder.d.ts +11 -0
- package/dist/resource/builder.d.ts.map +1 -0
- package/dist/resource/builder.js +12 -0
- package/dist/resource/builder.js.map +1 -0
- package/dist/resource/errors.d.ts +7 -0
- package/dist/resource/errors.d.ts.map +1 -0
- package/dist/resource/errors.js +9 -0
- package/dist/resource/errors.js.map +1 -0
- package/dist/resource/index.d.ts +9 -0
- package/dist/resource/index.d.ts.map +1 -0
- package/dist/resource/index.js +6 -0
- package/dist/resource/index.js.map +1 -0
- package/dist/resource/paginate.d.ts +13 -0
- package/dist/resource/paginate.d.ts.map +1 -0
- package/dist/resource/paginate.js +29 -0
- package/dist/resource/paginate.js.map +1 -0
- package/dist/resource/register.d.ts +16 -0
- package/dist/resource/register.d.ts.map +1 -0
- package/dist/resource/register.js +181 -0
- package/dist/resource/register.js.map +1 -0
- package/dist/resource/types.d.ts +69 -0
- package/dist/resource/types.d.ts.map +1 -0
- package/dist/resource/types.js +2 -0
- package/dist/resource/types.js.map +1 -0
- package/dist/surface/http.d.ts +2 -2
- package/dist/surface/http.d.ts.map +1 -1
- package/dist/surface/http.js +8 -25
- package/dist/surface/http.js.map +1 -1
- package/dist/surface/index.d.ts +1 -1
- package/dist/surface/index.d.ts.map +1 -1
- package/dist/surface/namespace.d.ts +1 -1
- package/dist/surface/namespace.d.ts.map +1 -1
- package/dist/surface/namespace.js +1 -1
- package/dist/surface/namespace.js.map +1 -1
- package/dist/surface/types.d.ts +0 -7
- package/dist/surface/types.d.ts.map +1 -1
- 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 +5 -4
- package/dist/test/plugin.d.ts.map +1 -1
- package/dist/test/plugin.js +12 -4
- 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 +7 -5
- 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 +5 -5
- package/dist/test/vitest.d.ts.map +1 -1
- package/dist/test/vitest.js +7 -4
- package/dist/test/vitest.js.map +1 -1
- package/dist/trunk.d.ts +35 -0
- package/dist/trunk.d.ts.map +1 -0
- package/dist/trunk.js +102 -0
- package/dist/trunk.js.map +1 -0
- package/dist/validation/surface.d.ts +4 -0
- package/dist/validation/surface.d.ts.map +1 -0
- package/dist/validation/surface.js +55 -0
- package/dist/validation/surface.js.map +1 -0
- package/dist/vector/index.d.ts +1 -2
- package/dist/vector/index.d.ts.map +1 -1
- package/dist/vector/index.js +1 -1
- package/dist/vector/index.js.map +1 -1
- package/dist/vector/namespace.d.ts +4 -10
- package/dist/vector/namespace.d.ts.map +1 -1
- package/dist/vector/namespace.js +4 -10
- package/dist/vector/namespace.js.map +1 -1
- package/dist/vector/query.d.ts +2 -15
- package/dist/vector/query.d.ts.map +1 -1
- package/dist/vector/query.js +1 -39
- package/dist/vector/query.js.map +1 -1
- package/dist/webhook/verify.d.ts +3 -5
- package/dist/webhook/verify.d.ts.map +1 -1
- package/dist/webhook/verify.js +2 -5
- package/dist/webhook/verify.js.map +1 -1
- package/dist/workspace/affected.d.ts +17 -0
- package/dist/workspace/affected.d.ts.map +1 -0
- package/dist/workspace/affected.js +29 -0
- package/dist/workspace/affected.js.map +1 -0
- package/dist/workspace/changed-files.d.ts +7 -0
- package/dist/workspace/changed-files.d.ts.map +1 -0
- package/dist/workspace/changed-files.js +38 -0
- package/dist/workspace/changed-files.js.map +1 -0
- package/dist/workspace/dependency-graph.d.ts +8 -0
- package/dist/workspace/dependency-graph.d.ts.map +1 -0
- package/dist/workspace/dependency-graph.js +54 -0
- package/dist/workspace/dependency-graph.js.map +1 -0
- package/dist/workspace/discover.d.ts +1 -1
- package/dist/workspace/discover.d.ts.map +1 -1
- package/dist/workspace/index.d.ts +3 -0
- package/dist/workspace/index.d.ts.map +1 -1
- package/dist/workspace/index.js +3 -0
- package/dist/workspace/index.js.map +1 -1
- package/dist/workspace/sync.d.ts +1 -1
- package/dist/workspace/sync.d.ts.map +1 -1
- package/package.json +53 -44
- package/dist/config/ts-register.d.ts.map +0 -1
- package/dist/config/ts-register.js.map +0 -1
- package/dist/config/ts-resolve-hooks.d.ts.map +0 -1
- package/dist/config/ts-resolve-hooks.js.map +0 -1
- package/dist/db/excluded.d.ts.map +0 -1
- package/dist/db/excluded.js.map +0 -1
- package/dist/jsonb/index.d.ts.map +0 -1
- package/dist/jsonb/index.js.map +0 -1
- package/dist/jsonb/namespace.d.ts.map +0 -1
- package/dist/jsonb/namespace.js.map +0 -1
- package/dist/jsonb/query.d.ts.map +0 -1
- package/dist/jsonb/query.js.map +0 -1
- package/dist/validation/doctrine.d.ts.map +0 -1
- package/dist/validation/doctrine.js.map +0 -1
- /package/dist/{config → core/config}/ts-register.d.ts +0 -0
- /package/dist/{config → core/config}/ts-register.js +0 -0
- /package/dist/{config → core/config}/ts-resolve-hooks.d.ts +0 -0
- /package/dist/{validation → core/validation}/doctrine.d.ts +0 -0
- /package/dist/{validation → core/validation}/doctrine.js +0 -0
- /package/dist/{db → data/db}/excluded.d.ts +0 -0
- /package/dist/{jsonb → data/jsonb}/index.d.ts +0 -0
- /package/dist/{jsonb → data/jsonb}/index.js +0 -0
- /package/dist/{jsonb → data/jsonb}/namespace.d.ts +0 -0
- /package/dist/{jsonb → data/jsonb}/namespace.js +0 -0
- /package/dist/{jsonb → data/jsonb}/query.d.ts +0 -0
- /package/dist/{jsonb → data/jsonb}/query.js +0 -0
|
@@ -0,0 +1,231 @@
|
|
|
1
|
+
import { SignJWT, jwtVerify, importPKCS8, importSPKI } from 'jose';
|
|
2
|
+
import { sql } from '../../data/db/sql.js';
|
|
3
|
+
import { UnauthorizedError } from '../../core/errors/index.js';
|
|
4
|
+
import { resolveCookieConfig, buildSetCookieHeader, buildClearCookieHeader, parseCookieHeader } from './cookie.js';
|
|
5
|
+
/** Creates a Sessions manager with JWT access/refresh tokens, rotation, reuse detection, and cookie helpers. */
|
|
6
|
+
export function createSessions(config) {
|
|
7
|
+
const environment = config.environment ?? 'production';
|
|
8
|
+
if (environment === 'production') {
|
|
9
|
+
validateSigningKeys(config);
|
|
10
|
+
}
|
|
11
|
+
let privateKey = null;
|
|
12
|
+
let publicKey = null;
|
|
13
|
+
const versionCache = new Map();
|
|
14
|
+
const cacheTtl = config.versionCacheTtlMs ?? 60_000;
|
|
15
|
+
async function getPrivateKey() {
|
|
16
|
+
if (!privateKey)
|
|
17
|
+
privateKey = await importPKCS8(config.signing.privateKey, config.signing.algorithm);
|
|
18
|
+
return privateKey;
|
|
19
|
+
}
|
|
20
|
+
async function getPublicKey() {
|
|
21
|
+
if (!publicKey)
|
|
22
|
+
publicKey = await importSPKI(config.signing.publicKey, config.signing.algorithm);
|
|
23
|
+
return publicKey;
|
|
24
|
+
}
|
|
25
|
+
function parseExpiry(exp) {
|
|
26
|
+
const match = exp.match(/^(\d+)([smhd])$/);
|
|
27
|
+
if (!match)
|
|
28
|
+
throw new Error(`Invalid expiry format: ${exp}`);
|
|
29
|
+
const value = parseInt(match[1], 10);
|
|
30
|
+
const unit = match[2];
|
|
31
|
+
switch (unit) {
|
|
32
|
+
case 's': return value;
|
|
33
|
+
case 'm': return value * 60;
|
|
34
|
+
case 'h': return value * 3600;
|
|
35
|
+
case 'd': return value * 86400;
|
|
36
|
+
default: return value;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
async function getOrCreateVersion(db, userId) {
|
|
40
|
+
const rows = await db.execute(sql `INSERT INTO pipework_auth_versions (user_id, version) VALUES (${userId}, 1)
|
|
41
|
+
ON CONFLICT (user_id) DO NOTHING
|
|
42
|
+
RETURNING version`);
|
|
43
|
+
if (rows.length > 0)
|
|
44
|
+
return rows[0]['version'];
|
|
45
|
+
const existing = await db.execute(sql `SELECT version FROM pipework_auth_versions WHERE user_id = ${userId}`);
|
|
46
|
+
const row = existing[0];
|
|
47
|
+
if (row === undefined)
|
|
48
|
+
return 1;
|
|
49
|
+
return row['version'];
|
|
50
|
+
}
|
|
51
|
+
async function issueTokens(db, user) {
|
|
52
|
+
const key = await getPrivateKey();
|
|
53
|
+
const version = config.versionCheck ? await getOrCreateVersion(db, user.id) : 1;
|
|
54
|
+
const expiresInSeconds = parseExpiry(config.accessToken.expiresIn);
|
|
55
|
+
const accessToken = await new SignJWT({ tid: user.tenantId, av: version, roles: user.roles })
|
|
56
|
+
.setProtectedHeader({ alg: config.signing.algorithm })
|
|
57
|
+
.setSubject(user.id)
|
|
58
|
+
.setIssuer(config.issuer)
|
|
59
|
+
.setAudience(config.audience)
|
|
60
|
+
.setIssuedAt()
|
|
61
|
+
.setExpirationTime(`${expiresInSeconds}s`)
|
|
62
|
+
.sign(key);
|
|
63
|
+
const familyId = crypto.randomUUID();
|
|
64
|
+
const refreshTokenValue = crypto.randomUUID();
|
|
65
|
+
const refreshHash = await hashToken(refreshTokenValue);
|
|
66
|
+
const refreshExpiresIn = parseExpiry(config.refreshToken.expiresIn);
|
|
67
|
+
const expiresAt = new Date(Date.now() + refreshExpiresIn * 1000);
|
|
68
|
+
await db.execute(sql `INSERT INTO pipework_refresh_tokens (user_id, tenant_id, token_hash, family_id, expires_at)
|
|
69
|
+
VALUES (${user.id}, ${user.tenantId}, ${refreshHash}, ${familyId}::uuid, ${expiresAt.toISOString()}::timestamptz)`);
|
|
70
|
+
return { accessToken, refreshToken: refreshTokenValue, expiresIn: expiresInSeconds };
|
|
71
|
+
}
|
|
72
|
+
async function refresh(db, refreshToken) {
|
|
73
|
+
const tokenHash = await hashToken(refreshToken);
|
|
74
|
+
return db.transaction(async (tx) => {
|
|
75
|
+
const rows = await tx.execute(sql `SELECT id, user_id, tenant_id, family_id, revoked_at, expires_at
|
|
76
|
+
FROM pipework_refresh_tokens
|
|
77
|
+
WHERE token_hash = ${tokenHash}
|
|
78
|
+
FOR UPDATE`);
|
|
79
|
+
if (rows.length === 0) {
|
|
80
|
+
throw new UnauthorizedError('Invalid refresh token');
|
|
81
|
+
}
|
|
82
|
+
const row = rows[0];
|
|
83
|
+
const userId = row['user_id'];
|
|
84
|
+
const tenantId = row['tenant_id'];
|
|
85
|
+
const familyId = row['family_id'];
|
|
86
|
+
const revokedAt = row['revoked_at'];
|
|
87
|
+
const expiresAt = new Date(row['expires_at']);
|
|
88
|
+
if (expiresAt < new Date()) {
|
|
89
|
+
throw new UnauthorizedError('Refresh token expired');
|
|
90
|
+
}
|
|
91
|
+
if (revokedAt !== null) {
|
|
92
|
+
if (config.refreshToken.reuseDetection) {
|
|
93
|
+
await tx.execute(sql `UPDATE pipework_refresh_tokens SET revoked_at = now()
|
|
94
|
+
WHERE family_id = ${familyId}::uuid AND revoked_at IS NULL`);
|
|
95
|
+
}
|
|
96
|
+
throw new UnauthorizedError('Refresh token reuse detected — all sessions revoked');
|
|
97
|
+
}
|
|
98
|
+
if (config.refreshToken.rotateOnUse) {
|
|
99
|
+
await tx.execute(sql `UPDATE pipework_refresh_tokens SET revoked_at = now() WHERE token_hash = ${tokenHash}`);
|
|
100
|
+
}
|
|
101
|
+
const roles = config.resolveRoles
|
|
102
|
+
? await config.resolveRoles(tx, userId, tenantId)
|
|
103
|
+
: undefined;
|
|
104
|
+
return issueTokens(tx, roles ? { id: userId, tenantId, roles } : { id: userId, tenantId });
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
async function revokeAll(db, userId) {
|
|
108
|
+
await db.execute(sql `UPDATE pipework_refresh_tokens SET revoked_at = now()
|
|
109
|
+
WHERE user_id = ${userId} AND revoked_at IS NULL`);
|
|
110
|
+
}
|
|
111
|
+
async function bumpVersion(db, userId) {
|
|
112
|
+
await db.execute(sql `INSERT INTO pipework_auth_versions (user_id, version, updated_at)
|
|
113
|
+
VALUES (${userId}, 2, now())
|
|
114
|
+
ON CONFLICT (user_id)
|
|
115
|
+
DO UPDATE SET version = pipework_auth_versions.version + 1, updated_at = now()`);
|
|
116
|
+
versionCache.delete(userId);
|
|
117
|
+
}
|
|
118
|
+
async function verifyAccessToken(token) {
|
|
119
|
+
const key = await getPublicKey();
|
|
120
|
+
try {
|
|
121
|
+
const { payload } = await jwtVerify(token, key, {
|
|
122
|
+
algorithms: [config.signing.algorithm],
|
|
123
|
+
issuer: config.issuer,
|
|
124
|
+
audience: config.audience,
|
|
125
|
+
});
|
|
126
|
+
return {
|
|
127
|
+
sub: payload.sub,
|
|
128
|
+
tid: payload['tid'],
|
|
129
|
+
av: payload['av'],
|
|
130
|
+
roles: payload['roles'],
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
catch {
|
|
134
|
+
throw new UnauthorizedError('Invalid access token');
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
async function checkVersion(db, userId, tokenVersion) {
|
|
138
|
+
const cached = versionCache.get(userId);
|
|
139
|
+
if (cached && cached.expiresAt > Date.now()) {
|
|
140
|
+
return cached.version === tokenVersion;
|
|
141
|
+
}
|
|
142
|
+
const rows = await db.execute(sql `SELECT version FROM pipework_auth_versions WHERE user_id = ${userId}`);
|
|
143
|
+
const currentVersion = rows.length > 0 ? rows[0]['version'] : 1;
|
|
144
|
+
versionCache.set(userId, { version: currentVersion, expiresAt: Date.now() + cacheTtl });
|
|
145
|
+
return currentVersion === tokenVersion;
|
|
146
|
+
}
|
|
147
|
+
async function cleanExpiredTokens(db) {
|
|
148
|
+
const rows = await db.execute(sql `DELETE FROM pipework_refresh_tokens WHERE expires_at < now() RETURNING id`);
|
|
149
|
+
return rows.length;
|
|
150
|
+
}
|
|
151
|
+
function getCookieConfig() {
|
|
152
|
+
const cookie = config.refreshToken.cookie;
|
|
153
|
+
if (cookie === undefined) {
|
|
154
|
+
throw new Error('Cookie-based session methods require refreshToken.cookie configuration');
|
|
155
|
+
}
|
|
156
|
+
return resolveCookieConfig(cookie, config.environment ?? 'production');
|
|
157
|
+
}
|
|
158
|
+
function getRefreshMaxAge() {
|
|
159
|
+
return parseExpiry(config.refreshToken.expiresIn);
|
|
160
|
+
}
|
|
161
|
+
async function issueTokensHttp(response, db, user) {
|
|
162
|
+
const resolved = getCookieConfig();
|
|
163
|
+
const pair = await issueTokens(db, user);
|
|
164
|
+
response.header('Set-Cookie', buildSetCookieHeader(resolved, pair.refreshToken, getRefreshMaxAge()));
|
|
165
|
+
return { accessToken: pair.accessToken, expiresIn: pair.expiresIn };
|
|
166
|
+
}
|
|
167
|
+
async function refreshHttp(response, db, request) {
|
|
168
|
+
const resolved = getCookieConfig();
|
|
169
|
+
const token = parseCookieHeader(request.headers['cookie'], resolved.name);
|
|
170
|
+
if (token === undefined) {
|
|
171
|
+
throw new UnauthorizedError('Missing refresh token cookie');
|
|
172
|
+
}
|
|
173
|
+
const pair = await refresh(db, token);
|
|
174
|
+
response.header('Set-Cookie', buildSetCookieHeader(resolved, pair.refreshToken, getRefreshMaxAge()));
|
|
175
|
+
return { accessToken: pair.accessToken, expiresIn: pair.expiresIn };
|
|
176
|
+
}
|
|
177
|
+
async function revokeHttp(response, db, request) {
|
|
178
|
+
const resolved = getCookieConfig();
|
|
179
|
+
const token = parseCookieHeader(request.headers['cookie'], resolved.name);
|
|
180
|
+
if (token === undefined) {
|
|
181
|
+
throw new UnauthorizedError('Missing refresh token cookie');
|
|
182
|
+
}
|
|
183
|
+
const tokenHash = await hashToken(token);
|
|
184
|
+
await db.execute(sql `UPDATE pipework_refresh_tokens SET revoked_at = now()
|
|
185
|
+
WHERE token_hash = ${tokenHash} AND revoked_at IS NULL`);
|
|
186
|
+
response.header('Set-Cookie', buildClearCookieHeader(resolved));
|
|
187
|
+
}
|
|
188
|
+
async function revokeAllHttp(response, db, userId) {
|
|
189
|
+
const resolved = getCookieConfig();
|
|
190
|
+
await revokeAll(db, userId);
|
|
191
|
+
response.header('Set-Cookie', buildClearCookieHeader(resolved));
|
|
192
|
+
}
|
|
193
|
+
return {
|
|
194
|
+
issueTokens, refresh, revokeAll, bumpVersion, verifyAccessToken, checkVersion, cleanExpiredTokens,
|
|
195
|
+
issueTokensHttp, refreshHttp, revokeHttp, revokeAllHttp,
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
const TEST_KEY_PATTERNS = [
|
|
199
|
+
'test', 'example', 'dummy', 'placeholder', 'changeme', 'insecure', 'dev-only',
|
|
200
|
+
];
|
|
201
|
+
function validateSigningKeys(config) {
|
|
202
|
+
const problems = [];
|
|
203
|
+
const { privateKey, publicKey } = config.signing;
|
|
204
|
+
if (privateKey.length < 100) {
|
|
205
|
+
problems.push('Private key appears too short for ES256. Ensure you are using a real PKCS#8 key.');
|
|
206
|
+
}
|
|
207
|
+
if (publicKey.length < 80) {
|
|
208
|
+
problems.push('Public key appears too short for ES256. Ensure you are using a real SPKI key.');
|
|
209
|
+
}
|
|
210
|
+
const combined = (privateKey + publicKey).toLowerCase();
|
|
211
|
+
for (const pattern of TEST_KEY_PATTERNS) {
|
|
212
|
+
if (combined.includes(pattern)) {
|
|
213
|
+
problems.push(`Signing key material contains "${pattern}" — this looks like a test key.`);
|
|
214
|
+
break;
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
if (!privateKey.includes('BEGIN') || !publicKey.includes('BEGIN')) {
|
|
218
|
+
problems.push('Keys should be PEM-encoded (BEGIN PRIVATE KEY / BEGIN PUBLIC KEY).');
|
|
219
|
+
}
|
|
220
|
+
if (problems.length > 0) {
|
|
221
|
+
throw new Error(`[pipework] Session signing keys are not suitable for production:\n\n${problems.map(p => ` - ${p}`).join('\n')}\n\n` +
|
|
222
|
+
' Generate production keys with: openssl ecparam -genkey -name prime256v1 -noout | openssl pkcs8 -topk8 -nocrypt\n');
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
async function hashToken(token) {
|
|
226
|
+
const encoder = new TextEncoder();
|
|
227
|
+
const data = encoder.encode(token);
|
|
228
|
+
const hash = await crypto.subtle.digest('SHA-256', data);
|
|
229
|
+
return Buffer.from(hash).toString('hex');
|
|
230
|
+
}
|
|
231
|
+
//# sourceMappingURL=sessions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.js","sourceRoot":"","sources":["../../../src/auth/auth/sessions.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { DB } from '../../data/db/types.js';
|
|
2
|
+
/** Runtime auth context passed to strategies — carries the resolved DB and request metadata. */
|
|
3
|
+
export interface AuthContext {
|
|
4
|
+
readonly db: (name?: string) => DB;
|
|
5
|
+
}
|
|
6
|
+
/** Pluggable auth strategy — implement authenticate() to extract auth from a request. */
|
|
7
|
+
export interface AuthStrategy<TAuth> {
|
|
8
|
+
readonly name: string;
|
|
9
|
+
extract(request: AuthRequest, context: AuthContext): Promise<TAuth | null>;
|
|
10
|
+
verify(extracted: TAuth, context: AuthContext): Promise<TAuth>;
|
|
11
|
+
}
|
|
12
|
+
/** Normalized request shape passed to auth strategies — headers, cookies, method, url. */
|
|
13
|
+
export interface AuthRequest {
|
|
14
|
+
readonly headers: Readonly<Record<string, string | undefined>>;
|
|
15
|
+
readonly cookies: Readonly<Record<string, string | undefined>>;
|
|
16
|
+
}
|
|
17
|
+
/** Minimum auth shape — userId and tenantId. Extend for app-specific auth fields. */
|
|
18
|
+
export interface BaseAuth {
|
|
19
|
+
readonly userId: string;
|
|
20
|
+
readonly tenantId: string;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/auth/auth/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAEhD,gGAAgG;AAChG,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,MAAM,KAAK,EAAE,CAAA;CACnC;AAED,yFAAyF;AACzF,MAAM,WAAW,YAAY,CAAC,KAAK;IACjC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,OAAO,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,CAAA;IAC1E,MAAM,CAAC,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,CAAC,CAAA;CAC/D;AAED,0FAA0F;AAC1F,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAA;IAC9D,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAA;CAC/D;AAED,qFAAqF;AACrF,MAAM,WAAW,QAAQ;IACvB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;IACvB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;CAC1B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/auth/auth/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { PermissionSet } from './types.js';
|
|
2
|
+
export declare class PermissionCache {
|
|
3
|
+
private readonly store;
|
|
4
|
+
private readonly ttlMs;
|
|
5
|
+
constructor(ttlMs: number);
|
|
6
|
+
get(userId: string, tenantId: string, authVersion: number): PermissionSet | null;
|
|
7
|
+
set(permissionSet: PermissionSet): void;
|
|
8
|
+
invalidate(userId: string, tenantId: string): void;
|
|
9
|
+
clear(): void;
|
|
10
|
+
get size(): number;
|
|
11
|
+
private key;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=cache.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.d.ts","sourceRoot":"","sources":["../../../src/auth/rbac/cache.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAO/C,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAgC;IACtD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAQ;gBAElB,KAAK,EAAE,MAAM;IAIzB,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,aAAa,GAAG,IAAI;IAWhF,GAAG,CAAC,aAAa,EAAE,aAAa,GAAG,IAAI;IAQvC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI;IASlD,KAAK,IAAI,IAAI;IAIb,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,OAAO,CAAC,GAAG;CAGZ"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export class PermissionCache {
|
|
2
|
+
store = new Map();
|
|
3
|
+
ttlMs;
|
|
4
|
+
constructor(ttlMs) {
|
|
5
|
+
this.ttlMs = ttlMs;
|
|
6
|
+
}
|
|
7
|
+
get(userId, tenantId, authVersion) {
|
|
8
|
+
const key = this.key(userId, tenantId, authVersion);
|
|
9
|
+
const entry = this.store.get(key);
|
|
10
|
+
if (!entry)
|
|
11
|
+
return null;
|
|
12
|
+
if (Date.now() > entry.expiresAt) {
|
|
13
|
+
this.store.delete(key);
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
return entry.set;
|
|
17
|
+
}
|
|
18
|
+
set(permissionSet) {
|
|
19
|
+
const key = this.key(permissionSet.userId, permissionSet.tenantId, permissionSet.authVersion);
|
|
20
|
+
this.store.set(key, {
|
|
21
|
+
set: permissionSet,
|
|
22
|
+
expiresAt: Date.now() + this.ttlMs,
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
invalidate(userId, tenantId) {
|
|
26
|
+
const prefix = `${userId}:${tenantId}:`;
|
|
27
|
+
for (const key of this.store.keys()) {
|
|
28
|
+
if (key.startsWith(prefix)) {
|
|
29
|
+
this.store.delete(key);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
clear() {
|
|
34
|
+
this.store.clear();
|
|
35
|
+
}
|
|
36
|
+
get size() {
|
|
37
|
+
return this.store.size;
|
|
38
|
+
}
|
|
39
|
+
key(userId, tenantId, authVersion) {
|
|
40
|
+
return `${userId}:${tenantId}:${authVersion}`;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=cache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../../src/auth/rbac/cache.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,eAAe;IACT,KAAK,GAAG,IAAI,GAAG,EAAsB,CAAA;IACrC,KAAK,CAAQ;IAE9B,YAAY,KAAa;QACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;IAED,GAAG,CAAC,MAAc,EAAE,QAAgB,EAAE,WAAmB;QACvD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAA;QACnD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QACjC,IAAI,CAAC,KAAK;YAAE,OAAO,IAAI,CAAA;QACvB,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;YACjC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;YACtB,OAAO,IAAI,CAAA;QACb,CAAC;QACD,OAAO,KAAK,CAAC,GAAG,CAAA;IAClB,CAAC;IAED,GAAG,CAAC,aAA4B;QAC9B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,MAAM,EAAE,aAAa,CAAC,QAAQ,EAAE,aAAa,CAAC,WAAW,CAAC,CAAA;QAC7F,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,GAAG,EAAE,aAAa;YAClB,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,KAAK;SACnC,CAAC,CAAA;IACJ,CAAC;IAED,UAAU,CAAC,MAAc,EAAE,QAAgB;QACzC,MAAM,MAAM,GAAG,GAAG,MAAM,IAAI,QAAQ,GAAG,CAAA;QACvC,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;YACpC,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC3B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;YACxB,CAAC;QACH,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;IACpB,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAA;IACxB,CAAC;IAEO,GAAG,CAAC,MAAc,EAAE,QAAgB,EAAE,WAAmB;QAC/D,OAAO,GAAG,MAAM,IAAI,QAAQ,IAAI,WAAW,EAAE,CAAA;IAC/C,CAAC;CACF"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ResolvedPermission } from './types.js';
|
|
2
|
+
export declare function scopeSatisfies(granted: string, required: string, hierarchy?: readonly string[]): boolean;
|
|
3
|
+
export declare function hasPermission(permissions: readonly ResolvedPermission[], resource: string, action: string, requiredScope?: string, hierarchy?: readonly string[]): boolean;
|
|
4
|
+
//# sourceMappingURL=check.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check.d.ts","sourceRoot":"","sources":["../../../src/auth/rbac/check.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAA;AAIpD,wBAAgB,cAAc,CAC5B,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,MAAM,EAChB,SAAS,GAAE,SAAS,MAAM,EAAsB,GAC/C,OAAO,CAKT;AAED,wBAAgB,aAAa,CAC3B,WAAW,EAAE,SAAS,kBAAkB,EAAE,EAC1C,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,MAAM,EACtB,SAAS,GAAE,SAAS,MAAM,EAAsB,GAC/C,OAAO,CAQT"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
const DEFAULT_HIERARCHY = ['own', 'team', 'territory', 'tenant'];
|
|
2
|
+
export function scopeSatisfies(granted, required, hierarchy = DEFAULT_HIERARCHY) {
|
|
3
|
+
const grantedIdx = hierarchy.indexOf(granted);
|
|
4
|
+
const requiredIdx = hierarchy.indexOf(required);
|
|
5
|
+
if (grantedIdx === -1 || requiredIdx === -1)
|
|
6
|
+
return false;
|
|
7
|
+
return grantedIdx >= requiredIdx;
|
|
8
|
+
}
|
|
9
|
+
export function hasPermission(permissions, resource, action, requiredScope, hierarchy = DEFAULT_HIERARCHY) {
|
|
10
|
+
for (const perm of permissions) {
|
|
11
|
+
if (perm.resource === resource && perm.action === action) {
|
|
12
|
+
if (requiredScope === undefined)
|
|
13
|
+
return true;
|
|
14
|
+
if (scopeSatisfies(perm.scope, requiredScope, hierarchy))
|
|
15
|
+
return true;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check.js","sourceRoot":"","sources":["../../../src/auth/rbac/check.ts"],"names":[],"mappings":"AAEA,MAAM,iBAAiB,GAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAA;AAEnF,MAAM,UAAU,cAAc,CAC5B,OAAe,EACf,QAAgB,EAChB,YAA+B,iBAAiB;IAEhD,MAAM,UAAU,GAAG,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;IAC7C,MAAM,WAAW,GAAG,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IAC/C,IAAI,UAAU,KAAK,CAAC,CAAC,IAAI,WAAW,KAAK,CAAC,CAAC;QAAE,OAAO,KAAK,CAAA;IACzD,OAAO,UAAU,IAAI,WAAW,CAAA;AAClC,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,WAA0C,EAC1C,QAAgB,EAChB,MAAc,EACd,aAAsB,EACtB,YAA+B,iBAAiB;IAEhD,KAAK,MAAM,IAAI,IAAI,WAAW,EAAE,CAAC;QAC/B,IAAI,IAAI,CAAC,QAAQ,KAAK,QAAQ,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YACzD,IAAI,aAAa,KAAK,SAAS;gBAAE,OAAO,IAAI,CAAA;YAC5C,IAAI,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,aAAa,EAAE,SAAS,CAAC;gBAAE,OAAO,IAAI,CAAA;QACvE,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { RbacConfig, Rbac } from './types.js';
|
|
2
|
+
export type { RbacConfig, Rbac, PermissionSet, ResolvedPermission, Scope, SeedData, SeedPermission, SeedRole, SeedRolePermission, SeedUserRole } from './types.js';
|
|
3
|
+
export { hasPermission, scopeSatisfies } from './check.js';
|
|
4
|
+
export { PermissionCache } from './cache.js';
|
|
5
|
+
export { enforcePermission } from './middleware.js';
|
|
6
|
+
/** Creates an Rbac instance from role/permission config — provides check, enforce, and seed operations. */
|
|
7
|
+
export declare function createRbac(config: RbacConfig): Rbac;
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/auth/rbac/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,IAAI,EAA2B,MAAM,YAAY,CAAA;AAM3E,YAAY,EAAE,UAAU,EAAE,IAAI,EAAE,aAAa,EAAE,kBAAkB,EAAE,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,QAAQ,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAClK,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAA;AAEnD,2GAA2G;AAC3G,wBAAgB,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,IAAI,CA0BnD"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { PermissionCache } from './cache.js';
|
|
2
|
+
import { resolveUserPermissions } from './resolve.js';
|
|
3
|
+
import { hasPermission } from './check.js';
|
|
4
|
+
import { seedRbac } from './seed.js';
|
|
5
|
+
export { hasPermission, scopeSatisfies } from './check.js';
|
|
6
|
+
export { PermissionCache } from './cache.js';
|
|
7
|
+
export { enforcePermission } from './middleware.js';
|
|
8
|
+
/** Creates an Rbac instance from role/permission config — provides check, enforce, and seed operations. */
|
|
9
|
+
export function createRbac(config) {
|
|
10
|
+
const cache = new PermissionCache(config.cacheTtlMs ?? 60_000);
|
|
11
|
+
const scopes = config.scopes ?? ['own', 'team', 'territory', 'tenant'];
|
|
12
|
+
return {
|
|
13
|
+
async resolve(db, userId, tenantId, authVersion) {
|
|
14
|
+
const cached = cache.get(userId, tenantId, authVersion);
|
|
15
|
+
if (cached)
|
|
16
|
+
return cached;
|
|
17
|
+
const resolved = await resolveUserPermissions(db, userId, tenantId, authVersion, config);
|
|
18
|
+
cache.set(resolved);
|
|
19
|
+
return resolved;
|
|
20
|
+
},
|
|
21
|
+
check(permissions, resource, action, requiredScope) {
|
|
22
|
+
return hasPermission(permissions.permissions, resource, action, requiredScope, scopes);
|
|
23
|
+
},
|
|
24
|
+
invalidate(userId, tenantId) {
|
|
25
|
+
cache.invalidate(userId, tenantId);
|
|
26
|
+
},
|
|
27
|
+
async seed(db, data) {
|
|
28
|
+
await seedRbac(db, data, config);
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/auth/rbac/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAC5C,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAA;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAA;AAGpC,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAA;AAEnD,2GAA2G;AAC3G,MAAM,UAAU,UAAU,CAAC,MAAkB;IAC3C,MAAM,KAAK,GAAG,IAAI,eAAe,CAAC,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,CAAA;IAC9D,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAA;IAEtE,OAAO;QACL,KAAK,CAAC,OAAO,CAAC,EAAM,EAAE,MAAc,EAAE,QAAgB,EAAE,WAAmB;YACzE,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAA;YACvD,IAAI,MAAM;gBAAE,OAAO,MAAM,CAAA;YAEzB,MAAM,QAAQ,GAAG,MAAM,sBAAsB,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,CAAC,CAAA;YACxF,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;YACnB,OAAO,QAAQ,CAAA;QACjB,CAAC;QAED,KAAK,CAAC,WAA0B,EAAE,QAAgB,EAAE,MAAc,EAAE,aAAsB;YACxF,OAAO,aAAa,CAAC,WAAW,CAAC,WAAW,EAAE,QAAQ,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,CAAC,CAAA;QACxF,CAAC;QAED,UAAU,CAAC,MAAc,EAAE,QAAgB;YACzC,KAAK,CAAC,UAAU,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAA;QACpC,CAAC;QAED,KAAK,CAAC,IAAI,CAAC,EAAM,EAAE,IAAc;YAC/B,MAAM,QAAQ,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,CAAC,CAAA;QAClC,CAAC;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { DB } from '../../data/db/index.js';
|
|
2
|
+
import type { Rbac } from './types.js';
|
|
3
|
+
export declare function enforcePermission(rbac: Rbac, db: DB, userId: string, tenantId: string, authVersion: number, resource: string, action: string, requiredScope?: string): Promise<void>;
|
|
4
|
+
//# sourceMappingURL=middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.d.ts","sourceRoot":"","sources":["../../../src/auth/rbac/middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,YAAY,CAAA;AAGtC,wBAAsB,iBAAiB,CACrC,IAAI,EAAE,IAAI,EACV,EAAE,EAAE,EAAE,EACN,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,EACd,aAAa,CAAC,EAAE,MAAM,GACrB,OAAO,CAAC,IAAI,CAAC,CAMf"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ForbiddenError } from '../../core/errors/index.js';
|
|
2
|
+
export async function enforcePermission(rbac, db, userId, tenantId, authVersion, resource, action, requiredScope) {
|
|
3
|
+
const permissions = await rbac.resolve(db, userId, tenantId, authVersion);
|
|
4
|
+
const granted = rbac.check(permissions, resource, action, requiredScope);
|
|
5
|
+
if (!granted) {
|
|
6
|
+
throw new ForbiddenError(`Missing permission: ${resource}:${action}`);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/auth/rbac/middleware.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAA;AAE3D,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,IAAU,EACV,EAAM,EACN,MAAc,EACd,QAAgB,EAChB,WAAmB,EACnB,QAAgB,EAChB,MAAc,EACd,aAAsB;IAEtB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAA;IACzE,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,QAAQ,EAAE,MAAM,EAAE,aAAa,CAAC,CAAA;IACxE,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,cAAc,CAAC,uBAAuB,QAAQ,IAAI,MAAM,EAAE,CAAC,CAAA;IACvE,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { createRbac, hasPermission, enforcePermission, scopeSatisfies, PermissionCache } from './index.js';
|
|
2
|
+
/** Role-based access control namespace — permission checking, enforcement, scope hierarchy. */
|
|
3
|
+
export declare const rbac: {
|
|
4
|
+
/** Creates an Rbac instance from config (roles, permissions, hierarchy). */
|
|
5
|
+
create: typeof createRbac;
|
|
6
|
+
/** Checks if a permission set includes the required resource/action/scope. Pure function, no DB. */
|
|
7
|
+
check: typeof hasPermission;
|
|
8
|
+
/** Checks permission and throws ForbiddenError if denied. Loads permissions from DB with caching. */
|
|
9
|
+
enforce: typeof enforcePermission;
|
|
10
|
+
/** Checks if a granted scope satisfies a required scope given a hierarchy (e.g. org > team > self). */
|
|
11
|
+
satisfies: typeof scopeSatisfies;
|
|
12
|
+
/** LRU cache for resolved permissions — avoids repeated DB lookups within a request. */
|
|
13
|
+
PermissionCache: typeof PermissionCache;
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/auth/rbac/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,iBAAiB,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE1G,+FAA+F;AAC/F,eAAO,MAAM,IAAI;IACf,4EAA4E;;IAE5E,oGAAoG;;IAEpG,qGAAqG;;IAErG,uGAAuG;;IAEvG,wFAAwF;;CAEzF,CAAA"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { createRbac, hasPermission, enforcePermission, scopeSatisfies, PermissionCache } from './index.js';
|
|
2
|
+
/** Role-based access control namespace — permission checking, enforcement, scope hierarchy. */
|
|
3
|
+
export const rbac = {
|
|
4
|
+
/** Creates an Rbac instance from config (roles, permissions, hierarchy). */
|
|
5
|
+
create: createRbac,
|
|
6
|
+
/** Checks if a permission set includes the required resource/action/scope. Pure function, no DB. */
|
|
7
|
+
check: hasPermission,
|
|
8
|
+
/** Checks permission and throws ForbiddenError if denied. Loads permissions from DB with caching. */
|
|
9
|
+
enforce: enforcePermission,
|
|
10
|
+
/** Checks if a granted scope satisfies a required scope given a hierarchy (e.g. org > team > self). */
|
|
11
|
+
satisfies: scopeSatisfies,
|
|
12
|
+
/** LRU cache for resolved permissions — avoids repeated DB lookups within a request. */
|
|
13
|
+
PermissionCache,
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=namespace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../../src/auth/rbac/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,iBAAiB,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE1G,+FAA+F;AAC/F,MAAM,CAAC,MAAM,IAAI,GAAG;IAClB,4EAA4E;IAC5E,MAAM,EAAE,UAAU;IAClB,oGAAoG;IACpG,KAAK,EAAE,aAAa;IACpB,qGAAqG;IACrG,OAAO,EAAE,iBAAiB;IAC1B,uGAAuG;IACvG,SAAS,EAAE,cAAc;IACzB,wFAAwF;IACxF,eAAe;CAChB,CAAA"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { DB } from '../../data/db/index.js';
|
|
2
|
+
import type { RbacConfig, PermissionSet } from './types.js';
|
|
3
|
+
export declare function resolveUserPermissions(db: DB, userId: string, tenantId: string, authVersion: number, config: RbacConfig): Promise<PermissionSet>;
|
|
4
|
+
//# sourceMappingURL=resolve.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve.d.ts","sourceRoot":"","sources":["../../../src/auth/rbac/resolve.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,KAAK,EAAE,UAAU,EAAE,aAAa,EAAsB,MAAM,YAAY,CAAA;AAG/E,wBAAsB,sBAAsB,CAC1C,EAAE,EAAE,EAAE,EACN,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,aAAa,CAAC,CAwBxB"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { sql } from '../../data/db/sql.js';
|
|
2
|
+
import { assertValidIdentifier, quoteIdentifier } from '../../data/db/identifiers.js';
|
|
3
|
+
export async function resolveUserPermissions(db, userId, tenantId, authVersion, config) {
|
|
4
|
+
const userRolesTable = config.table?.userRoles ?? 'pipework_user_roles';
|
|
5
|
+
const rolePermissionsTable = config.table?.rolePermissions ?? 'pipework_role_permissions';
|
|
6
|
+
const permissionsTable = config.table?.permissions ?? 'pipework_permissions';
|
|
7
|
+
assertValidIdentifier(userRolesTable, 'userRoles table');
|
|
8
|
+
assertValidIdentifier(rolePermissionsTable, 'rolePermissions table');
|
|
9
|
+
assertValidIdentifier(permissionsTable, 'permissions table');
|
|
10
|
+
const rows = await db.execute(sql `
|
|
11
|
+
SELECT p.resource, p.action, rp.scope
|
|
12
|
+
FROM ${sql.raw(quoteIdentifier(userRolesTable, 'userRoles table'))} ur
|
|
13
|
+
JOIN ${sql.raw(quoteIdentifier(rolePermissionsTable, 'rolePermissions table'))} rp ON rp.role_id = ur.role_id
|
|
14
|
+
JOIN ${sql.raw(quoteIdentifier(permissionsTable, 'permissions table'))} p ON p.id = rp.permission_id
|
|
15
|
+
WHERE ur.user_id = ${userId} AND ur.tenant_id = ${tenantId}
|
|
16
|
+
`);
|
|
17
|
+
const permissions = rows.map((row) => ({
|
|
18
|
+
resource: row['resource'],
|
|
19
|
+
action: row['action'],
|
|
20
|
+
scope: row['scope'],
|
|
21
|
+
}));
|
|
22
|
+
return { userId, tenantId, authVersion, permissions };
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=resolve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve.js","sourceRoot":"","sources":["../../../src/auth/rbac/resolve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,sBAAsB,CAAA;AAG1C,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAA;AAErF,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,EAAM,EACN,MAAc,EACd,QAAgB,EAChB,WAAmB,EACnB,MAAkB;IAElB,MAAM,cAAc,GAAG,MAAM,CAAC,KAAK,EAAE,SAAS,IAAI,qBAAqB,CAAA;IACvE,MAAM,oBAAoB,GAAG,MAAM,CAAC,KAAK,EAAE,eAAe,IAAI,2BAA2B,CAAA;IACzF,MAAM,gBAAgB,GAAG,MAAM,CAAC,KAAK,EAAE,WAAW,IAAI,sBAAsB,CAAA;IAE5E,qBAAqB,CAAC,cAAc,EAAE,iBAAiB,CAAC,CAAA;IACxD,qBAAqB,CAAC,oBAAoB,EAAE,uBAAuB,CAAC,CAAA;IACpE,qBAAqB,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,CAAA;IAE5D,MAAM,IAAI,GAAG,MAAM,EAAE,CAAC,OAAO,CAAC,GAAG,CAAA;;WAExB,GAAG,CAAC,GAAG,CAAC,eAAe,CAAC,cAAc,EAAE,iBAAiB,CAAC,CAAC;WAC3D,GAAG,CAAC,GAAG,CAAC,eAAe,CAAC,oBAAoB,EAAE,uBAAuB,CAAC,CAAC;WACvE,GAAG,CAAC,GAAG,CAAC,eAAe,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,CAAC;yBACjD,MAAM,uBAAuB,QAAQ;GAC3D,CAAC,CAAA;IAEF,MAAM,WAAW,GAAyB,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAC3D,QAAQ,EAAE,GAAG,CAAC,UAAU,CAAW;QACnC,MAAM,EAAE,GAAG,CAAC,QAAQ,CAAW;QAC/B,KAAK,EAAE,GAAG,CAAC,OAAO,CAAW;KAC9B,CAAC,CAAC,CAAA;IAEH,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE,CAAA;AACvD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"seed.d.ts","sourceRoot":"","sources":["../../../src/auth/rbac/seed.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAGtD,wBAAsB,QAAQ,CAC5B,EAAE,EAAE,EAAE,EACN,IAAI,EAAE,QAAQ,EACd,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,IAAI,CAAC,CAgEf"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { sql } from '../../data/db/sql.js';
|
|
2
|
+
import { assertValidIdentifier, quoteIdentifier } from '../../data/db/identifiers.js';
|
|
3
|
+
export async function seedRbac(db, data, config) {
|
|
4
|
+
const permissionsTable = config.table?.permissions ?? 'pipework_permissions';
|
|
5
|
+
const rolesTable = config.table?.roles ?? 'pipework_roles';
|
|
6
|
+
const rolePermissionsTable = config.table?.rolePermissions ?? 'pipework_role_permissions';
|
|
7
|
+
const userRolesTable = config.table?.userRoles ?? 'pipework_user_roles';
|
|
8
|
+
assertValidIdentifier(permissionsTable, 'permissions table');
|
|
9
|
+
assertValidIdentifier(rolesTable, 'roles table');
|
|
10
|
+
assertValidIdentifier(rolePermissionsTable, 'rolePermissions table');
|
|
11
|
+
assertValidIdentifier(userRolesTable, 'userRoles table');
|
|
12
|
+
const permQ = quoteIdentifier(permissionsTable, 'permissions table');
|
|
13
|
+
const rolesQ = quoteIdentifier(rolesTable, 'roles table');
|
|
14
|
+
const rolePermQ = quoteIdentifier(rolePermissionsTable, 'rolePermissions table');
|
|
15
|
+
const userRolesQ = quoteIdentifier(userRolesTable, 'userRoles table');
|
|
16
|
+
for (const perm of data.permissions) {
|
|
17
|
+
await db.execute(sql `
|
|
18
|
+
INSERT INTO ${sql.raw(permQ)} (resource, action)
|
|
19
|
+
VALUES (${perm.resource}, ${perm.action})
|
|
20
|
+
ON CONFLICT (resource, action) DO NOTHING
|
|
21
|
+
`);
|
|
22
|
+
}
|
|
23
|
+
for (const role of data.roles) {
|
|
24
|
+
if (role.description !== undefined) {
|
|
25
|
+
await db.execute(sql `
|
|
26
|
+
INSERT INTO ${sql.raw(rolesQ)} (name, tenant_id, description)
|
|
27
|
+
VALUES (${role.name}, ${role.tenantId}, ${role.description})
|
|
28
|
+
ON CONFLICT (tenant_id, name) DO UPDATE SET
|
|
29
|
+
description = EXCLUDED.description
|
|
30
|
+
`);
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
await db.execute(sql `
|
|
34
|
+
INSERT INTO ${sql.raw(rolesQ)} (name, tenant_id)
|
|
35
|
+
VALUES (${role.name}, ${role.tenantId})
|
|
36
|
+
ON CONFLICT (tenant_id, name) DO UPDATE SET
|
|
37
|
+
description = EXCLUDED.description
|
|
38
|
+
`);
|
|
39
|
+
}
|
|
40
|
+
for (const rp of role.permissions) {
|
|
41
|
+
await db.execute(sql `
|
|
42
|
+
INSERT INTO ${sql.raw(rolePermQ)} (role_id, permission_id, scope)
|
|
43
|
+
SELECT r.id, p.id, ${rp.scope}
|
|
44
|
+
FROM ${sql.raw(rolesQ)} r, ${sql.raw(permQ)} p
|
|
45
|
+
WHERE r.name = ${role.name} AND r.tenant_id = ${role.tenantId}
|
|
46
|
+
AND p.resource = ${rp.resource} AND p.action = ${rp.action}
|
|
47
|
+
ON CONFLICT (role_id, permission_id) DO UPDATE SET scope = EXCLUDED.scope
|
|
48
|
+
`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
if (data.userRoles) {
|
|
52
|
+
for (const ur of data.userRoles) {
|
|
53
|
+
await db.execute(sql `
|
|
54
|
+
INSERT INTO ${sql.raw(userRolesQ)} (user_id, role_id, tenant_id)
|
|
55
|
+
SELECT ${ur.userId}, r.id, ${ur.tenantId}
|
|
56
|
+
FROM ${sql.raw(rolesQ)} r
|
|
57
|
+
WHERE r.name = ${ur.roleName} AND r.tenant_id = ${ur.tenantId}
|
|
58
|
+
ON CONFLICT (user_id, role_id, tenant_id) DO NOTHING
|
|
59
|
+
`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=seed.js.map
|