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,56 @@
|
|
|
1
|
+
import { createStore } from './store.js';
|
|
2
|
+
const DEFAULTS = {
|
|
3
|
+
table: '__pipework_idempotency',
|
|
4
|
+
headerName: 'Idempotency-Key',
|
|
5
|
+
ttlSeconds: 86400,
|
|
6
|
+
lockTimeoutMs: 30_000,
|
|
7
|
+
methods: ['POST', 'PATCH', 'DELETE'],
|
|
8
|
+
};
|
|
9
|
+
export function createIdempotency(instance, config) {
|
|
10
|
+
const resolved = {
|
|
11
|
+
database: config.database,
|
|
12
|
+
table: config.table ?? DEFAULTS.table,
|
|
13
|
+
headerName: config.headerName ?? DEFAULTS.headerName,
|
|
14
|
+
ttlSeconds: config.ttlSeconds ?? DEFAULTS.ttlSeconds,
|
|
15
|
+
lockTimeoutMs: config.lockTimeoutMs ?? DEFAULTS.lockTimeoutMs,
|
|
16
|
+
methods: config.methods ?? [...DEFAULTS.methods],
|
|
17
|
+
};
|
|
18
|
+
const store = createStore(resolved.table);
|
|
19
|
+
return {
|
|
20
|
+
store,
|
|
21
|
+
config: resolved,
|
|
22
|
+
async check(db, tenantId, key, method, path) {
|
|
23
|
+
const existing = await store.find(db, tenantId, key);
|
|
24
|
+
if (existing === null) {
|
|
25
|
+
const locked = await store.lock(db, tenantId, key, method, path, resolved.lockTimeoutMs);
|
|
26
|
+
if (!locked) {
|
|
27
|
+
return { status: 'locked' };
|
|
28
|
+
}
|
|
29
|
+
return { status: 'new' };
|
|
30
|
+
}
|
|
31
|
+
if (existing.statusCode !== null) {
|
|
32
|
+
return { status: 'completed', statusCode: existing.statusCode, body: existing.responseBody };
|
|
33
|
+
}
|
|
34
|
+
if (existing.lockedUntil !== null && existing.lockedUntil.getTime() > Date.now()) {
|
|
35
|
+
return { status: 'locked' };
|
|
36
|
+
}
|
|
37
|
+
// Lock expired — re-lock and retry
|
|
38
|
+
await store.remove(db, tenantId, key);
|
|
39
|
+
const locked = await store.lock(db, tenantId, key, method, path, resolved.lockTimeoutMs);
|
|
40
|
+
if (!locked) {
|
|
41
|
+
return { status: 'locked' };
|
|
42
|
+
}
|
|
43
|
+
return { status: 'new' };
|
|
44
|
+
},
|
|
45
|
+
async complete(db, tenantId, key, statusCode, body) {
|
|
46
|
+
await store.complete(db, tenantId, key, statusCode, body);
|
|
47
|
+
},
|
|
48
|
+
async fail(db, tenantId, key) {
|
|
49
|
+
await store.remove(db, tenantId, key);
|
|
50
|
+
},
|
|
51
|
+
async cleanup(db) {
|
|
52
|
+
return store.cleanup(db, resolved.ttlSeconds);
|
|
53
|
+
},
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/infra/idempotency/middleware.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../src/infra/idempotency/store.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAqB,MAAM,YAAY,CAAA;AAErE,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,gBAAgB,CA2E3D"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { sql } from '../../data/db/sql.js';
|
|
2
|
+
export function createStore(table) {
|
|
3
|
+
return {
|
|
4
|
+
async ensureTable(db) {
|
|
5
|
+
await db.execute(sql.raw(`
|
|
6
|
+
CREATE TABLE IF NOT EXISTS ${table} (
|
|
7
|
+
key TEXT NOT NULL,
|
|
8
|
+
tenant_id TEXT NOT NULL,
|
|
9
|
+
method TEXT NOT NULL,
|
|
10
|
+
path TEXT NOT NULL,
|
|
11
|
+
status_code INTEGER,
|
|
12
|
+
response_body JSONB,
|
|
13
|
+
locked_until TIMESTAMPTZ,
|
|
14
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT now(),
|
|
15
|
+
PRIMARY KEY (tenant_id, key)
|
|
16
|
+
)
|
|
17
|
+
`));
|
|
18
|
+
},
|
|
19
|
+
async find(db, tenantId, key) {
|
|
20
|
+
const rows = await db.execute(sql `SELECT key, tenant_id, method, path, status_code, response_body, locked_until, created_at
|
|
21
|
+
FROM ${sql.raw(table)}
|
|
22
|
+
WHERE tenant_id = ${tenantId} AND key = ${key}`);
|
|
23
|
+
const row = rows[0];
|
|
24
|
+
if (row === undefined)
|
|
25
|
+
return null;
|
|
26
|
+
return {
|
|
27
|
+
key: row['key'],
|
|
28
|
+
tenantId: row['tenant_id'],
|
|
29
|
+
method: row['method'],
|
|
30
|
+
path: row['path'],
|
|
31
|
+
statusCode: row['status_code'],
|
|
32
|
+
responseBody: row['response_body'],
|
|
33
|
+
lockedUntil: row['locked_until'] !== null ? new Date(row['locked_until']) : null,
|
|
34
|
+
createdAt: new Date(row['created_at']),
|
|
35
|
+
};
|
|
36
|
+
},
|
|
37
|
+
async lock(db, tenantId, key, method, path, lockMs) {
|
|
38
|
+
const lockUntil = new Date(Date.now() + lockMs);
|
|
39
|
+
const rows = await db.execute(sql `INSERT INTO ${sql.raw(table)} (key, tenant_id, method, path, locked_until)
|
|
40
|
+
VALUES (${key}, ${tenantId}, ${method}, ${path}, ${lockUntil.toISOString()})
|
|
41
|
+
ON CONFLICT (tenant_id, key) DO NOTHING
|
|
42
|
+
RETURNING key`);
|
|
43
|
+
return rows.length > 0;
|
|
44
|
+
},
|
|
45
|
+
async complete(db, tenantId, key, statusCode, responseBody) {
|
|
46
|
+
await db.execute(sql `UPDATE ${sql.raw(table)}
|
|
47
|
+
SET status_code = ${statusCode},
|
|
48
|
+
response_body = ${JSON.stringify(responseBody)},
|
|
49
|
+
locked_until = NULL
|
|
50
|
+
WHERE tenant_id = ${tenantId} AND key = ${key}`);
|
|
51
|
+
},
|
|
52
|
+
async remove(db, tenantId, key) {
|
|
53
|
+
await db.execute(sql `DELETE FROM ${sql.raw(table)} WHERE tenant_id = ${tenantId} AND key = ${key}`);
|
|
54
|
+
},
|
|
55
|
+
async cleanup(db, ttlSeconds) {
|
|
56
|
+
const rows = await db.execute(sql `DELETE FROM ${sql.raw(table)}
|
|
57
|
+
WHERE created_at < now() - ${ttlSeconds.toString() + ' seconds'}::interval
|
|
58
|
+
RETURNING key`);
|
|
59
|
+
return rows.length;
|
|
60
|
+
},
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/infra/idempotency/store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,sBAAsB,CAAA;AAI1C,MAAM,UAAU,WAAW,CAAC,KAAa;IACvC,OAAO;QACL,KAAK,CAAC,WAAW,CAAC,EAAM;YACtB,MAAM,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC;qCACM,KAAK;;;;;;;;;;;OAWnC,CAAC,CAAC,CAAA;QACL,CAAC;QAED,KAAK,CAAC,IAAI,CAAC,EAAM,EAAE,QAAgB,EAAE,GAAW;YAC9C,MAAM,IAAI,GAAc,MAAM,EAAE,CAAC,OAAO,CACtC,GAAG,CAAA;mBACQ,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC;gCACD,QAAQ,cAAc,GAAG,EAAE,CACpD,CAAA;YACD,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAwC,CAAA;YAC1D,IAAI,GAAG,KAAK,SAAS;gBAAE,OAAO,IAAI,CAAA;YAElC,OAAO;gBACL,GAAG,EAAE,GAAG,CAAC,KAAK,CAAW;gBACzB,QAAQ,EAAE,GAAG,CAAC,WAAW,CAAW;gBACpC,MAAM,EAAE,GAAG,CAAC,QAAQ,CAAW;gBAC/B,IAAI,EAAE,GAAG,CAAC,MAAM,CAAW;gBAC3B,UAAU,EAAE,GAAG,CAAC,aAAa,CAAkB;gBAC/C,YAAY,EAAE,GAAG,CAAC,eAAe,CAAC;gBAClC,WAAW,EAAE,GAAG,CAAC,cAAc,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,cAAc,CAAW,CAAC,CAAC,CAAC,CAAC,IAAI;gBAC1F,SAAS,EAAE,IAAI,IAAI,CAAC,GAAG,CAAC,YAAY,CAAW,CAAC;aACjD,CAAA;QACH,CAAC;QAED,KAAK,CAAC,IAAI,CAAC,EAAM,EAAE,QAAgB,EAAE,GAAW,EAAE,MAAc,EAAE,IAAY,EAAE,MAAc;YAC5F,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAA;YAC/C,MAAM,IAAI,GAAc,MAAM,EAAE,CAAC,OAAO,CACtC,GAAG,CAAA,eAAe,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC;sBAClB,GAAG,KAAK,QAAQ,KAAK,MAAM,KAAK,IAAI,KAAK,SAAS,CAAC,WAAW,EAAE;;0BAE5D,CACnB,CAAA;YACD,OAAQ,IAAkB,CAAC,MAAM,GAAG,CAAC,CAAA;QACvC,CAAC;QAED,KAAK,CAAC,QAAQ,CAAC,EAAM,EAAE,QAAgB,EAAE,GAAW,EAAE,UAAkB,EAAE,YAAqB;YAC7F,MAAM,EAAE,CAAC,OAAO,CACd,GAAG,CAAA,UAAU,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC;gCACH,UAAU;kCACR,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;;gCAE9B,QAAQ,cAAc,GAAG,EAAE,CACpD,CAAA;QACH,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,EAAM,EAAE,QAAgB,EAAE,GAAW;YAChD,MAAM,EAAE,CAAC,OAAO,CACd,GAAG,CAAA,eAAe,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,sBAAsB,QAAQ,cAAc,GAAG,EAAE,CAClF,CAAA;QACH,CAAC;QAED,KAAK,CAAC,OAAO,CAAC,EAAM,EAAE,UAAkB;YACtC,MAAM,IAAI,GAAc,MAAM,EAAE,CAAC,OAAO,CACtC,GAAG,CAAA,eAAe,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC;yCACC,UAAU,CAAC,QAAQ,EAAE,GAAG,UAAU;0BACjD,CACnB,CAAA;YACD,OAAQ,IAAkB,CAAC,MAAM,CAAA;QACnC,CAAC;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { DB } from '../../data/db/index.js';
|
|
2
|
+
export interface IdempotencyConfig {
|
|
3
|
+
database: string;
|
|
4
|
+
table?: string;
|
|
5
|
+
headerName?: string;
|
|
6
|
+
ttlSeconds?: number;
|
|
7
|
+
lockTimeoutMs?: number;
|
|
8
|
+
methods?: ReadonlyArray<'POST' | 'PUT' | 'PATCH' | 'DELETE'>;
|
|
9
|
+
}
|
|
10
|
+
export interface IdempotencyRecord {
|
|
11
|
+
key: string;
|
|
12
|
+
tenantId: string;
|
|
13
|
+
method: string;
|
|
14
|
+
path: string;
|
|
15
|
+
statusCode: number | null;
|
|
16
|
+
responseBody: unknown;
|
|
17
|
+
lockedUntil: Date | null;
|
|
18
|
+
createdAt: Date;
|
|
19
|
+
}
|
|
20
|
+
export interface IdempotencyStore {
|
|
21
|
+
ensureTable(db: DB): Promise<void>;
|
|
22
|
+
find(db: DB, tenantId: string, key: string): Promise<IdempotencyRecord | null>;
|
|
23
|
+
lock(db: DB, tenantId: string, key: string, method: string, path: string, lockMs: number): Promise<boolean>;
|
|
24
|
+
complete(db: DB, tenantId: string, key: string, statusCode: number, responseBody: unknown): Promise<void>;
|
|
25
|
+
remove(db: DB, tenantId: string, key: string): Promise<void>;
|
|
26
|
+
cleanup(db: DB, ttlSeconds: number): Promise<number>;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/infra/idempotency/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAEhD,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,MAAM,CAAA;IAChB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,OAAO,CAAC,EAAE,aAAa,CAAC,MAAM,GAAG,KAAK,GAAG,OAAO,GAAG,QAAQ,CAAC,CAAA;CAC7D;AAED,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,MAAM,CAAA;IACX,QAAQ,EAAE,MAAM,CAAA;IAChB,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,YAAY,EAAE,OAAO,CAAA;IACrB,WAAW,EAAE,IAAI,GAAG,IAAI,CAAA;IACxB,SAAS,EAAE,IAAI,CAAA;CAChB;AAED,MAAM,WAAW,gBAAgB;IAC/B,WAAW,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAClC,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,GAAG,IAAI,CAAC,CAAA;IAC9E,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAA;IAC3G,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACzG,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAC5D,OAAO,CAAC,EAAE,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;CACrD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/infra/idempotency/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Handler, HttpMethod } from '../../request/di/types.js';
|
|
2
|
+
import type { SignatureVerifier } from './verify.js';
|
|
3
|
+
export interface InboundWebhookConfig<TPayload> {
|
|
4
|
+
path: string;
|
|
5
|
+
method?: HttpMethod;
|
|
6
|
+
verifier: SignatureVerifier;
|
|
7
|
+
parsePayload?: (rawBody: Buffer) => TPayload;
|
|
8
|
+
idempotencyKey?: (payload: TPayload) => string;
|
|
9
|
+
}
|
|
10
|
+
export interface InboundWebhookContext<TPayload> {
|
|
11
|
+
payload: TPayload;
|
|
12
|
+
rawBody: Buffer;
|
|
13
|
+
headers: Readonly<Record<string, string | undefined>>;
|
|
14
|
+
}
|
|
15
|
+
export declare function defineInboundWebhook<TPayload = unknown>(config: InboundWebhookConfig<TPayload>, handler: (ctx: InboundWebhookContext<TPayload>) => Promise<unknown>): Handler<Record<string, unknown>, unknown>;
|
|
16
|
+
//# sourceMappingURL=inbound.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inbound.d.ts","sourceRoot":"","sources":["../../../src/infra/webhook/inbound.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAA;AACpE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAIpD,MAAM,WAAW,oBAAoB,CAAC,QAAQ;IAC5C,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,UAAU,CAAA;IACnB,QAAQ,EAAE,iBAAiB,CAAA;IAC3B,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,QAAQ,CAAA;IAC5C,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,KAAK,MAAM,CAAA;CAC/C;AAED,MAAM,WAAW,qBAAqB,CAAC,QAAQ;IAC7C,OAAO,EAAE,QAAQ,CAAA;IACjB,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAA;CACtD;AAED,wBAAgB,oBAAoB,CAAC,QAAQ,GAAG,OAAO,EACrD,MAAM,EAAE,oBAAoB,CAAC,QAAQ,CAAC,EACtC,OAAO,EAAE,CAAC,GAAG,EAAE,qBAAqB,CAAC,QAAQ,CAAC,KAAK,OAAO,CAAC,OAAO,CAAC,GAClE,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,CAAC,CAsB3C"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Builder } from '../../request/di/builder.js';
|
|
2
|
+
import { UnauthorizedError } from '../../core/errors/index.js';
|
|
3
|
+
export function defineInboundWebhook(config, handler) {
|
|
4
|
+
const method = config.method ?? 'POST';
|
|
5
|
+
const parse = config.parsePayload ?? ((raw) => JSON.parse(raw.toString('utf-8')));
|
|
6
|
+
return new Builder()
|
|
7
|
+
.public()
|
|
8
|
+
.rawBody()
|
|
9
|
+
.request()
|
|
10
|
+
.route(method, config.path)
|
|
11
|
+
.fit(async ({ rawBody, request }) => {
|
|
12
|
+
if (!config.verifier.verify(rawBody, request.headers)) {
|
|
13
|
+
throw new UnauthorizedError('Webhook signature verification failed.\n\n' +
|
|
14
|
+
' The request signature does not match the expected value.\n' +
|
|
15
|
+
' Check that the signing secret is correct and the raw body is unmodified.\n');
|
|
16
|
+
}
|
|
17
|
+
const payload = parse(rawBody);
|
|
18
|
+
return handler({ payload, rawBody, headers: request.headers });
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=inbound.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inbound.js","sourceRoot":"","sources":["../../../src/infra/webhook/inbound.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,6BAA6B,CAAA;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAA;AAgB9D,MAAM,UAAU,oBAAoB,CAClC,MAAsC,EACtC,OAAmE;IAEnE,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,MAAM,CAAA;IACtC,MAAM,KAAK,GAAG,MAAM,CAAC,YAAY,IAAI,CAAC,CAAC,GAAW,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAa,CAAC,CAAA;IAErG,OAAO,IAAI,OAAO,EAAE;SACjB,MAAM,EAAE;SACR,OAAO,EAAE;SACT,OAAO,EAAE;SACT,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;SAC1B,GAAG,CAAC,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE;QAClC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YACtD,MAAM,IAAI,iBAAiB,CACzB,4CAA4C;gBAC5C,8DAA8D;gBAC9D,8EAA8E,CAC/E,CAAA;QACH,CAAC;QAED,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,CAAA;QAE9B,OAAO,OAAO,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAA;IAChE,CAAC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { defineInboundWebhook, type InboundWebhookConfig, type InboundWebhookContext } from './inbound.js';
|
|
2
|
+
export { hmacVerifier, stripeVerifier, githubVerifier, type SignatureVerifier } from './verify.js';
|
|
3
|
+
export { signPayload, type SignedPayload, type WebhookSignatureOptions } from './sign.js';
|
|
4
|
+
export { createOutboundWebhook, type OutboundWebhookConfig, type OutboundWebhook, type WebhookEndpoint, type DeliveryAttempt } from './outbound.js';
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/infra/webhook/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,KAAK,oBAAoB,EAAE,KAAK,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAC1G,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,cAAc,EAAE,KAAK,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAClG,OAAO,EAAE,WAAW,EAAE,KAAK,aAAa,EAAE,KAAK,uBAAuB,EAAE,MAAM,WAAW,CAAA;AACzF,OAAO,EAAE,qBAAqB,EAAE,KAAK,qBAAqB,EAAE,KAAK,eAAe,EAC9E,KAAK,eAAe,EAAE,KAAK,eAAe,EAAE,MAAM,eAAe,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/infra/webhook/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAyD,MAAM,cAAc,CAAA;AAC1G,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,cAAc,EAA0B,MAAM,aAAa,CAAA;AAClG,OAAO,EAAE,WAAW,EAAoD,MAAM,WAAW,CAAA;AACzF,OAAO,EAAE,qBAAqB,EACgB,MAAM,eAAe,CAAA"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { defineInboundWebhook } from './inbound.js';
|
|
2
|
+
import { hmacVerifier, stripeVerifier, githubVerifier } from './verify.js';
|
|
3
|
+
import { signPayload } from './sign.js';
|
|
4
|
+
import { createOutboundWebhook } from './outbound.js';
|
|
5
|
+
/** Webhook namespace — inbound verification, outbound delivery with retries, HMAC signing. */
|
|
6
|
+
export declare const webhook: {
|
|
7
|
+
/** Defines an inbound webhook handler with signature verification and optional idempotency. */
|
|
8
|
+
readonly defineInbound: typeof defineInboundWebhook;
|
|
9
|
+
/** Creates an outbound webhook system — endpoint registration, payload signing, delivery with retries. */
|
|
10
|
+
readonly createOutbound: typeof createOutboundWebhook;
|
|
11
|
+
readonly verify: {
|
|
12
|
+
/** Creates an HMAC signature verifier for inbound webhooks. */
|
|
13
|
+
readonly hmac: typeof hmacVerifier;
|
|
14
|
+
/** Creates a Stripe-compatible signature verifier. */
|
|
15
|
+
readonly stripe: typeof stripeVerifier;
|
|
16
|
+
/** Creates a GitHub-compatible signature verifier. */
|
|
17
|
+
readonly github: typeof githubVerifier;
|
|
18
|
+
};
|
|
19
|
+
/** Signs a payload with HMAC for outbound delivery — returns body, signature, timestamp, messageId. */
|
|
20
|
+
readonly sign: typeof signPayload;
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../../src/infra/webhook/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAA;AACnD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAA;AAErD,8FAA8F;AAC9F,eAAO,MAAM,OAAO;IAClB,+FAA+F;;IAE/F,0GAA0G;;;QAIxG,+DAA+D;;QAE/D,sDAAsD;;QAEtD,sDAAsD;;;IAIxD,uGAAuG;;CAE/F,CAAA"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { defineInboundWebhook } from './inbound.js';
|
|
2
|
+
import { hmacVerifier, stripeVerifier, githubVerifier } from './verify.js';
|
|
3
|
+
import { signPayload } from './sign.js';
|
|
4
|
+
import { createOutboundWebhook } from './outbound.js';
|
|
5
|
+
/** Webhook namespace — inbound verification, outbound delivery with retries, HMAC signing. */
|
|
6
|
+
export const webhook = {
|
|
7
|
+
/** Defines an inbound webhook handler with signature verification and optional idempotency. */
|
|
8
|
+
defineInbound: defineInboundWebhook,
|
|
9
|
+
/** Creates an outbound webhook system — endpoint registration, payload signing, delivery with retries. */
|
|
10
|
+
createOutbound: createOutboundWebhook,
|
|
11
|
+
verify: {
|
|
12
|
+
/** Creates an HMAC signature verifier for inbound webhooks. */
|
|
13
|
+
hmac: hmacVerifier,
|
|
14
|
+
/** Creates a Stripe-compatible signature verifier. */
|
|
15
|
+
stripe: stripeVerifier,
|
|
16
|
+
/** Creates a GitHub-compatible signature verifier. */
|
|
17
|
+
github: githubVerifier,
|
|
18
|
+
},
|
|
19
|
+
/** Signs a payload with HMAC for outbound delivery — returns body, signature, timestamp, messageId. */
|
|
20
|
+
sign: signPayload,
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=namespace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../../src/infra/webhook/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAA;AACnD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAA;AAErD,8FAA8F;AAC9F,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,+FAA+F;IAC/F,aAAa,EAAE,oBAAoB;IACnC,0GAA0G;IAC1G,cAAc,EAAE,qBAAqB;IAErC,MAAM,EAAE;QACN,+DAA+D;QAC/D,IAAI,EAAE,YAAY;QAClB,sDAAsD;QACtD,MAAM,EAAE,cAAc;QACtB,sDAAsD;QACtD,MAAM,EAAE,cAAc;KACvB;IAED,uGAAuG;IACvG,IAAI,EAAE,WAAW;CACT,CAAA"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { DB } from '../../data/db/index.js';
|
|
2
|
+
import { type WebhookSignatureOptions } from './sign.js';
|
|
3
|
+
export interface OutboundWebhookConfig {
|
|
4
|
+
table?: string;
|
|
5
|
+
deliveryTable?: string;
|
|
6
|
+
signing?: WebhookSignatureOptions;
|
|
7
|
+
retry?: {
|
|
8
|
+
maxAttempts?: number;
|
|
9
|
+
initialDelayMs?: number;
|
|
10
|
+
maxDelayMs?: number;
|
|
11
|
+
};
|
|
12
|
+
timeoutMs?: number;
|
|
13
|
+
}
|
|
14
|
+
export interface WebhookEndpoint {
|
|
15
|
+
id: string;
|
|
16
|
+
tenantId: string;
|
|
17
|
+
url: string;
|
|
18
|
+
secret: string;
|
|
19
|
+
events: string[];
|
|
20
|
+
active: boolean;
|
|
21
|
+
}
|
|
22
|
+
export interface DeliveryAttempt {
|
|
23
|
+
id: string;
|
|
24
|
+
endpointId: string;
|
|
25
|
+
tenantId: string;
|
|
26
|
+
eventType: string;
|
|
27
|
+
payload: unknown;
|
|
28
|
+
statusCode: number | null;
|
|
29
|
+
responseBody: string | null;
|
|
30
|
+
attempt: number;
|
|
31
|
+
maxAttempts: number;
|
|
32
|
+
nextRetryAt: Date | null;
|
|
33
|
+
createdAt: Date;
|
|
34
|
+
}
|
|
35
|
+
export interface OutboundWebhook {
|
|
36
|
+
ensureTables(db: DB): Promise<void>;
|
|
37
|
+
send(db: DB, tenantId: string, eventType: string, payload: unknown): Promise<string[]>;
|
|
38
|
+
deliver(db: DB, deliveryId: string): Promise<{
|
|
39
|
+
success: boolean;
|
|
40
|
+
statusCode: number | null;
|
|
41
|
+
}>;
|
|
42
|
+
processPending(db: DB): Promise<number>;
|
|
43
|
+
registerEndpoint(db: DB, endpoint: Omit<WebhookEndpoint, 'id'>): Promise<string>;
|
|
44
|
+
listEndpoints(db: DB, tenantId: string): Promise<WebhookEndpoint[]>;
|
|
45
|
+
removeEndpoint(db: DB, tenantId: string, endpointId: string): Promise<boolean>;
|
|
46
|
+
}
|
|
47
|
+
export declare function createOutboundWebhook(config?: OutboundWebhookConfig): OutboundWebhook;
|
|
48
|
+
//# sourceMappingURL=outbound.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outbound.d.ts","sourceRoot":"","sources":["../../../src/infra/webhook/outbound.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAe,KAAK,uBAAuB,EAAE,MAAM,WAAW,CAAA;AAErE,MAAM,WAAW,qBAAqB;IACpC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,OAAO,CAAC,EAAE,uBAAuB,CAAA;IACjC,KAAK,CAAC,EAAE;QACN,WAAW,CAAC,EAAE,MAAM,CAAA;QACpB,cAAc,CAAC,EAAE,MAAM,CAAA;QACvB,UAAU,CAAC,EAAE,MAAM,CAAA;KACpB,CAAA;IACD,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,EAAE,EAAE,MAAM,CAAA;IACV,QAAQ,EAAE,MAAM,CAAA;IAChB,GAAG,EAAE,MAAM,CAAA;IACX,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,MAAM,EAAE,CAAA;IAChB,MAAM,EAAE,OAAO,CAAA;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,EAAE,EAAE,MAAM,CAAA;IACV,UAAU,EAAE,MAAM,CAAA;IAClB,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;IACjB,OAAO,EAAE,OAAO,CAAA;IAChB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAA;IAC3B,OAAO,EAAE,MAAM,CAAA;IACf,WAAW,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,IAAI,GAAG,IAAI,CAAA;IACxB,SAAS,EAAE,IAAI,CAAA;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,YAAY,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACnC,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAA;IACtF,OAAO,CAAC,EAAE,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE,CAAC,CAAA;IAC7F,cAAc,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IACvC,gBAAgB,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IAChF,aAAa,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC,CAAA;IACnE,cAAc,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAA;CAC/E;AAWD,wBAAgB,qBAAqB,CAAC,MAAM,GAAE,qBAA0B,GAAG,eAAe,CAqLzF"}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { sql } from '../../data/db/sql.js';
|
|
2
|
+
import { signPayload } from './sign.js';
|
|
3
|
+
const DEFAULTS = {
|
|
4
|
+
table: '__pipework_webhook_endpoints',
|
|
5
|
+
deliveryTable: '__pipework_webhook_deliveries',
|
|
6
|
+
maxAttempts: 5,
|
|
7
|
+
initialDelayMs: 1000,
|
|
8
|
+
maxDelayMs: 3_600_000,
|
|
9
|
+
timeoutMs: 30_000,
|
|
10
|
+
};
|
|
11
|
+
export function createOutboundWebhook(config = {}) {
|
|
12
|
+
const endpointTable = config.table ?? DEFAULTS.table;
|
|
13
|
+
const deliveryTable = config.deliveryTable ?? DEFAULTS.deliveryTable;
|
|
14
|
+
const maxAttempts = config.retry?.maxAttempts ?? DEFAULTS.maxAttempts;
|
|
15
|
+
const initialDelayMs = config.retry?.initialDelayMs ?? DEFAULTS.initialDelayMs;
|
|
16
|
+
const maxDelayMs = config.retry?.maxDelayMs ?? DEFAULTS.maxDelayMs;
|
|
17
|
+
const timeoutMs = config.timeoutMs ?? DEFAULTS.timeoutMs;
|
|
18
|
+
const signingOptions = config.signing ?? {};
|
|
19
|
+
return {
|
|
20
|
+
async ensureTables(db) {
|
|
21
|
+
await db.execute(sql.raw(`
|
|
22
|
+
CREATE TABLE IF NOT EXISTS ${endpointTable} (
|
|
23
|
+
id TEXT NOT NULL PRIMARY KEY DEFAULT gen_random_uuid()::text,
|
|
24
|
+
tenant_id TEXT NOT NULL,
|
|
25
|
+
url TEXT NOT NULL,
|
|
26
|
+
secret TEXT NOT NULL,
|
|
27
|
+
events TEXT[] NOT NULL DEFAULT '{}',
|
|
28
|
+
active BOOLEAN NOT NULL DEFAULT true,
|
|
29
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT now()
|
|
30
|
+
)
|
|
31
|
+
`));
|
|
32
|
+
await db.execute(sql.raw(`
|
|
33
|
+
CREATE TABLE IF NOT EXISTS ${deliveryTable} (
|
|
34
|
+
id TEXT NOT NULL PRIMARY KEY DEFAULT gen_random_uuid()::text,
|
|
35
|
+
endpoint_id TEXT NOT NULL,
|
|
36
|
+
tenant_id TEXT NOT NULL,
|
|
37
|
+
event_type TEXT NOT NULL,
|
|
38
|
+
payload JSONB NOT NULL,
|
|
39
|
+
status_code INTEGER,
|
|
40
|
+
response_body TEXT,
|
|
41
|
+
attempt INTEGER NOT NULL DEFAULT 0,
|
|
42
|
+
max_attempts INTEGER NOT NULL,
|
|
43
|
+
next_retry_at TIMESTAMPTZ,
|
|
44
|
+
completed_at TIMESTAMPTZ,
|
|
45
|
+
created_at TIMESTAMPTZ NOT NULL DEFAULT now()
|
|
46
|
+
)
|
|
47
|
+
`));
|
|
48
|
+
},
|
|
49
|
+
async send(db, tenantId, eventType, payload) {
|
|
50
|
+
const endpoints = await db.execute(sql `SELECT id, url, secret FROM ${sql.raw(endpointTable)}
|
|
51
|
+
WHERE tenant_id = ${tenantId}
|
|
52
|
+
AND active = true
|
|
53
|
+
AND (events = '{}' OR ${eventType} = ANY(events))`);
|
|
54
|
+
const deliveryIds = [];
|
|
55
|
+
for (const row of endpoints) {
|
|
56
|
+
const result = await db.execute(sql `INSERT INTO ${sql.raw(deliveryTable)} (endpoint_id, tenant_id, event_type, payload, max_attempts, next_retry_at)
|
|
57
|
+
VALUES (${row.id}, ${tenantId}, ${eventType}, ${JSON.stringify(payload)}, ${maxAttempts}, now())
|
|
58
|
+
RETURNING id`);
|
|
59
|
+
const inserted = result[0];
|
|
60
|
+
if (inserted !== undefined)
|
|
61
|
+
deliveryIds.push(inserted.id);
|
|
62
|
+
}
|
|
63
|
+
return deliveryIds;
|
|
64
|
+
},
|
|
65
|
+
async deliver(db, deliveryId) {
|
|
66
|
+
const rows = await db.execute(sql `SELECT d.id, d.endpoint_id, d.event_type, d.payload, d.attempt, d.max_attempts,
|
|
67
|
+
e.url, e.secret
|
|
68
|
+
FROM ${sql.raw(deliveryTable)} d
|
|
69
|
+
JOIN ${sql.raw(endpointTable)} e ON e.id = d.endpoint_id
|
|
70
|
+
WHERE d.id = ${deliveryId} AND d.completed_at IS NULL`);
|
|
71
|
+
const delivery = rows[0];
|
|
72
|
+
if (delivery === undefined)
|
|
73
|
+
return { success: false, statusCode: null };
|
|
74
|
+
const attempt = delivery['attempt'] + 1;
|
|
75
|
+
const signed = signPayload(delivery['payload'], delivery['secret'], signingOptions);
|
|
76
|
+
let statusCode = null;
|
|
77
|
+
let responseBody = null;
|
|
78
|
+
let success = false;
|
|
79
|
+
try {
|
|
80
|
+
const controller = new AbortController();
|
|
81
|
+
const timer = setTimeout(() => controller.abort(), timeoutMs);
|
|
82
|
+
const response = await fetch(delivery['url'], {
|
|
83
|
+
method: 'POST',
|
|
84
|
+
headers: {
|
|
85
|
+
'Content-Type': 'application/json',
|
|
86
|
+
'X-Webhook-Id': signed.messageId,
|
|
87
|
+
'X-Webhook-Timestamp': signed.timestamp.toString(),
|
|
88
|
+
'X-Webhook-Signature': signed.signature,
|
|
89
|
+
},
|
|
90
|
+
body: signed.body,
|
|
91
|
+
signal: controller.signal,
|
|
92
|
+
});
|
|
93
|
+
clearTimeout(timer);
|
|
94
|
+
statusCode = response.status;
|
|
95
|
+
responseBody = await response.text().catch(() => null);
|
|
96
|
+
success = statusCode >= 200 && statusCode < 300;
|
|
97
|
+
}
|
|
98
|
+
catch {
|
|
99
|
+
statusCode = null;
|
|
100
|
+
responseBody = null;
|
|
101
|
+
success = false;
|
|
102
|
+
}
|
|
103
|
+
if (success || attempt >= delivery['max_attempts']) {
|
|
104
|
+
await db.execute(sql `UPDATE ${sql.raw(deliveryTable)}
|
|
105
|
+
SET attempt = ${attempt}, status_code = ${statusCode},
|
|
106
|
+
response_body = ${responseBody}, completed_at = now(), next_retry_at = NULL
|
|
107
|
+
WHERE id = ${deliveryId}`);
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
const delayMs = Math.min(initialDelayMs * Math.pow(2, attempt - 1), maxDelayMs);
|
|
111
|
+
const nextRetry = new Date(Date.now() + delayMs);
|
|
112
|
+
await db.execute(sql `UPDATE ${sql.raw(deliveryTable)}
|
|
113
|
+
SET attempt = ${attempt}, status_code = ${statusCode},
|
|
114
|
+
response_body = ${responseBody}, next_retry_at = ${nextRetry.toISOString()}
|
|
115
|
+
WHERE id = ${deliveryId}`);
|
|
116
|
+
}
|
|
117
|
+
return { success, statusCode };
|
|
118
|
+
},
|
|
119
|
+
async processPending(db) {
|
|
120
|
+
const rows = await db.execute(sql `SELECT id FROM ${sql.raw(deliveryTable)}
|
|
121
|
+
WHERE completed_at IS NULL AND next_retry_at <= now()
|
|
122
|
+
ORDER BY next_retry_at ASC
|
|
123
|
+
LIMIT 100`);
|
|
124
|
+
let processed = 0;
|
|
125
|
+
for (const row of rows) {
|
|
126
|
+
await this.deliver(db, row.id);
|
|
127
|
+
processed++;
|
|
128
|
+
}
|
|
129
|
+
return processed;
|
|
130
|
+
},
|
|
131
|
+
async registerEndpoint(db, endpoint) {
|
|
132
|
+
const rows = await db.execute(sql `INSERT INTO ${sql.raw(endpointTable)} (tenant_id, url, secret, events, active)
|
|
133
|
+
VALUES (${endpoint.tenantId}, ${endpoint.url}, ${endpoint.secret},
|
|
134
|
+
${`{${endpoint.events.join(',')}}`}, ${endpoint.active})
|
|
135
|
+
RETURNING id`);
|
|
136
|
+
return (rows[0]).id;
|
|
137
|
+
},
|
|
138
|
+
async listEndpoints(db, tenantId) {
|
|
139
|
+
const rows = await db.execute(sql `SELECT id, tenant_id, url, secret, events, active
|
|
140
|
+
FROM ${sql.raw(endpointTable)}
|
|
141
|
+
WHERE tenant_id = ${tenantId}
|
|
142
|
+
ORDER BY created_at ASC`);
|
|
143
|
+
return rows.map(row => ({
|
|
144
|
+
id: row['id'],
|
|
145
|
+
tenantId: row['tenant_id'],
|
|
146
|
+
url: row['url'],
|
|
147
|
+
secret: row['secret'],
|
|
148
|
+
events: row['events'],
|
|
149
|
+
active: row['active'],
|
|
150
|
+
}));
|
|
151
|
+
},
|
|
152
|
+
async removeEndpoint(db, tenantId, endpointId) {
|
|
153
|
+
const rows = await db.execute(sql `DELETE FROM ${sql.raw(endpointTable)}
|
|
154
|
+
WHERE id = ${endpointId} AND tenant_id = ${tenantId}
|
|
155
|
+
RETURNING id`);
|
|
156
|
+
return rows.length > 0;
|
|
157
|
+
},
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
//# sourceMappingURL=outbound.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outbound.js","sourceRoot":"","sources":["../../../src/infra/webhook/outbound.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface WebhookSignatureOptions {
|
|
2
|
+
algorithm?: string;
|
|
3
|
+
encoding?: 'hex' | 'base64';
|
|
4
|
+
}
|
|
5
|
+
export interface SignedPayload {
|
|
6
|
+
body: string;
|
|
7
|
+
signature: string;
|
|
8
|
+
timestamp: number;
|
|
9
|
+
messageId: string;
|
|
10
|
+
}
|
|
11
|
+
export declare function signPayload(payload: unknown, secret: string, options?: WebhookSignatureOptions): SignedPayload;
|
|
12
|
+
//# sourceMappingURL=sign.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sign.d.ts","sourceRoot":"","sources":["../../../src/infra/webhook/sign.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,uBAAuB;IACtC,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,QAAQ,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAA;CAC5B;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAA;IACZ,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;CAClB;AAED,wBAAgB,WAAW,CACzB,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,MAAM,EACd,OAAO,GAAE,uBAA4B,GACpC,aAAa,CAWf"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { createHmac, randomUUID } from 'node:crypto';
|
|
2
|
+
export function signPayload(payload, secret, options = {}) {
|
|
3
|
+
const algorithm = options.algorithm ?? 'sha256';
|
|
4
|
+
const encoding = options.encoding ?? 'hex';
|
|
5
|
+
const messageId = randomUUID();
|
|
6
|
+
const timestamp = Math.floor(Date.now() / 1000);
|
|
7
|
+
const body = typeof payload === 'string' ? payload : JSON.stringify(payload);
|
|
8
|
+
const toSign = `${messageId}.${timestamp}.${body}`;
|
|
9
|
+
const signature = createHmac(algorithm, secret).update(toSign).digest(encoding);
|
|
10
|
+
return { body, signature, timestamp, messageId };
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=sign.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sign.js","sourceRoot":"","sources":["../../../src/infra/webhook/sign.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAcpD,MAAM,UAAU,WAAW,CACzB,OAAgB,EAChB,MAAc,EACd,UAAmC,EAAE;IAErC,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,QAAQ,CAAA;IAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,KAAK,CAAA;IAE1C,MAAM,SAAS,GAAG,UAAU,EAAE,CAAA;IAC9B,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAA;IAC/C,MAAM,IAAI,GAAG,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;IAC5E,MAAM,MAAM,GAAG,GAAG,SAAS,IAAI,SAAS,IAAI,IAAI,EAAE,CAAA;IAClD,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAE/E,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,CAAA;AAClD,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export interface SignatureVerifier {
|
|
2
|
+
verify(rawBody: Buffer, headers: Readonly<Record<string, string | undefined>>): boolean;
|
|
3
|
+
}
|
|
4
|
+
type LazySecret = string | (() => string);
|
|
5
|
+
export declare function hmacVerifier(options: {
|
|
6
|
+
secret: LazySecret;
|
|
7
|
+
algorithm?: string;
|
|
8
|
+
header: string;
|
|
9
|
+
prefix?: string;
|
|
10
|
+
encoding?: 'hex' | 'base64';
|
|
11
|
+
computePayload?: (rawBody: Buffer, headers: Readonly<Record<string, string | undefined>>) => Buffer;
|
|
12
|
+
}): SignatureVerifier;
|
|
13
|
+
export declare function stripeVerifier(secret: LazySecret): SignatureVerifier;
|
|
14
|
+
export declare function githubVerifier(secret: LazySecret): SignatureVerifier;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=verify.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verify.d.ts","sourceRoot":"","sources":["../../../src/infra/webhook/verify.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,iBAAiB;IAChC,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,GAAG,OAAO,CAAA;CACxF;AAED,KAAK,UAAU,GAAG,MAAM,GAAG,CAAC,MAAM,MAAM,CAAC,CAAA;AAMzC,wBAAgB,YAAY,CAAC,OAAO,EAAE;IACpC,MAAM,EAAE,UAAU,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,QAAQ,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAA;IAC3B,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,KAAK,MAAM,CAAA;CACpG,GAAG,iBAAiB,CAuBpB;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,UAAU,GAAG,iBAAiB,CA2BpE;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,UAAU,GAAG,iBAAiB,CAQpE"}
|