pipework 0.8.7 → 0.8.8
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 +4 -0
- package/dist/REFERENCE.md +873 -0
- package/dist/audit/emit.d.ts +3 -0
- package/dist/audit/emit.d.ts.map +1 -0
- package/dist/audit/emit.js +66 -0
- package/dist/audit/emit.js.map +1 -0
- package/dist/audit/index.d.ts +3 -0
- package/dist/audit/index.d.ts.map +1 -0
- package/dist/audit/index.js +2 -0
- package/dist/audit/index.js.map +1 -0
- package/dist/audit/namespace.d.ts +7 -0
- package/dist/audit/namespace.d.ts.map +1 -0
- package/dist/audit/namespace.js +7 -0
- package/dist/audit/namespace.js.map +1 -0
- package/dist/audit/types.d.ts +17 -0
- package/dist/audit/types.d.ts.map +1 -0
- package/dist/audit/types.js +2 -0
- package/dist/audit/types.js.map +1 -0
- package/dist/auth/chain.d.ts +26 -0
- package/dist/auth/chain.d.ts.map +1 -0
- package/dist/auth/chain.js +46 -0
- package/dist/auth/chain.js.map +1 -0
- package/dist/auth/cookie.d.ts +24 -0
- package/dist/auth/cookie.d.ts.map +1 -0
- package/dist/auth/cookie.js +59 -0
- package/dist/auth/cookie.js.map +1 -0
- package/dist/auth/index.d.ts +10 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/index.js +5 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth/multi-org.d.ts +77 -0
- package/dist/auth/multi-org.d.ts.map +1 -0
- package/dist/auth/multi-org.js +164 -0
- package/dist/auth/multi-org.js.map +1 -0
- package/dist/auth/namespace.d.ts +22 -0
- package/dist/auth/namespace.d.ts.map +1 -0
- package/dist/auth/namespace.js +22 -0
- package/dist/auth/namespace.js.map +1 -0
- package/dist/auth/sessions.d.ts +70 -0
- package/dist/auth/sessions.d.ts.map +1 -0
- package/dist/auth/sessions.js +231 -0
- package/dist/auth/sessions.js.map +1 -0
- package/dist/auth/types.d.ts +22 -0
- package/dist/auth/types.d.ts.map +1 -0
- package/dist/auth/types.js +2 -0
- package/dist/auth/types.js.map +1 -0
- package/dist/behavior/audited.d.ts +5 -0
- package/dist/behavior/audited.d.ts.map +1 -0
- package/dist/behavior/audited.js +78 -0
- package/dist/behavior/audited.js.map +1 -0
- package/dist/behavior/cached.d.ts +7 -0
- package/dist/behavior/cached.d.ts.map +1 -0
- package/dist/behavior/cached.js +48 -0
- package/dist/behavior/cached.js.map +1 -0
- package/dist/behavior/compose.d.ts +4 -0
- package/dist/behavior/compose.d.ts.map +1 -0
- package/dist/behavior/compose.js +18 -0
- package/dist/behavior/compose.js.map +1 -0
- package/dist/behavior/index.d.ts +6 -0
- package/dist/behavior/index.d.ts.map +1 -0
- package/dist/behavior/index.js +5 -0
- package/dist/behavior/index.js.map +1 -0
- package/dist/behavior/namespace.d.ts +16 -0
- package/dist/behavior/namespace.d.ts.map +1 -0
- package/dist/behavior/namespace.js +16 -0
- package/dist/behavior/namespace.js.map +1 -0
- package/dist/behavior/types.d.ts +23 -0
- package/dist/behavior/types.d.ts.map +1 -0
- package/dist/behavior/types.js +2 -0
- package/dist/behavior/types.js.map +1 -0
- package/dist/behavior/versioned.d.ts +4 -0
- package/dist/behavior/versioned.d.ts.map +1 -0
- package/dist/behavior/versioned.js +39 -0
- package/dist/behavior/versioned.js.map +1 -0
- package/dist/cache/create.d.ts +3 -0
- package/dist/cache/create.d.ts.map +1 -0
- package/dist/cache/create.js +90 -0
- package/dist/cache/create.js.map +1 -0
- package/dist/cache/index.d.ts +5 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +3 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cache/namespace.d.ts +10 -0
- package/dist/cache/namespace.d.ts.map +1 -0
- package/dist/cache/namespace.js +10 -0
- package/dist/cache/namespace.js.map +1 -0
- package/dist/cache/tenant.d.ts +21 -0
- package/dist/cache/tenant.d.ts.map +1 -0
- package/dist/cache/tenant.js +101 -0
- package/dist/cache/tenant.js.map +1 -0
- package/dist/cache/types.d.ts +22 -0
- package/dist/cache/types.d.ts.map +1 -0
- package/dist/cache/types.js +2 -0
- package/dist/cache/types.js.map +1 -0
- package/dist/cli/commands/generate.d.ts.map +1 -1
- package/dist/cli/commands/generate.js +10 -2
- package/dist/cli/commands/generate.js.map +1 -1
- package/dist/config/discover.d.ts +4 -0
- package/dist/config/discover.d.ts.map +1 -0
- package/dist/config/discover.js +42 -0
- package/dist/config/discover.js.map +1 -0
- package/dist/config/env-resolve.d.ts +4 -0
- package/dist/config/env-resolve.d.ts.map +1 -0
- package/dist/config/env-resolve.js +71 -0
- package/dist/config/env-resolve.js.map +1 -0
- package/dist/config/env-types.d.ts +42 -0
- package/dist/config/env-types.d.ts.map +1 -0
- package/dist/config/env-types.js +2 -0
- package/dist/config/env-types.js.map +1 -0
- package/dist/config/env.d.ts +2 -0
- package/dist/config/env.d.ts.map +1 -0
- package/dist/config/env.js +48 -0
- package/dist/config/env.js.map +1 -0
- package/dist/config/index.d.ts +8 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +7 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/load.d.ts +34 -0
- package/dist/config/load.d.ts.map +1 -0
- package/dist/config/load.js +113 -0
- package/dist/config/load.js.map +1 -0
- package/dist/config/namespace.d.ts +172 -0
- package/dist/config/namespace.d.ts.map +1 -0
- package/dist/config/namespace.js +14 -0
- package/dist/config/namespace.js.map +1 -0
- package/dist/config/resolve.d.ts +8 -0
- package/dist/config/resolve.d.ts.map +1 -0
- package/dist/config/resolve.js +43 -0
- package/dist/config/resolve.js.map +1 -0
- package/dist/config/schema.d.ts +400 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +106 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/context/create.d.ts +24 -0
- package/dist/context/create.d.ts.map +1 -0
- package/dist/context/create.js +38 -0
- package/dist/context/create.js.map +1 -0
- package/dist/context/guard.d.ts +5 -0
- package/dist/context/guard.d.ts.map +1 -0
- package/dist/context/guard.js +35 -0
- package/dist/context/guard.js.map +1 -0
- package/dist/context/index.d.ts +5 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js +4 -0
- package/dist/context/index.js.map +1 -0
- package/dist/context/store.d.ts +7 -0
- package/dist/context/store.d.ts.map +1 -0
- package/dist/context/store.js +18 -0
- package/dist/context/store.js.map +1 -0
- package/dist/context/types.d.ts +28 -0
- package/dist/context/types.d.ts.map +1 -0
- package/dist/context/types.js +2 -0
- package/dist/context/types.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/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/validation/doctrine.d.ts +13 -0
- package/dist/core/validation/doctrine.d.ts.map +1 -0
- package/dist/core/validation/doctrine.js +115 -0
- package/dist/core/validation/doctrine.js.map +1 -0
- package/dist/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/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 +130 -0
- package/dist/data/domain/project-table.js.map +1 -0
- package/dist/data/migrate/generate.d.ts +1 -1
- package/dist/data/migrate/generate.d.ts.map +1 -1
- package/dist/data/migrate/generate.js +6 -1
- package/dist/data/migrate/generate.js.map +1 -1
- package/dist/data/migrate/internal-definitions.d.ts +5 -0
- package/dist/data/migrate/internal-definitions.d.ts.map +1 -0
- package/dist/data/migrate/internal-definitions.js +28 -0
- package/dist/data/migrate/internal-definitions.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/db/col/index.d.ts +2 -0
- package/dist/db/col/index.d.ts.map +1 -0
- package/dist/db/col/index.js +5 -0
- package/dist/db/col/index.js.map +1 -0
- package/dist/db/context.d.ts +4 -0
- package/dist/db/context.d.ts.map +1 -0
- package/dist/db/context.js +3 -0
- package/dist/db/context.js.map +1 -0
- package/dist/db/db.d.ts +6 -0
- package/dist/db/db.d.ts.map +1 -0
- package/dist/db/db.js +65 -0
- package/dist/db/db.js.map +1 -0
- package/dist/db/filter.d.ts +46 -0
- package/dist/db/filter.d.ts.map +1 -0
- package/dist/db/filter.js +9 -0
- package/dist/db/filter.js.map +1 -0
- package/dist/db/generated/drizzle-orm/aggregate.d.ts +2 -0
- package/dist/db/generated/drizzle-orm/aggregate.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/aggregate.js +5 -0
- package/dist/db/generated/drizzle-orm/aggregate.js.map +1 -0
- package/dist/db/generated/drizzle-orm/introspection.d.ts +2 -0
- package/dist/db/generated/drizzle-orm/introspection.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/introspection.js +5 -0
- package/dist/db/generated/drizzle-orm/introspection.js.map +1 -0
- package/dist/db/generated/drizzle-orm/operator.d.ts +2 -0
- package/dist/db/generated/drizzle-orm/operator.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/operator.js +5 -0
- package/dist/db/generated/drizzle-orm/operator.js.map +1 -0
- package/dist/db/generated/drizzle-orm/relation.d.ts +2 -0
- package/dist/db/generated/drizzle-orm/relation.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/relation.js +5 -0
- package/dist/db/generated/drizzle-orm/relation.js.map +1 -0
- package/dist/db/generated/drizzle-orm/type.d.ts +3 -0
- package/dist/db/generated/drizzle-orm/type.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/type.js +5 -0
- package/dist/db/generated/drizzle-orm/type.js.map +1 -0
- package/dist/db/generated/pg-core/introspection.d.ts +2 -0
- package/dist/db/generated/pg-core/introspection.d.ts.map +1 -0
- package/dist/db/generated/pg-core/introspection.js +5 -0
- package/dist/db/generated/pg-core/introspection.js.map +1 -0
- package/dist/db/generated/pg-core/set-operation.d.ts +2 -0
- package/dist/db/generated/pg-core/set-operation.d.ts.map +1 -0
- package/dist/db/generated/pg-core/set-operation.js +5 -0
- package/dist/db/generated/pg-core/set-operation.js.map +1 -0
- package/dist/db/generated/pg-core/type.d.ts +3 -0
- package/dist/db/generated/pg-core/type.d.ts.map +1 -0
- package/dist/db/generated/pg-core/type.js +5 -0
- package/dist/db/generated/pg-core/type.js.map +1 -0
- package/dist/db/identifiers.d.ts +3 -0
- package/dist/db/identifiers.d.ts.map +1 -0
- package/dist/db/identifiers.js +13 -0
- package/dist/db/identifiers.js.map +1 -0
- package/dist/db/idx/index.d.ts +2 -0
- package/dist/db/idx/index.d.ts.map +1 -0
- package/dist/db/idx/index.js +5 -0
- package/dist/db/idx/index.js.map +1 -0
- package/dist/db/index.d.ts +9 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +7 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/instrumentation.d.ts +5 -0
- package/dist/db/instrumentation.d.ts.map +1 -0
- package/dist/db/instrumentation.js +44 -0
- package/dist/db/instrumentation.js.map +1 -0
- package/dist/db/namespace.d.ts +89 -0
- package/dist/db/namespace.d.ts.map +1 -0
- package/dist/db/namespace.js +30 -0
- package/dist/db/namespace.js.map +1 -0
- package/dist/db/pool.d.ts +17 -0
- package/dist/db/pool.d.ts.map +1 -0
- package/dist/db/pool.js +39 -0
- package/dist/db/pool.js.map +1 -0
- package/dist/db/schema-features.d.ts +2 -0
- package/dist/db/schema-features.d.ts.map +1 -0
- package/dist/db/schema-features.js +4 -0
- package/dist/db/schema-features.js.map +1 -0
- package/dist/db/sql.d.ts +2 -0
- package/dist/db/sql.d.ts.map +1 -0
- package/dist/db/sql.js +2 -0
- package/dist/db/sql.js.map +1 -0
- package/dist/db/types.d.ts +17 -0
- package/dist/db/types.d.ts.map +1 -0
- package/dist/db/types.js +2 -0
- package/dist/db/types.js.map +1 -0
- package/dist/di/builder.d.ts +73 -0
- package/dist/di/builder.d.ts.map +1 -0
- package/dist/di/builder.js +189 -0
- package/dist/di/builder.js.map +1 -0
- package/dist/di/index.d.ts +6 -0
- package/dist/di/index.d.ts.map +1 -0
- package/dist/di/index.js +6 -0
- package/dist/di/index.js.map +1 -0
- package/dist/di/resolve.d.ts +9 -0
- package/dist/di/resolve.d.ts.map +1 -0
- package/dist/di/resolve.js +90 -0
- package/dist/di/resolve.js.map +1 -0
- package/dist/di/types.d.ts +56 -0
- package/dist/di/types.d.ts.map +1 -0
- package/dist/di/types.js +3 -0
- package/dist/di/types.js.map +1 -0
- package/dist/domain/brand.d.ts +19 -0
- package/dist/domain/brand.d.ts.map +1 -0
- package/dist/domain/brand.js +2 -0
- package/dist/domain/brand.js.map +1 -0
- package/dist/domain/define.d.ts +5 -0
- package/dist/domain/define.d.ts.map +1 -0
- package/dist/domain/define.js +155 -0
- package/dist/domain/define.js.map +1 -0
- package/dist/domain/field.d.ts +35 -0
- package/dist/domain/field.d.ts.map +1 -0
- package/dist/domain/field.js +115 -0
- package/dist/domain/field.js.map +1 -0
- package/dist/domain/index.d.ts +8 -0
- package/dist/domain/index.d.ts.map +1 -0
- package/dist/domain/index.js +6 -0
- package/dist/domain/index.js.map +1 -0
- package/dist/domain/naming.d.ts +2 -0
- package/dist/domain/naming.d.ts.map +1 -0
- package/dist/domain/naming.js +7 -0
- package/dist/domain/naming.js.map +1 -0
- package/dist/domain/project-factory.d.ts +4 -0
- package/dist/domain/project-factory.d.ts.map +1 -0
- package/dist/domain/project-factory.js +138 -0
- package/dist/domain/project-factory.js.map +1 -0
- package/dist/domain/project-schema.d.ts +6 -0
- package/dist/domain/project-schema.d.ts.map +1 -0
- package/dist/domain/project-schema.js +123 -0
- package/dist/domain/project-schema.js.map +1 -0
- package/dist/domain/project-table.d.ts +30 -0
- package/dist/domain/project-table.d.ts.map +1 -0
- package/dist/domain/project-table.js +125 -0
- package/dist/domain/project-table.js.map +1 -0
- package/dist/domain/traits.d.ts +9 -0
- package/dist/domain/traits.d.ts.map +1 -0
- package/dist/domain/traits.js +48 -0
- package/dist/domain/traits.js.map +1 -0
- package/dist/domain/types.d.ts +102 -0
- package/dist/domain/types.d.ts.map +1 -0
- package/dist/domain/types.js +2 -0
- package/dist/domain/types.js.map +1 -0
- 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/errors/base.d.ts +7 -0
- package/dist/errors/base.d.ts.map +1 -0
- package/dist/errors/base.js +9 -0
- package/dist/errors/base.js.map +1 -0
- package/dist/errors/index.d.ts +3 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +3 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/errors/namespace.d.ts +17 -0
- package/dist/errors/namespace.d.ts.map +1 -0
- package/dist/errors/namespace.js +17 -0
- package/dist/errors/namespace.js.map +1 -0
- package/dist/errors/types.d.ts +29 -0
- package/dist/errors/types.d.ts.map +1 -0
- package/dist/errors/types.js +46 -0
- package/dist/errors/types.js.map +1 -0
- package/dist/fitting/namespace.d.ts +3 -0
- package/dist/fitting/namespace.d.ts.map +1 -0
- package/dist/fitting/namespace.js +4 -0
- package/dist/fitting/namespace.js.map +1 -0
- package/dist/fixture/batch.d.ts +17 -0
- package/dist/fixture/batch.d.ts.map +1 -0
- package/dist/fixture/batch.js +47 -0
- package/dist/fixture/batch.js.map +1 -0
- package/dist/fixture/builder.d.ts +11 -0
- package/dist/fixture/builder.d.ts.map +1 -0
- package/dist/fixture/builder.js +12 -0
- package/dist/fixture/builder.js.map +1 -0
- package/dist/fixture/errors.d.ts +7 -0
- package/dist/fixture/errors.d.ts.map +1 -0
- package/dist/fixture/errors.js +9 -0
- package/dist/fixture/errors.js.map +1 -0
- package/dist/fixture/index.d.ts +9 -0
- package/dist/fixture/index.d.ts.map +1 -0
- package/dist/fixture/index.js +6 -0
- package/dist/fixture/index.js.map +1 -0
- package/dist/fixture/namespace.d.ts +23 -0
- package/dist/fixture/namespace.d.ts.map +1 -0
- package/dist/fixture/namespace.js +23 -0
- package/dist/fixture/namespace.js.map +1 -0
- package/dist/fixture/paginate.d.ts +13 -0
- package/dist/fixture/paginate.d.ts.map +1 -0
- package/dist/fixture/paginate.js +29 -0
- package/dist/fixture/paginate.js.map +1 -0
- package/dist/fixture/register.d.ts +16 -0
- package/dist/fixture/register.d.ts.map +1 -0
- package/dist/fixture/register.js +181 -0
- package/dist/fixture/register.js.map +1 -0
- package/dist/fixture/to-handlers.d.ts +6 -0
- package/dist/fixture/to-handlers.d.ts.map +1 -0
- package/dist/fixture/to-handlers.js +245 -0
- package/dist/fixture/to-handlers.js.map +1 -0
- package/dist/fixture/types.d.ts +69 -0
- package/dist/fixture/types.d.ts.map +1 -0
- package/dist/fixture/types.js +2 -0
- package/dist/fixture/types.js.map +1 -0
- package/dist/flow/namespace.d.ts +14 -0
- package/dist/flow/namespace.d.ts.map +1 -0
- package/dist/flow/namespace.js +14 -0
- package/dist/flow/namespace.js.map +1 -0
- package/dist/http/index.d.ts +4 -0
- package/dist/http/index.d.ts.map +1 -0
- package/dist/http/index.js +3 -0
- package/dist/http/index.js.map +1 -0
- package/dist/http/middleware.d.ts +20 -0
- package/dist/http/middleware.d.ts.map +1 -0
- package/dist/http/middleware.js +71 -0
- package/dist/http/middleware.js.map +1 -0
- package/dist/http/namespace.d.ts +3 -0
- package/dist/http/namespace.d.ts.map +1 -0
- package/dist/http/namespace.js +3 -0
- package/dist/http/namespace.js.map +1 -0
- package/dist/http/response.d.ts +5 -0
- package/dist/http/response.d.ts.map +1 -0
- package/dist/http/response.js +22 -0
- package/dist/http/response.js.map +1 -0
- package/dist/http/server.d.ts +17 -0
- package/dist/http/server.d.ts.map +1 -0
- package/dist/http/server.js +391 -0
- package/dist/http/server.js.map +1 -0
- package/dist/http/types.d.ts +130 -0
- package/dist/http/types.d.ts.map +1 -0
- package/dist/http/types.js +2 -0
- package/dist/http/types.js.map +1 -0
- package/dist/idempotency/index.d.ts +4 -0
- package/dist/idempotency/index.d.ts.map +1 -0
- package/dist/idempotency/index.js +3 -0
- package/dist/idempotency/index.js.map +1 -0
- package/dist/idempotency/middleware.d.ts +21 -0
- package/dist/idempotency/middleware.d.ts.map +1 -0
- package/dist/idempotency/middleware.js +56 -0
- package/dist/idempotency/middleware.js.map +1 -0
- package/dist/idempotency/store.d.ts +3 -0
- package/dist/idempotency/store.d.ts.map +1 -0
- package/dist/idempotency/store.js +63 -0
- package/dist/idempotency/store.js.map +1 -0
- package/dist/idempotency/types.d.ts +28 -0
- package/dist/idempotency/types.d.ts.map +1 -0
- package/dist/idempotency/types.js +2 -0
- package/dist/idempotency/types.js.map +1 -0
- package/dist/infra/idempotency/store.d.ts.map +1 -1
- package/dist/infra/idempotency/store.js +6 -1
- package/dist/infra/idempotency/store.js.map +1 -1
- package/dist/jobs/cron.d.ts +11 -0
- package/dist/jobs/cron.d.ts.map +1 -0
- package/dist/jobs/cron.js +176 -0
- package/dist/jobs/cron.js.map +1 -0
- package/dist/jobs/execute.d.ts +12 -0
- package/dist/jobs/execute.d.ts.map +1 -0
- package/dist/jobs/execute.js +19 -0
- package/dist/jobs/execute.js.map +1 -0
- package/dist/jobs/index.d.ts +8 -0
- package/dist/jobs/index.d.ts.map +1 -0
- package/dist/jobs/index.js +4 -0
- package/dist/jobs/index.js.map +1 -0
- package/dist/jobs/listener.d.ts +32 -0
- package/dist/jobs/listener.d.ts.map +1 -0
- package/dist/jobs/listener.js +95 -0
- package/dist/jobs/listener.js.map +1 -0
- package/dist/jobs/namespace.d.ts +15 -0
- package/dist/jobs/namespace.d.ts.map +1 -0
- package/dist/jobs/namespace.js +15 -0
- package/dist/jobs/namespace.js.map +1 -0
- package/dist/jobs/queue.d.ts +58 -0
- package/dist/jobs/queue.d.ts.map +1 -0
- package/dist/jobs/queue.js +163 -0
- package/dist/jobs/queue.js.map +1 -0
- package/dist/jobs/scheduler.d.ts +31 -0
- package/dist/jobs/scheduler.d.ts.map +1 -0
- package/dist/jobs/scheduler.js +94 -0
- package/dist/jobs/scheduler.js.map +1 -0
- package/dist/lifecycle/drain.d.ts +7 -0
- package/dist/lifecycle/drain.d.ts.map +1 -0
- package/dist/lifecycle/drain.js +24 -0
- package/dist/lifecycle/drain.js.map +1 -0
- package/dist/lifecycle/health.d.ts +8 -0
- package/dist/lifecycle/health.d.ts.map +1 -0
- package/dist/lifecycle/health.js +62 -0
- package/dist/lifecycle/health.js.map +1 -0
- package/dist/lifecycle/index.d.ts +5 -0
- package/dist/lifecycle/index.d.ts.map +1 -0
- package/dist/lifecycle/index.js +4 -0
- package/dist/lifecycle/index.js.map +1 -0
- package/dist/lifecycle/namespace.d.ts +7 -0
- package/dist/lifecycle/namespace.d.ts.map +1 -0
- package/dist/lifecycle/namespace.js +7 -0
- package/dist/lifecycle/namespace.js.map +1 -0
- package/dist/lifecycle/startup.d.ts +8 -0
- package/dist/lifecycle/startup.d.ts.map +1 -0
- package/dist/lifecycle/startup.js +43 -0
- package/dist/lifecycle/startup.js.map +1 -0
- package/dist/lifecycle/types.d.ts +30 -0
- package/dist/lifecycle/types.d.ts.map +1 -0
- package/dist/lifecycle/types.js +2 -0
- package/dist/lifecycle/types.js.map +1 -0
- package/dist/log/namespace.d.ts +15 -0
- package/dist/log/namespace.d.ts.map +1 -0
- package/dist/log/namespace.js +16 -0
- package/dist/log/namespace.js.map +1 -0
- package/dist/logging/context.d.ts +11 -0
- package/dist/logging/context.d.ts.map +1 -0
- package/dist/logging/context.js +46 -0
- package/dist/logging/context.js.map +1 -0
- package/dist/logging/index.d.ts +4 -0
- package/dist/logging/index.d.ts.map +1 -0
- package/dist/logging/index.js +3 -0
- package/dist/logging/index.js.map +1 -0
- package/dist/logging/logger.d.ts +8 -0
- package/dist/logging/logger.d.ts.map +1 -0
- package/dist/logging/logger.js +39 -0
- package/dist/logging/logger.js.map +1 -0
- package/dist/logging/proxy.d.ts +3 -0
- package/dist/logging/proxy.d.ts.map +1 -0
- package/dist/logging/proxy.js +14 -0
- package/dist/logging/proxy.js.map +1 -0
- package/dist/logging/types.d.ts +36 -0
- package/dist/logging/types.d.ts.map +1 -0
- package/dist/logging/types.js +2 -0
- package/dist/logging/types.js.map +1 -0
- package/dist/migrate/check.d.ts +14 -0
- package/dist/migrate/check.d.ts.map +1 -0
- package/dist/migrate/check.js +58 -0
- package/dist/migrate/check.js.map +1 -0
- package/dist/migrate/generate.d.ts +9 -0
- package/dist/migrate/generate.d.ts.map +1 -0
- package/dist/migrate/generate.js +152 -0
- package/dist/migrate/generate.js.map +1 -0
- package/dist/migrate/index.d.ts +7 -0
- package/dist/migrate/index.d.ts.map +1 -0
- package/dist/migrate/index.js +7 -0
- package/dist/migrate/index.js.map +1 -0
- package/dist/migrate/post-process.d.ts +9 -0
- package/dist/migrate/post-process.d.ts.map +1 -0
- package/dist/migrate/post-process.js +60 -0
- package/dist/migrate/post-process.js.map +1 -0
- package/dist/migrate/rls-generate.d.ts +3 -0
- package/dist/migrate/rls-generate.d.ts.map +1 -0
- package/dist/migrate/rls-generate.js +28 -0
- package/dist/migrate/rls-generate.js.map +1 -0
- package/dist/migrate/run.d.ts +21 -0
- package/dist/migrate/run.d.ts.map +1 -0
- package/dist/migrate/run.js +66 -0
- package/dist/migrate/run.js.map +1 -0
- package/dist/migrate/safety.d.ts +10 -0
- package/dist/migrate/safety.d.ts.map +1 -0
- package/dist/migrate/safety.js +115 -0
- package/dist/migrate/safety.js.map +1 -0
- package/dist/openapi/generate.d.ts +13 -0
- package/dist/openapi/generate.d.ts.map +1 -0
- package/dist/openapi/generate.js +84 -0
- package/dist/openapi/generate.js.map +1 -0
- package/dist/openapi/index.d.ts +3 -0
- package/dist/openapi/index.d.ts.map +1 -0
- package/dist/openapi/index.js +2 -0
- package/dist/openapi/index.js.map +1 -0
- package/dist/openapi/namespace.d.ts +7 -0
- package/dist/openapi/namespace.d.ts.map +1 -0
- package/dist/openapi/namespace.js +7 -0
- package/dist/openapi/namespace.js.map +1 -0
- package/dist/pipeline/define.d.ts +3 -0
- package/dist/pipeline/define.d.ts.map +1 -0
- package/dist/pipeline/define.js +44 -0
- package/dist/pipeline/define.js.map +1 -0
- package/dist/pipeline/errors.d.ts +17 -0
- package/dist/pipeline/errors.d.ts.map +1 -0
- package/dist/pipeline/errors.js +28 -0
- package/dist/pipeline/errors.js.map +1 -0
- package/dist/pipeline/execute.d.ts +4 -0
- package/dist/pipeline/execute.d.ts.map +1 -0
- package/dist/pipeline/execute.js +90 -0
- package/dist/pipeline/execute.js.map +1 -0
- package/dist/pipeline/index.d.ts +4 -0
- package/dist/pipeline/index.d.ts.map +1 -0
- package/dist/pipeline/index.js +3 -0
- package/dist/pipeline/index.js.map +1 -0
- package/dist/pipeline/namespace.d.ts +12 -0
- package/dist/pipeline/namespace.d.ts.map +1 -0
- package/dist/pipeline/namespace.js +12 -0
- package/dist/pipeline/namespace.js.map +1 -0
- package/dist/pipeline/resume.d.ts +4 -0
- package/dist/pipeline/resume.d.ts.map +1 -0
- package/dist/pipeline/resume.js +100 -0
- package/dist/pipeline/resume.js.map +1 -0
- package/dist/pipeline/types.d.ts +50 -0
- package/dist/pipeline/types.d.ts.map +1 -0
- package/dist/pipeline/types.js +2 -0
- package/dist/pipeline/types.js.map +1 -0
- package/dist/pipework.d.ts +88 -0
- package/dist/pipework.d.ts.map +1 -0
- package/dist/pipework.js +222 -0
- package/dist/pipework.js.map +1 -0
- package/dist/rbac/cache.d.ts +13 -0
- package/dist/rbac/cache.d.ts.map +1 -0
- package/dist/rbac/cache.js +43 -0
- package/dist/rbac/cache.js.map +1 -0
- package/dist/rbac/check.d.ts +4 -0
- package/dist/rbac/check.d.ts.map +1 -0
- package/dist/rbac/check.js +20 -0
- package/dist/rbac/check.js.map +1 -0
- package/dist/rbac/index.d.ts +8 -0
- package/dist/rbac/index.d.ts.map +1 -0
- package/dist/rbac/index.js +32 -0
- package/dist/rbac/index.js.map +1 -0
- package/dist/rbac/middleware.d.ts +4 -0
- package/dist/rbac/middleware.d.ts.map +1 -0
- package/dist/rbac/middleware.js +9 -0
- package/dist/rbac/middleware.js.map +1 -0
- package/dist/rbac/namespace.d.ts +15 -0
- package/dist/rbac/namespace.d.ts.map +1 -0
- package/dist/rbac/namespace.js +15 -0
- package/dist/rbac/namespace.js.map +1 -0
- package/dist/rbac/resolve.d.ts +4 -0
- package/dist/rbac/resolve.d.ts.map +1 -0
- package/dist/rbac/resolve.js +24 -0
- package/dist/rbac/resolve.js.map +1 -0
- package/dist/rbac/seed.d.ts +4 -0
- package/dist/rbac/seed.d.ts.map +1 -0
- package/dist/rbac/seed.js +63 -0
- package/dist/rbac/seed.js.map +1 -0
- package/dist/rbac/types.d.ts +56 -0
- package/dist/rbac/types.d.ts.map +1 -0
- package/dist/rbac/types.js +2 -0
- package/dist/rbac/types.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/schema/branded.d.ts +3 -0
- package/dist/schema/branded.d.ts.map +1 -0
- package/dist/schema/branded.js +8 -0
- package/dist/schema/branded.js.map +1 -0
- package/dist/schema/generated/coerce.d.ts +2 -0
- package/dist/schema/generated/coerce.d.ts.map +1 -0
- package/dist/schema/generated/coerce.js +5 -0
- package/dist/schema/generated/coerce.js.map +1 -0
- package/dist/schema/generated/combinator.d.ts +3 -0
- package/dist/schema/generated/combinator.d.ts.map +1 -0
- package/dist/schema/generated/combinator.js +5 -0
- package/dist/schema/generated/combinator.js.map +1 -0
- package/dist/schema/generated/encoding.d.ts +2 -0
- package/dist/schema/generated/encoding.d.ts.map +1 -0
- package/dist/schema/generated/encoding.js +5 -0
- package/dist/schema/generated/encoding.js.map +1 -0
- package/dist/schema/generated/error.d.ts +3 -0
- package/dist/schema/generated/error.d.ts.map +1 -0
- package/dist/schema/generated/error.js +5 -0
- package/dist/schema/generated/error.js.map +1 -0
- package/dist/schema/generated/format.d.ts +2 -0
- package/dist/schema/generated/format.d.ts.map +1 -0
- package/dist/schema/generated/format.js +5 -0
- package/dist/schema/generated/format.js.map +1 -0
- package/dist/schema/generated/type-constructor.d.ts +3 -0
- package/dist/schema/generated/type-constructor.d.ts.map +1 -0
- package/dist/schema/generated/type-constructor.js +8 -0
- package/dist/schema/generated/type-constructor.js.map +1 -0
- package/dist/schema/generated/type.d.ts +3 -0
- package/dist/schema/generated/type.d.ts.map +1 -0
- package/dist/schema/generated/type.js +5 -0
- package/dist/schema/generated/type.js.map +1 -0
- package/dist/schema/index.d.ts +6 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +5 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/json-schema.d.ts +5 -0
- package/dist/schema/json-schema.d.ts.map +1 -0
- package/dist/schema/json-schema.js +5 -0
- package/dist/schema/json-schema.js.map +1 -0
- package/dist/schema/namespace.d.ts +139 -0
- package/dist/schema/namespace.d.ts.map +1 -0
- package/dist/schema/namespace.js +46 -0
- package/dist/schema/namespace.js.map +1 -0
- package/dist/schema/parse.d.ts +11 -0
- package/dist/schema/parse.d.ts.map +1 -0
- package/dist/schema/parse.js +30 -0
- package/dist/schema/parse.js.map +1 -0
- package/dist/schema/types.d.ts +6 -0
- package/dist/schema/types.d.ts.map +1 -0
- package/dist/schema/types.js +2 -0
- package/dist/schema/types.js.map +1 -0
- package/dist/state-machine/define.d.ts +3 -0
- package/dist/state-machine/define.d.ts.map +1 -0
- package/dist/state-machine/define.js +46 -0
- package/dist/state-machine/define.js.map +1 -0
- package/dist/state-machine/errors.d.ts +12 -0
- package/dist/state-machine/errors.d.ts.map +1 -0
- package/dist/state-machine/errors.js +19 -0
- package/dist/state-machine/errors.js.map +1 -0
- package/dist/state-machine/index.d.ts +4 -0
- package/dist/state-machine/index.d.ts.map +1 -0
- package/dist/state-machine/index.js +3 -0
- package/dist/state-machine/index.js.map +1 -0
- package/dist/state-machine/namespace.d.ts +12 -0
- package/dist/state-machine/namespace.d.ts.map +1 -0
- package/dist/state-machine/namespace.js +12 -0
- package/dist/state-machine/namespace.js.map +1 -0
- package/dist/state-machine/transition.d.ts +7 -0
- package/dist/state-machine/transition.d.ts.map +1 -0
- package/dist/state-machine/transition.js +57 -0
- package/dist/state-machine/transition.js.map +1 -0
- package/dist/state-machine/types.d.ts +33 -0
- package/dist/state-machine/types.d.ts.map +1 -0
- package/dist/state-machine/types.js +2 -0
- package/dist/state-machine/types.js.map +1 -0
- package/dist/surface/http.d.ts +3 -0
- package/dist/surface/http.d.ts.map +1 -0
- package/dist/surface/http.js +84 -0
- package/dist/surface/http.js.map +1 -0
- package/dist/surface/index.d.ts +7 -0
- package/dist/surface/index.d.ts.map +1 -0
- package/dist/surface/index.js +6 -0
- package/dist/surface/index.js.map +1 -0
- package/dist/surface/namespace.d.ts +13 -0
- package/dist/surface/namespace.d.ts.map +1 -0
- package/dist/surface/namespace.js +13 -0
- package/dist/surface/namespace.js.map +1 -0
- package/dist/surface/script.d.ts +3 -0
- package/dist/surface/script.d.ts.map +1 -0
- package/dist/surface/script.js +24 -0
- package/dist/surface/script.js.map +1 -0
- package/dist/surface/start.d.ts +8 -0
- package/dist/surface/start.d.ts.map +1 -0
- package/dist/surface/start.js +64 -0
- package/dist/surface/start.js.map +1 -0
- package/dist/surface/types.d.ts +111 -0
- package/dist/surface/types.d.ts.map +1 -0
- package/dist/surface/types.js +2 -0
- package/dist/surface/types.js.map +1 -0
- package/dist/surface/validate.d.ts +7 -0
- package/dist/surface/validate.d.ts.map +1 -0
- package/dist/surface/validate.js +121 -0
- package/dist/surface/validate.js.map +1 -0
- package/dist/surface/worker.d.ts +3 -0
- package/dist/surface/worker.d.ts.map +1 -0
- package/dist/surface/worker.js +151 -0
- package/dist/surface/worker.js.map +1 -0
- package/dist/temporal/close.d.ts +3 -0
- package/dist/temporal/close.d.ts.map +1 -0
- package/dist/temporal/close.js +19 -0
- package/dist/temporal/close.js.map +1 -0
- package/dist/temporal/columns.d.ts +7 -0
- package/dist/temporal/columns.d.ts.map +1 -0
- package/dist/temporal/columns.js +10 -0
- package/dist/temporal/columns.js.map +1 -0
- package/dist/temporal/definition-queries.d.ts +14 -0
- package/dist/temporal/definition-queries.d.ts.map +1 -0
- package/dist/temporal/definition-queries.js +45 -0
- package/dist/temporal/definition-queries.js.map +1 -0
- package/dist/temporal/errors.d.ts +7 -0
- package/dist/temporal/errors.d.ts.map +1 -0
- package/dist/temporal/errors.js +9 -0
- package/dist/temporal/errors.js.map +1 -0
- package/dist/temporal/get-current.d.ts +3 -0
- package/dist/temporal/get-current.d.ts.map +1 -0
- package/dist/temporal/get-current.js +18 -0
- package/dist/temporal/get-current.js.map +1 -0
- package/dist/temporal/index.d.ts +9 -0
- package/dist/temporal/index.d.ts.map +1 -0
- package/dist/temporal/index.js +8 -0
- package/dist/temporal/index.js.map +1 -0
- package/dist/temporal/namespace.d.ts +31 -0
- package/dist/temporal/namespace.d.ts.map +1 -0
- package/dist/temporal/namespace.js +31 -0
- package/dist/temporal/namespace.js.map +1 -0
- package/dist/temporal/query.d.ts +10 -0
- package/dist/temporal/query.d.ts.map +1 -0
- package/dist/temporal/query.js +11 -0
- package/dist/temporal/query.js.map +1 -0
- package/dist/temporal/revise.d.ts +3 -0
- package/dist/temporal/revise.d.ts.map +1 -0
- package/dist/temporal/revise.js +52 -0
- package/dist/temporal/revise.js.map +1 -0
- package/dist/temporal/types.d.ts +19 -0
- package/dist/temporal/types.d.ts.map +1 -0
- package/dist/temporal/types.js +2 -0
- package/dist/temporal/types.js.map +1 -0
- package/dist/tenant/extract.d.ts +6 -0
- package/dist/tenant/extract.d.ts.map +1 -0
- package/dist/tenant/extract.js +18 -0
- package/dist/tenant/extract.js.map +1 -0
- package/dist/tenant/index.d.ts +8 -0
- package/dist/tenant/index.d.ts.map +1 -0
- package/dist/tenant/index.js +7 -0
- package/dist/tenant/index.js.map +1 -0
- package/dist/tenant/namespace.d.ts +23 -0
- package/dist/tenant/namespace.d.ts.map +1 -0
- package/dist/tenant/namespace.js +23 -0
- package/dist/tenant/namespace.js.map +1 -0
- package/dist/tenant/propagate.d.ts +4 -0
- package/dist/tenant/propagate.d.ts.map +1 -0
- package/dist/tenant/propagate.js +15 -0
- package/dist/tenant/propagate.js.map +1 -0
- package/dist/tenant/rls.d.ts +5 -0
- package/dist/tenant/rls.d.ts.map +1 -0
- package/dist/tenant/rls.js +35 -0
- package/dist/tenant/rls.js.map +1 -0
- package/dist/tenant/scope.d.ts +8 -0
- package/dist/tenant/scope.d.ts.map +1 -0
- package/dist/tenant/scope.js +21 -0
- package/dist/tenant/scope.js.map +1 -0
- package/dist/tenant/scoped-db.d.ts +4 -0
- package/dist/tenant/scoped-db.d.ts.map +1 -0
- package/dist/tenant/scoped-db.js +234 -0
- package/dist/tenant/scoped-db.js.map +1 -0
- package/dist/tenant/types.d.ts +14 -0
- package/dist/tenant/types.d.ts.map +1 -0
- package/dist/tenant/types.js +2 -0
- package/dist/tenant/types.js.map +1 -0
- package/dist/tenant/validate.d.ts +4 -0
- package/dist/tenant/validate.d.ts.map +1 -0
- package/dist/tenant/validate.js +20 -0
- package/dist/tenant/validate.js.map +1 -0
- package/dist/test/vitest-config.d.ts +21 -0
- package/dist/test/vitest-config.d.ts.map +1 -0
- package/dist/test/vitest-config.js +47 -0
- package/dist/test/vitest-config.js.map +1 -0
- 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/connectivity.d.ts +4 -0
- package/dist/validation/connectivity.d.ts.map +1 -0
- package/dist/validation/connectivity.js +32 -0
- package/dist/validation/connectivity.js.map +1 -0
- package/dist/validation/domain.d.ts +4 -0
- package/dist/validation/domain.d.ts.map +1 -0
- package/dist/validation/domain.js +72 -0
- package/dist/validation/domain.js.map +1 -0
- package/dist/validation/index.d.ts +6 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +6 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/startup.d.ts +12 -0
- package/dist/validation/startup.d.ts.map +1 -0
- package/dist/validation/startup.js +19 -0
- package/dist/validation/startup.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/validation/types.d.ts +13 -0
- package/dist/validation/types.d.ts.map +1 -0
- package/dist/validation/types.js +13 -0
- package/dist/validation/types.js.map +1 -0
- package/dist/vector/index.d.ts +4 -0
- package/dist/vector/index.d.ts.map +1 -0
- package/dist/vector/index.js +4 -0
- package/dist/vector/index.js.map +1 -0
- package/dist/vector/namespace.d.ts +27 -0
- package/dist/vector/namespace.d.ts.map +1 -0
- package/dist/vector/namespace.js +27 -0
- package/dist/vector/namespace.js.map +1 -0
- package/dist/vector/query.d.ts +9 -0
- package/dist/vector/query.d.ts.map +1 -0
- package/dist/vector/query.js +33 -0
- package/dist/vector/query.js.map +1 -0
- package/dist/vector/types.d.ts +19 -0
- package/dist/vector/types.d.ts.map +1 -0
- package/dist/vector/types.js +26 -0
- package/dist/vector/types.js.map +1 -0
- package/dist/vector/validate.d.ts +3 -0
- package/dist/vector/validate.d.ts.map +1 -0
- package/dist/vector/validate.js +10 -0
- package/dist/vector/validate.js.map +1 -0
- package/dist/webhook/inbound.d.ts +16 -0
- package/dist/webhook/inbound.d.ts.map +1 -0
- package/dist/webhook/inbound.js +21 -0
- package/dist/webhook/inbound.js.map +1 -0
- package/dist/webhook/index.d.ts +5 -0
- package/dist/webhook/index.d.ts.map +1 -0
- package/dist/webhook/index.js +5 -0
- package/dist/webhook/index.js.map +1 -0
- package/dist/webhook/namespace.d.ts +22 -0
- package/dist/webhook/namespace.d.ts.map +1 -0
- package/dist/webhook/namespace.js +22 -0
- package/dist/webhook/namespace.js.map +1 -0
- package/dist/webhook/outbound.d.ts +48 -0
- package/dist/webhook/outbound.d.ts.map +1 -0
- package/dist/webhook/outbound.js +160 -0
- package/dist/webhook/outbound.js.map +1 -0
- package/dist/webhook/sign.d.ts +12 -0
- package/dist/webhook/sign.d.ts.map +1 -0
- package/dist/webhook/sign.js +12 -0
- package/dist/webhook/sign.js.map +1 -0
- package/dist/webhook/verify.d.ts +14 -0
- package/dist/webhook/verify.d.ts.map +1 -0
- package/dist/webhook/verify.js +61 -0
- package/dist/webhook/verify.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { migrateAll, migrateOne, UnsafeMigrationError, type MigrateResult, type MigrateOptions } from './run.js';
|
|
2
|
+
export { checkMigrations, formatCheckResult, type MigrationCheckResult, type MigrationHazard, type Severity } from './check.js';
|
|
3
|
+
export { analyzeSQL } from './safety.js';
|
|
4
|
+
export { generateForDatabase, type GenerateResult } from './generate.js';
|
|
5
|
+
export { postProcessMigration } from './post-process.js';
|
|
6
|
+
export { generateRlsStatements } from './rls-generate.js';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/migrate/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,oBAAoB,EAAE,KAAK,aAAa,EAAE,KAAK,cAAc,EAAE,MAAM,UAAU,CAAA;AAChH,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAE,KAAK,oBAAoB,EAAE,KAAK,eAAe,EAAE,KAAK,QAAQ,EAAE,MAAM,YAAY,CAAA;AAC/H,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AACxC,OAAO,EAAE,mBAAmB,EAAE,KAAK,cAAc,EAAE,MAAM,eAAe,CAAA;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAA;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { migrateAll, migrateOne, UnsafeMigrationError } from './run.js';
|
|
2
|
+
export { checkMigrations, formatCheckResult } from './check.js';
|
|
3
|
+
export { analyzeSQL } from './safety.js';
|
|
4
|
+
export { generateForDatabase } from './generate.js';
|
|
5
|
+
export { postProcessMigration } from './post-process.js';
|
|
6
|
+
export { generateRlsStatements } from './rls-generate.js';
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/migrate/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,oBAAoB,EAA2C,MAAM,UAAU,CAAA;AAChH,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAkE,MAAM,YAAY,CAAA;AAC/H,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AACxC,OAAO,EAAE,mBAAmB,EAAuB,MAAM,eAAe,CAAA;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAA;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Transform unsafe drizzle-kit migration SQL into safe SQL.
|
|
3
|
+
*
|
|
4
|
+
* Two transforms are applied:
|
|
5
|
+
* 1. `CREATE INDEX` → `CREATE INDEX CONCURRENTLY` (with `-- pipework:no-transaction` pragma)
|
|
6
|
+
* 2. `ADD CONSTRAINT ... FOREIGN KEY` → appends `NOT VALID`, emits `VALIDATE CONSTRAINT`
|
|
7
|
+
*/
|
|
8
|
+
export declare function postProcessMigration(sql: string): string;
|
|
9
|
+
//# sourceMappingURL=post-process.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"post-process.d.ts","sourceRoot":"","sources":["../../src/migrate/post-process.ts"],"names":[],"mappings":"AAQA;;;;;;GAMG;AACH,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CA4DxD"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
const CREATE_INDEX_RE = /\bCREATE\s+(UNIQUE\s+)?INDEX\b(?!\s+CONCURRENTLY)/i;
|
|
2
|
+
const CONCURRENTLY_RE = /\bCONCURRENTLY\b/i;
|
|
3
|
+
const FK_RE = /\bADD\s+CONSTRAINT\b[^;]*\bFOREIGN\s+KEY\b(?![^;]*\bNOT\s+VALID\b)/i;
|
|
4
|
+
const ALTER_TABLE_NAME_RE = /\bALTER\s+TABLE\s+(?:ONLY\s+)?((?:"(?:[^"]+)"\.)*"(?:[^"]+)"|[^\s(]+(?:\.[^\s(]+)*)/i;
|
|
5
|
+
const ADD_CONSTRAINT_NAME_RE = /\bADD\s+CONSTRAINT\s+("(?:[^"]+)"|[^\s(]+)/i;
|
|
6
|
+
const NO_TRANSACTION_PRAGMA = '-- pipework:no-transaction';
|
|
7
|
+
/**
|
|
8
|
+
* Transform unsafe drizzle-kit migration SQL into safe SQL.
|
|
9
|
+
*
|
|
10
|
+
* Two transforms are applied:
|
|
11
|
+
* 1. `CREATE INDEX` → `CREATE INDEX CONCURRENTLY` (with `-- pipework:no-transaction` pragma)
|
|
12
|
+
* 2. `ADD CONSTRAINT ... FOREIGN KEY` → appends `NOT VALID`, emits `VALIDATE CONSTRAINT`
|
|
13
|
+
*/
|
|
14
|
+
export function postProcessMigration(sql) {
|
|
15
|
+
const parts = sql.split(';');
|
|
16
|
+
const trailing = parts[parts.length - 1];
|
|
17
|
+
const rawStatements = parts.slice(0, -1);
|
|
18
|
+
const outputStatements = [];
|
|
19
|
+
let hasConcurrently = false;
|
|
20
|
+
for (const raw of rawStatements) {
|
|
21
|
+
const trimmed = raw.trim();
|
|
22
|
+
if (trimmed.length === 0 || trimmed.startsWith('--')) {
|
|
23
|
+
outputStatements.push(raw);
|
|
24
|
+
continue;
|
|
25
|
+
}
|
|
26
|
+
if (CREATE_INDEX_RE.test(trimmed)) {
|
|
27
|
+
const rewritten = raw.replace(/\b(CREATE\s+(?:UNIQUE\s+)?)(INDEX)\b/i, '$1$2 CONCURRENTLY');
|
|
28
|
+
outputStatements.push(rewritten);
|
|
29
|
+
hasConcurrently = true;
|
|
30
|
+
continue;
|
|
31
|
+
}
|
|
32
|
+
if (CONCURRENTLY_RE.test(trimmed)) {
|
|
33
|
+
hasConcurrently = true;
|
|
34
|
+
}
|
|
35
|
+
if (FK_RE.test(trimmed)) {
|
|
36
|
+
const tableMatch = ALTER_TABLE_NAME_RE.exec(trimmed);
|
|
37
|
+
const constraintMatch = ADD_CONSTRAINT_NAME_RE.exec(trimmed);
|
|
38
|
+
if (tableMatch !== null && constraintMatch !== null) {
|
|
39
|
+
const tableName = tableMatch[1];
|
|
40
|
+
const constraintName = constraintMatch[1];
|
|
41
|
+
const withNotValid = raw.replace(/\s*$/, ' NOT VALID');
|
|
42
|
+
outputStatements.push(withNotValid);
|
|
43
|
+
outputStatements.push(`\nALTER TABLE ${tableName} VALIDATE CONSTRAINT ${constraintName}`);
|
|
44
|
+
continue;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
outputStatements.push(raw);
|
|
48
|
+
}
|
|
49
|
+
let result = outputStatements.join(';') + ';';
|
|
50
|
+
if (trailing !== undefined && trailing.trim().length > 0) {
|
|
51
|
+
result += trailing;
|
|
52
|
+
}
|
|
53
|
+
if (hasConcurrently) {
|
|
54
|
+
result = result.startsWith(NO_TRANSACTION_PRAGMA)
|
|
55
|
+
? result
|
|
56
|
+
: `${NO_TRANSACTION_PRAGMA}\n${result}`;
|
|
57
|
+
}
|
|
58
|
+
return result;
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=post-process.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"post-process.js","sourceRoot":"","sources":["../../src/migrate/post-process.ts"],"names":[],"mappings":"AAAA,MAAM,eAAe,GAAG,oDAAoD,CAAA;AAC5E,MAAM,eAAe,GAAG,mBAAmB,CAAA;AAC3C,MAAM,KAAK,GAAG,qEAAqE,CAAA;AACnF,MAAM,mBAAmB,GAAG,sFAAsF,CAAA;AAClH,MAAM,sBAAsB,GAAG,6CAA6C,CAAA;AAE5E,MAAM,qBAAqB,GAAG,4BAA4B,CAAA;AAE1D;;;;;;GAMG;AACH,MAAM,UAAU,oBAAoB,CAAC,GAAW;IAC9C,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IAC5B,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;IACxC,MAAM,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IAExC,MAAM,gBAAgB,GAAa,EAAE,CAAA;IACrC,IAAI,eAAe,GAAG,KAAK,CAAA;IAE3B,KAAK,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;QAChC,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,EAAE,CAAA;QAC1B,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACrD,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YAC1B,SAAQ;QACV,CAAC;QAED,IAAI,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAC3B,uCAAuC,EACvC,mBAAmB,CACpB,CAAA;YACD,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAChC,eAAe,GAAG,IAAI,CAAA;YACtB,SAAQ;QACV,CAAC;QAED,IAAI,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,eAAe,GAAG,IAAI,CAAA;QACxB,CAAC;QAED,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YACxB,MAAM,UAAU,GAAG,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YACpD,MAAM,eAAe,GAAG,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YAE5D,IAAI,UAAU,KAAK,IAAI,IAAI,eAAe,KAAK,IAAI,EAAE,CAAC;gBACpD,MAAM,SAAS,GAAG,UAAU,CAAC,CAAC,CAAE,CAAA;gBAChC,MAAM,cAAc,GAAG,eAAe,CAAC,CAAC,CAAE,CAAA;gBAE1C,MAAM,YAAY,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,YAAY,CAAC,CAAA;gBACtD,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;gBACnC,gBAAgB,CAAC,IAAI,CAAC,iBAAiB,SAAS,wBAAwB,cAAc,EAAE,CAAC,CAAA;gBACzF,SAAQ;YACV,CAAC;QACH,CAAC;QAED,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IAC5B,CAAC;IAED,IAAI,MAAM,GAAG,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAA;IAE7C,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACzD,MAAM,IAAI,QAAQ,CAAA;IACpB,CAAC;IAED,IAAI,eAAe,EAAE,CAAC;QACpB,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,qBAAqB,CAAC;YAC/C,CAAC,CAAC,MAAM;YACR,CAAC,CAAC,GAAG,qBAAqB,KAAK,MAAM,EAAE,CAAA;IAC3C,CAAC;IAED,OAAO,MAAM,CAAA;AACf,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rls-generate.d.ts","sourceRoot":"","sources":["../../src/migrate/rls-generate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAA;AAMtD,wBAAgB,qBAAqB,CACnC,YAAY,EAAE,MAAM,EACpB,WAAW,EAAE,WAAW,CAAC,MAAM,EAAE,YAAY,CAAC,EAC9C,UAAU,EAAE,MAAM,GACjB,MAAM,CA6BR"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { camelToSnake } from '../domain/naming.js';
|
|
2
|
+
import { tenantIsolationPolicy } from '../tenant/rls.js';
|
|
3
|
+
const CREATE_TABLE_RE = /CREATE\s+TABLE\s+(?:IF\s+NOT\s+EXISTS\s+)?(?:"([^"]+)"|([a-z_][a-z0-9_]*))/gi;
|
|
4
|
+
export function generateRlsStatements(migrationSql, definitions, sessionVar) {
|
|
5
|
+
const rlsBlocks = [];
|
|
6
|
+
let match;
|
|
7
|
+
while ((match = CREATE_TABLE_RE.exec(migrationSql)) !== null) {
|
|
8
|
+
const tableName = match[1] ?? match[2];
|
|
9
|
+
if (tableName === undefined)
|
|
10
|
+
continue;
|
|
11
|
+
const definition = definitions.get(tableName);
|
|
12
|
+
if (definition === undefined)
|
|
13
|
+
continue;
|
|
14
|
+
const tenantFieldKey = Object.keys(definition.$fields).find((key) => definition.$fields[key]._meta.tenant === true);
|
|
15
|
+
if (tenantFieldKey === undefined)
|
|
16
|
+
continue;
|
|
17
|
+
const columnName = camelToSnake(tenantFieldKey);
|
|
18
|
+
if (migrationSql.includes(`"${tableName}" ENABLE ROW LEVEL SECURITY`) ||
|
|
19
|
+
migrationSql.includes(`${tableName} ENABLE ROW LEVEL SECURITY`)) {
|
|
20
|
+
continue;
|
|
21
|
+
}
|
|
22
|
+
rlsBlocks.push(tenantIsolationPolicy(tableName, columnName, sessionVar));
|
|
23
|
+
}
|
|
24
|
+
if (rlsBlocks.length === 0)
|
|
25
|
+
return migrationSql;
|
|
26
|
+
return migrationSql + ';\n\n' + rlsBlocks.join(';\n\n');
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=rls-generate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rls-generate.js","sourceRoot":"","sources":["../../src/migrate/rls-generate.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAClD,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAExD,MAAM,eAAe,GAAG,8EAA8E,CAAA;AAEtG,MAAM,UAAU,qBAAqB,CACnC,YAAoB,EACpB,WAA8C,EAC9C,UAAkB;IAElB,MAAM,SAAS,GAAa,EAAE,CAAA;IAC9B,IAAI,KAA6B,CAAA;IAEjC,OAAO,CAAC,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;QAC7D,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,CAAA;QACtC,IAAI,SAAS,KAAK,SAAS;YAAE,SAAQ;QAErC,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;QAC7C,IAAI,UAAU,KAAK,SAAS;YAAE,SAAQ;QAEtC,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI,CACzD,CAAC,GAAG,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAE,CAAC,KAAK,CAAC,MAAM,KAAK,IAAI,CACxD,CAAA;QACD,IAAI,cAAc,KAAK,SAAS;YAAE,SAAQ;QAE1C,MAAM,UAAU,GAAG,YAAY,CAAC,cAAc,CAAC,CAAA;QAE/C,IAAI,YAAY,CAAC,QAAQ,CAAC,IAAI,SAAS,6BAA6B,CAAC;YACjE,YAAY,CAAC,QAAQ,CAAC,GAAG,SAAS,4BAA4B,CAAC,EAAE,CAAC;YACpE,SAAQ;QACV,CAAC;QAED,SAAS,CAAC,IAAI,CAAC,qBAAqB,CAAC,SAAS,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC,CAAA;IAC1E,CAAC;IAED,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,YAAY,CAAA;IAE/C,OAAO,YAAY,GAAG,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;AACzD,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { Manifold } from '../pipework.js';
|
|
2
|
+
import type { ResolvedDatabase } from '../config/index.js';
|
|
3
|
+
import { type MigrationCheckResult } from './check.js';
|
|
4
|
+
export interface MigrateOptions {
|
|
5
|
+
allowDestructive?: boolean;
|
|
6
|
+
acknowledgeLock?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export interface MigrateResult {
|
|
9
|
+
database: string;
|
|
10
|
+
migrationsRun: number;
|
|
11
|
+
extensions: string[];
|
|
12
|
+
safetyCheck: MigrationCheckResult;
|
|
13
|
+
}
|
|
14
|
+
export declare class UnsafeMigrationError extends Error {
|
|
15
|
+
readonly check: MigrationCheckResult;
|
|
16
|
+
readonly name = "UnsafeMigrationError";
|
|
17
|
+
constructor(check: MigrationCheckResult, message: string);
|
|
18
|
+
}
|
|
19
|
+
export declare function migrateAll(instance: Manifold, options?: MigrateOptions): Promise<MigrateResult[]>;
|
|
20
|
+
export declare function migrateOne(instance: Manifold, dbConfig: ResolvedDatabase, options?: MigrateOptions): Promise<MigrateResult>;
|
|
21
|
+
//# sourceMappingURL=run.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../src/migrate/run.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAC9C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAE1D,OAAO,EAAmB,KAAK,oBAAoB,EAAE,MAAM,YAAY,CAAA;AAEvE,MAAM,WAAW,cAAc;IAC7B,gBAAgB,CAAC,EAAE,OAAO,CAAA;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAA;CAC1B;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,EAAE,MAAM,CAAA;IAChB,aAAa,EAAE,MAAM,CAAA;IACrB,UAAU,EAAE,MAAM,EAAE,CAAA;IACpB,WAAW,EAAE,oBAAoB,CAAA;CAClC;AAED,qBAAa,oBAAqB,SAAQ,KAAK;aAG3B,KAAK,EAAE,oBAAoB;IAF7C,SAAkB,IAAI,0BAAyB;gBAE7B,KAAK,EAAE,oBAAoB,EAC3C,OAAO,EAAE,MAAM;CAIlB;AAED,wBAAsB,UAAU,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,GAAE,cAAmB,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAU3G;AAED,wBAAsB,UAAU,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,gBAAgB,EAAE,OAAO,GAAE,cAAmB,GAAG,OAAO,CAAC,aAAa,CAAC,CA8CrI"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { migrate as drizzleMigrate } from 'drizzle-orm/postgres-js/migrator';
|
|
2
|
+
import { sql } from 'drizzle-orm';
|
|
3
|
+
import { quoteIdentifier } from '../db/identifiers.js';
|
|
4
|
+
import { checkMigrations } from './check.js';
|
|
5
|
+
export class UnsafeMigrationError extends Error {
|
|
6
|
+
check;
|
|
7
|
+
name = 'UnsafeMigrationError';
|
|
8
|
+
constructor(check, message) {
|
|
9
|
+
super(message);
|
|
10
|
+
this.check = check;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export async function migrateAll(instance, options = {}) {
|
|
14
|
+
const results = [];
|
|
15
|
+
for (const [, dbConfig] of instance.config.databases()) {
|
|
16
|
+
if (dbConfig.migrations === undefined)
|
|
17
|
+
continue;
|
|
18
|
+
const result = await migrateOne(instance, dbConfig, options);
|
|
19
|
+
results.push(result);
|
|
20
|
+
}
|
|
21
|
+
return results;
|
|
22
|
+
}
|
|
23
|
+
export async function migrateOne(instance, dbConfig, options = {}) {
|
|
24
|
+
const safetyCheck = dbConfig.migrations !== undefined
|
|
25
|
+
? checkMigrations(dbConfig.migrations)
|
|
26
|
+
: { safe: true, hasDestructive: false, hasLocking: false, fileHazards: [] };
|
|
27
|
+
if (safetyCheck.hasDestructive && options.allowDestructive !== true) {
|
|
28
|
+
throw new UnsafeMigrationError(safetyCheck, `Migration for "${dbConfig.name}" contains destructive operations (DROP TABLE, DROP COLUMN, etc.). ` +
|
|
29
|
+
`Pass { allowDestructive: true } or use --allow-destructive on the CLI to proceed.`);
|
|
30
|
+
}
|
|
31
|
+
if (safetyCheck.hasLocking && options.acknowledgeLock !== true) {
|
|
32
|
+
throw new UnsafeMigrationError(safetyCheck, `Migration for "${dbConfig.name}" contains operations that acquire heavy locks. ` +
|
|
33
|
+
`Pass { acknowledgeLock: true } or use --acknowledge-lock on the CLI to proceed.`);
|
|
34
|
+
}
|
|
35
|
+
const conn = instance.pool.getOrCreate(dbConfig);
|
|
36
|
+
let extensionsCreated = [];
|
|
37
|
+
if (dbConfig.extensions.length > 0) {
|
|
38
|
+
for (const ext of dbConfig.extensions) {
|
|
39
|
+
await conn.drizzle.execute(sql.raw(`CREATE EXTENSION IF NOT EXISTS ${quoteIdentifier(ext, 'extension')}`));
|
|
40
|
+
}
|
|
41
|
+
extensionsCreated = [...dbConfig.extensions];
|
|
42
|
+
}
|
|
43
|
+
const beforeTables = await getMigrationCount(conn.drizzle, dbConfig.migrationTable);
|
|
44
|
+
await drizzleMigrate(conn.drizzle, {
|
|
45
|
+
migrationsFolder: dbConfig.migrations,
|
|
46
|
+
migrationsTable: dbConfig.migrationTable,
|
|
47
|
+
});
|
|
48
|
+
const afterTables = await getMigrationCount(conn.drizzle, dbConfig.migrationTable);
|
|
49
|
+
return {
|
|
50
|
+
database: dbConfig.name,
|
|
51
|
+
migrationsRun: afterTables - beforeTables,
|
|
52
|
+
extensions: extensionsCreated,
|
|
53
|
+
safetyCheck,
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
async function getMigrationCount(db, table) {
|
|
57
|
+
try {
|
|
58
|
+
const result = await db.execute(sql.raw(`SELECT count(*)::int as count FROM ${quoteIdentifier(table, 'migration table')}`));
|
|
59
|
+
const row = result[0];
|
|
60
|
+
return row?.count ?? 0;
|
|
61
|
+
}
|
|
62
|
+
catch {
|
|
63
|
+
return 0;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=run.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../src/migrate/run.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export type Severity = 'destructive' | 'locking' | 'safe';
|
|
2
|
+
export interface MigrationHazard {
|
|
3
|
+
severity: Severity;
|
|
4
|
+
operation: string;
|
|
5
|
+
statement: string;
|
|
6
|
+
suggestion: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function analyzeSQL(sql: string): MigrationHazard[];
|
|
9
|
+
export declare function formatHazards(hazards: MigrationHazard[], file: string): string;
|
|
10
|
+
//# sourceMappingURL=safety.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"safety.d.ts","sourceRoot":"","sources":["../../src/migrate/safety.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,aAAa,GAAG,SAAS,GAAG,MAAM,CAAA;AAEzD,MAAM,WAAW,eAAe;IAC9B,QAAQ,EAAE,QAAQ,CAAA;IAClB,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,EAAE,MAAM,CAAA;CACnB;AA8ED,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,EAAE,CAmBzD;AASD,wBAAgB,aAAa,CAAC,OAAO,EAAE,eAAe,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,CAoB9E"}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
const RULES = [
|
|
2
|
+
// ── Destructive (data loss / backward-incompatible) ───────────────────
|
|
3
|
+
{
|
|
4
|
+
pattern: /\bDROP\s+TABLE\b/i,
|
|
5
|
+
severity: 'destructive',
|
|
6
|
+
operation: 'DROP TABLE',
|
|
7
|
+
suggestion: 'Rename the table first, deploy, verify no access, then drop in a follow-up migration.',
|
|
8
|
+
},
|
|
9
|
+
{
|
|
10
|
+
pattern: /\bDROP\s+COLUMN\b/i,
|
|
11
|
+
severity: 'destructive',
|
|
12
|
+
operation: 'DROP COLUMN',
|
|
13
|
+
suggestion: 'Stop reading the column in application code first, then drop in a follow-up migration.',
|
|
14
|
+
},
|
|
15
|
+
{
|
|
16
|
+
pattern: /\bALTER\s+COLUMN\b[^;]*\bSET\s+NOT\s+NULL\b/i,
|
|
17
|
+
severity: 'destructive',
|
|
18
|
+
operation: 'SET NOT NULL',
|
|
19
|
+
suggestion: 'Add a CHECK constraint with NOT VALID, validate it separately, then convert to NOT NULL.',
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
pattern: /\bALTER\s+COLUMN\b[^;]*\bTYPE\b/i,
|
|
23
|
+
severity: 'destructive',
|
|
24
|
+
operation: 'ALTER COLUMN TYPE',
|
|
25
|
+
suggestion: 'Add a new column with the target type, backfill, swap reads, then drop the old column.',
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
pattern: /\bTRUNCATE\b/i,
|
|
29
|
+
severity: 'destructive',
|
|
30
|
+
operation: 'TRUNCATE',
|
|
31
|
+
suggestion: 'Use DELETE with a WHERE clause if you need to remove rows in a migration.',
|
|
32
|
+
},
|
|
33
|
+
// ── Locking (acquires heavy locks, risks downtime under load) ─────────
|
|
34
|
+
{
|
|
35
|
+
pattern: /\bCREATE\s+(?:UNIQUE\s+)?INDEX\b(?!\s+CONCURRENTLY)/i,
|
|
36
|
+
severity: 'locking',
|
|
37
|
+
operation: 'CREATE INDEX (non-concurrent)',
|
|
38
|
+
suggestion: 'Use CREATE INDEX CONCURRENTLY to avoid blocking writes.',
|
|
39
|
+
except: /\bCONCURRENTLY\b/i,
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
pattern: /\bRENAME\s+COLUMN\b/i,
|
|
43
|
+
severity: 'locking',
|
|
44
|
+
operation: 'RENAME COLUMN',
|
|
45
|
+
suggestion: 'Add a new column, backfill, migrate reads, then drop the old column.',
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
pattern: /\bRENAME\s+TABLE\b/i,
|
|
49
|
+
severity: 'locking',
|
|
50
|
+
operation: 'RENAME TABLE',
|
|
51
|
+
suggestion: 'Create a new table, migrate data, swap reads, then drop the old table.',
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
pattern: /\bRENAME\s+TO\b/i,
|
|
55
|
+
severity: 'locking',
|
|
56
|
+
operation: 'RENAME TO',
|
|
57
|
+
suggestion: 'Renames acquire AccessExclusive locks. Consider a multi-step migration instead.',
|
|
58
|
+
except: /\bRENAME\s+COLUMN\b|\bRENAME\s+TABLE\b/i,
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
pattern: /\bADD\s+CONSTRAINT\b[^;]*\bFOREIGN\s+KEY\b(?![^;]*\bNOT\s+VALID\b)/i,
|
|
62
|
+
severity: 'locking',
|
|
63
|
+
operation: 'ADD FOREIGN KEY (without NOT VALID)',
|
|
64
|
+
suggestion: 'Add the constraint with NOT VALID, then VALIDATE CONSTRAINT in a separate statement.',
|
|
65
|
+
},
|
|
66
|
+
];
|
|
67
|
+
export function analyzeSQL(sql) {
|
|
68
|
+
const statements = splitStatements(sql);
|
|
69
|
+
const hazards = [];
|
|
70
|
+
for (const stmt of statements) {
|
|
71
|
+
for (const rule of RULES) {
|
|
72
|
+
if (!rule.pattern.test(stmt))
|
|
73
|
+
continue;
|
|
74
|
+
if (rule.except !== undefined && rule.except.test(stmt))
|
|
75
|
+
continue;
|
|
76
|
+
hazards.push({
|
|
77
|
+
severity: rule.severity,
|
|
78
|
+
operation: rule.operation,
|
|
79
|
+
statement: stmt.trim().slice(0, 200),
|
|
80
|
+
suggestion: rule.suggestion,
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return hazards;
|
|
85
|
+
}
|
|
86
|
+
function splitStatements(sql) {
|
|
87
|
+
return sql
|
|
88
|
+
.split(/;/)
|
|
89
|
+
.map(s => s.trim())
|
|
90
|
+
.filter(s => s.length > 0 && !s.startsWith('--'));
|
|
91
|
+
}
|
|
92
|
+
export function formatHazards(hazards, file) {
|
|
93
|
+
const destructive = hazards.filter(h => h.severity === 'destructive');
|
|
94
|
+
const locking = hazards.filter(h => h.severity === 'locking');
|
|
95
|
+
const lines = [];
|
|
96
|
+
lines.push(` ${file}:`);
|
|
97
|
+
for (const h of destructive) {
|
|
98
|
+
lines.push(` ✗ DESTRUCTIVE: ${h.operation}`);
|
|
99
|
+
lines.push(` ${truncate(h.statement, 120)}`);
|
|
100
|
+
lines.push(` → ${h.suggestion}`);
|
|
101
|
+
}
|
|
102
|
+
for (const h of locking) {
|
|
103
|
+
lines.push(` ⚠ LOCKING: ${h.operation}`);
|
|
104
|
+
lines.push(` ${truncate(h.statement, 120)}`);
|
|
105
|
+
lines.push(` → ${h.suggestion}`);
|
|
106
|
+
}
|
|
107
|
+
return lines.join('\n');
|
|
108
|
+
}
|
|
109
|
+
function truncate(s, max) {
|
|
110
|
+
const oneLine = s.replace(/\s+/g, ' ');
|
|
111
|
+
if (oneLine.length <= max)
|
|
112
|
+
return oneLine;
|
|
113
|
+
return oneLine.slice(0, max - 3) + '...';
|
|
114
|
+
}
|
|
115
|
+
//# sourceMappingURL=safety.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"safety.js","sourceRoot":"","sources":["../../src/migrate/safety.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { RouteRegistration } from '../http/types.js';
|
|
2
|
+
export interface OpenAPIInfo {
|
|
3
|
+
title: string;
|
|
4
|
+
version: string;
|
|
5
|
+
description?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface OpenAPIDocument {
|
|
8
|
+
openapi: '3.0.3';
|
|
9
|
+
info: OpenAPIInfo;
|
|
10
|
+
paths: Record<string, Record<string, unknown>>;
|
|
11
|
+
}
|
|
12
|
+
export declare function generateOpenAPI(info: OpenAPIInfo, routes: readonly RouteRegistration[]): OpenAPIDocument;
|
|
13
|
+
//# sourceMappingURL=generate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate.d.ts","sourceRoot":"","sources":["../../src/openapi/generate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAGzD,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,MAAM,CAAA;IACf,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB;AAED,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,OAAO,CAAA;IAChB,IAAI,EAAE,WAAW,CAAA;IACjB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAA;CAC/C;AAED,wBAAgB,eAAe,CAC7B,IAAI,EAAE,WAAW,EACjB,MAAM,EAAE,SAAS,iBAAiB,EAAE,GACnC,eAAe,CA8FjB"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { toJsonSchema } from '../schema/json-schema.js';
|
|
2
|
+
export function generateOpenAPI(info, routes) {
|
|
3
|
+
const paths = {};
|
|
4
|
+
for (const route of routes) {
|
|
5
|
+
const { method, path, handler } = route;
|
|
6
|
+
const meta = handler.meta;
|
|
7
|
+
const openApiPath = path.replace(/:(\w+)/g, '{$1}');
|
|
8
|
+
let pathItem = paths[openApiPath];
|
|
9
|
+
if (!pathItem) {
|
|
10
|
+
pathItem = {};
|
|
11
|
+
paths[openApiPath] = pathItem;
|
|
12
|
+
}
|
|
13
|
+
const operation = {};
|
|
14
|
+
const parameters = [];
|
|
15
|
+
if (meta.paramsSchema) {
|
|
16
|
+
const schema = toJsonSchema(meta.paramsSchema);
|
|
17
|
+
if ('properties' in schema) {
|
|
18
|
+
const props = schema['properties'];
|
|
19
|
+
for (const [name, propSchema] of Object.entries(props)) {
|
|
20
|
+
parameters.push({
|
|
21
|
+
name,
|
|
22
|
+
in: 'path',
|
|
23
|
+
required: true,
|
|
24
|
+
schema: propSchema,
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
if (meta.querySchema) {
|
|
30
|
+
const schema = toJsonSchema(meta.querySchema);
|
|
31
|
+
if ('properties' in schema) {
|
|
32
|
+
const props = schema['properties'];
|
|
33
|
+
const requiredFields = Array.isArray(schema['required']) ? schema['required'] : [];
|
|
34
|
+
for (const [name, propSchema] of Object.entries(props)) {
|
|
35
|
+
parameters.push({
|
|
36
|
+
name,
|
|
37
|
+
in: 'query',
|
|
38
|
+
required: requiredFields.includes(name),
|
|
39
|
+
schema: propSchema,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
if (parameters.length > 0) {
|
|
45
|
+
operation['parameters'] = parameters;
|
|
46
|
+
}
|
|
47
|
+
if (meta.inputSchema) {
|
|
48
|
+
operation['requestBody'] = {
|
|
49
|
+
required: true,
|
|
50
|
+
content: {
|
|
51
|
+
'application/json': {
|
|
52
|
+
schema: toJsonSchema(meta.inputSchema),
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
const responses = {};
|
|
58
|
+
if (meta.outputSchemas.size > 0) {
|
|
59
|
+
for (const [status, outputSchema] of meta.outputSchemas) {
|
|
60
|
+
responses[String(status)] = {
|
|
61
|
+
description: status === 200 ? 'Successful response' : `${status} response`,
|
|
62
|
+
content: {
|
|
63
|
+
'application/json': {
|
|
64
|
+
schema: toJsonSchema(outputSchema),
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
responses['200'] = { description: 'Successful response' };
|
|
72
|
+
}
|
|
73
|
+
if (meta.requiresAuth) {
|
|
74
|
+
responses['401'] = { description: 'Unauthorized' };
|
|
75
|
+
}
|
|
76
|
+
if (meta.permission) {
|
|
77
|
+
responses['403'] = { description: 'Forbidden' };
|
|
78
|
+
}
|
|
79
|
+
operation['responses'] = responses;
|
|
80
|
+
pathItem[method.toLowerCase()] = operation;
|
|
81
|
+
}
|
|
82
|
+
return { openapi: '3.0.3', info, paths };
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=generate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate.js","sourceRoot":"","sources":["../../src/openapi/generate.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/openapi/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/openapi/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { generateOpenAPI } from './generate.js';
|
|
2
|
+
/** OpenAPI spec generation namespace. */
|
|
3
|
+
export declare const openapi: {
|
|
4
|
+
/** Generates an OpenAPI 3.1 document from route registrations — schemas derived from fitting() input/output. */
|
|
5
|
+
generate: typeof generateOpenAPI;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../src/openapi/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,yCAAyC;AACzC,eAAO,MAAM,OAAO;IAClB,gHAAgH;;CAEjH,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { generateOpenAPI } from './generate.js';
|
|
2
|
+
/** OpenAPI spec generation namespace. */
|
|
3
|
+
export const openapi = {
|
|
4
|
+
/** Generates an OpenAPI 3.1 document from route registrations — schemas derived from fitting() input/output. */
|
|
5
|
+
generate: generateOpenAPI,
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=namespace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../src/openapi/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,yCAAyC;AACzC,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,gHAAgH;IAChH,QAAQ,EAAE,eAAe;CAC1B,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"define.d.ts","sourceRoot":"","sources":["../../src/pipeline/define.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,QAAQ,EAAuC,MAAM,YAAY,CAAA;AAI/F,wBAAgB,cAAc,CAAC,MAAM,EAAE,cAAc,GAAG,QAAQ,CA6C/D"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { sql } from '../db/sql.js';
|
|
2
|
+
import { executePipeline } from './execute.js';
|
|
3
|
+
import { resumePipeline } from './resume.js';
|
|
4
|
+
export function definePipeline(config) {
|
|
5
|
+
if (config.steps.length === 0) {
|
|
6
|
+
throw new Error(`[pipework] Pipeline "${config.name}" must have at least one step.`);
|
|
7
|
+
}
|
|
8
|
+
const stepNames = new Set();
|
|
9
|
+
for (const step of config.steps) {
|
|
10
|
+
if (stepNames.has(step.name)) {
|
|
11
|
+
throw new Error(`[pipework] Pipeline "${config.name}" has duplicate step name "${step.name}".`);
|
|
12
|
+
}
|
|
13
|
+
stepNames.add(step.name);
|
|
14
|
+
}
|
|
15
|
+
return {
|
|
16
|
+
async execute(db, input, context) {
|
|
17
|
+
return executePipeline(db, config, input, context);
|
|
18
|
+
},
|
|
19
|
+
async resume(db, runId, stepOutput) {
|
|
20
|
+
return resumePipeline(db, config, runId, stepOutput);
|
|
21
|
+
},
|
|
22
|
+
async getStatus(db, runId) {
|
|
23
|
+
const [row] = await db.execute(sql `
|
|
24
|
+
SELECT id, pipeline_name, status, current_step, input, started_at, completed_at, error
|
|
25
|
+
FROM pipework_pipeline_runs
|
|
26
|
+
WHERE id = ${runId}::uuid
|
|
27
|
+
`);
|
|
28
|
+
if (row === undefined)
|
|
29
|
+
return null;
|
|
30
|
+
return {
|
|
31
|
+
id: String(row['id']),
|
|
32
|
+
pipelineName: String(row['pipeline_name']),
|
|
33
|
+
status: String(row['status']),
|
|
34
|
+
currentStep: Number(row['current_step']),
|
|
35
|
+
input: row['input'],
|
|
36
|
+
startedAt: new Date(String(row['started_at'])),
|
|
37
|
+
completedAt: row['completed_at'] !== null ? new Date(String(row['completed_at'])) : null,
|
|
38
|
+
error: row['error'] ?? null,
|
|
39
|
+
};
|
|
40
|
+
},
|
|
41
|
+
definition: config,
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=define.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"define.js","sourceRoot":"","sources":["../../src/pipeline/define.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAA;AAElC,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AAE5C,MAAM,UAAU,cAAc,CAAC,MAAsB;IACnD,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9B,MAAM,IAAI,KAAK,CAAC,wBAAwB,MAAM,CAAC,IAAI,gCAAgC,CAAC,CAAA;IACtF,CAAC;IAED,MAAM,SAAS,GAAG,IAAI,GAAG,EAAU,CAAA;IACnC,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;QAChC,IAAI,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YAC7B,MAAM,IAAI,KAAK,CAAC,wBAAwB,MAAM,CAAC,IAAI,8BAA8B,IAAI,CAAC,IAAI,IAAI,CAAC,CAAA;QACjG,CAAC;QACD,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC1B,CAAC;IAED,OAAO;QACL,KAAK,CAAC,OAAO,CAAC,EAAM,EAAE,KAAc,EAAE,OAA+B;YACnE,OAAO,eAAe,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,CAAA;QACpD,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,EAAM,EAAE,KAAa,EAAE,UAAmB;YACrD,OAAO,cAAc,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,CAAC,CAAA;QACtD,CAAC;QAED,KAAK,CAAC,SAAS,CAAC,EAAM,EAAE,KAAa;YACnC,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,EAAE,CAAC,OAAO,CAAC,GAAG,CAAA;;;qBAGnB,KAAK;OACnB,CAAC,CAAA;YAEF,IAAI,GAAG,KAAK,SAAS;gBAAE,OAAO,IAAI,CAAA;YAElC,OAAO;gBACL,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACrB,YAAY,EAAE,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;gBAC1C,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAA0B;gBACtD,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;gBACxC,KAAK,EAAE,GAAG,CAAC,OAAO,CAAC;gBACnB,SAAS,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC;gBAC9C,WAAW,EAAE,GAAG,CAAC,cAAc,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;gBACxF,KAAK,EAAE,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI;aAC5B,CAAA;QACH,CAAC;QAED,UAAU,EAAE,MAAM;KACnB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { PipeworkError } from '../errors/base.js';
|
|
2
|
+
export declare class PipelineStepError extends PipeworkError {
|
|
3
|
+
readonly code: "PIPELINE_STEP_FAILED";
|
|
4
|
+
readonly httpStatus: 500;
|
|
5
|
+
readonly pipelineName: string;
|
|
6
|
+
readonly stepName: string;
|
|
7
|
+
readonly stepIndex: number;
|
|
8
|
+
constructor(pipelineName: string, stepName: string, stepIndex: number, cause: unknown);
|
|
9
|
+
}
|
|
10
|
+
export declare class PipelineResumeError extends PipeworkError {
|
|
11
|
+
readonly code: "PIPELINE_RESUME_FAILED";
|
|
12
|
+
readonly httpStatus: 409;
|
|
13
|
+
readonly runId: string;
|
|
14
|
+
readonly reason: string;
|
|
15
|
+
constructor(runId: string, reason: string);
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/pipeline/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAEjD,qBAAa,iBAAkB,SAAQ,aAAa;IAClD,QAAQ,CAAC,IAAI,EAAG,sBAAsB,CAAS;IAC/C,QAAQ,CAAC,UAAU,EAAG,GAAG,CAAS;IAClC,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAA;gBAEd,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO;CAUtF;AAED,qBAAa,mBAAoB,SAAQ,aAAa;IACpD,QAAQ,CAAC,IAAI,EAAG,wBAAwB,CAAS;IACjD,QAAQ,CAAC,UAAU,EAAG,GAAG,CAAS;IAClC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;gBAEX,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;CAO1C"}
|