pipework 0.8.6 → 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 +10 -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/schema/audit-record-fields.d.ts.map +1 -1
- package/dist/audit/schema/audit-record-fields.js +8 -5
- package/dist/audit/schema/audit-record-fields.js.map +1 -1
- package/dist/audit/schema/audit-record.d.ts.map +1 -1
- package/dist/audit/schema/audit-record.js +4 -3
- package/dist/audit/schema/audit-record.js.map +1 -1
- 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/core/validation/domain.d.ts.map +1 -1
- package/dist/core/validation/domain.js +3 -2
- package/dist/core/validation/domain.js.map +1 -1
- 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/build-factory.d.ts.map +1 -1
- package/dist/data/domain/build-factory.js +3 -1
- package/dist/data/domain/build-factory.js.map +1 -1
- package/dist/data/domain/build-table.d.ts.map +1 -1
- package/dist/data/domain/build-table.js +6 -3
- package/dist/data/domain/build-table.js.map +1 -1
- package/dist/data/domain/field.d.ts +12 -2
- package/dist/data/domain/field.d.ts.map +1 -1
- package/dist/data/domain/field.js +10 -4
- package/dist/data/domain/field.js.map +1 -1
- 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/domain/types.d.ts +24 -2
- package/dist/data/domain/types.d.ts.map +1 -1
- package/dist/data/domain/types.js +5 -1
- package/dist/data/domain/types.js.map +1 -1
- 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/trace/entry/close-trace.d.ts.map +1 -1
- package/dist/trace/entry/close-trace.js +18 -6
- package/dist/trace/entry/close-trace.js.map +1 -1
- package/dist/trace/schema/trace-fields.d.ts.map +1 -1
- package/dist/trace/schema/trace-fields.js +18 -6
- package/dist/trace/schema/trace-fields.js.map +1 -1
- package/dist/trace/schema/trace-step-fields.d.ts.map +1 -1
- package/dist/trace/schema/trace-step-fields.js +11 -3
- package/dist/trace/schema/trace-step-fields.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/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,24 @@
|
|
|
1
|
+
export function setupDrain(app) {
|
|
2
|
+
let count = 0;
|
|
3
|
+
app.addHook('onRequest', () => { count++; return Promise.resolve(); });
|
|
4
|
+
app.addHook('onResponse', () => { count--; return Promise.resolve(); });
|
|
5
|
+
return {
|
|
6
|
+
inFlight: () => count,
|
|
7
|
+
waitForDrain: (timeoutMs) => new Promise((resolve, reject) => {
|
|
8
|
+
if (count === 0)
|
|
9
|
+
return resolve();
|
|
10
|
+
const deadline = setTimeout(() => {
|
|
11
|
+
clearInterval(poll);
|
|
12
|
+
reject(new Error(`[pipework] Drain timeout: ${count} requests still in-flight after ${timeoutMs}ms`));
|
|
13
|
+
}, timeoutMs);
|
|
14
|
+
const poll = setInterval(() => {
|
|
15
|
+
if (count === 0) {
|
|
16
|
+
clearTimeout(deadline);
|
|
17
|
+
clearInterval(poll);
|
|
18
|
+
resolve();
|
|
19
|
+
}
|
|
20
|
+
}, 50);
|
|
21
|
+
}),
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=drain.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"drain.js","sourceRoot":"","sources":["../../src/lifecycle/drain.ts"],"names":[],"mappings":"AAOA,MAAM,UAAU,UAAU,CAAC,GAAoB;IAC7C,IAAI,KAAK,GAAG,CAAC,CAAA;IAEb,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,OAAO,OAAO,CAAC,OAAO,EAAE,CAAA,CAAC,CAAC,CAAC,CAAA;IACrE,GAAG,CAAC,OAAO,CAAC,YAAY,EAAE,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,OAAO,OAAO,CAAC,OAAO,EAAE,CAAA,CAAC,CAAC,CAAC,CAAA;IAEtE,OAAO;QACL,QAAQ,EAAE,GAAG,EAAE,CAAC,KAAK;QACrB,YAAY,EAAE,CAAC,SAAiB,EAAE,EAAE,CAAC,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACzE,IAAI,KAAK,KAAK,CAAC;gBAAE,OAAO,OAAO,EAAE,CAAA;YAEjC,MAAM,QAAQ,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC/B,aAAa,CAAC,IAAI,CAAC,CAAA;gBACnB,MAAM,CAAC,IAAI,KAAK,CAAC,6BAA6B,KAAK,mCAAmC,SAAS,IAAI,CAAC,CAAC,CAAA;YACvG,CAAC,EAAE,SAAS,CAAC,CAAA;YAEb,MAAM,IAAI,GAAG,WAAW,CAAC,GAAG,EAAE;gBAC5B,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;oBAChB,YAAY,CAAC,QAAQ,CAAC,CAAA;oBACtB,aAAa,CAAC,IAAI,CAAC,CAAA;oBACnB,OAAO,EAAE,CAAA;gBACX,CAAC;YACH,CAAC,EAAE,EAAE,CAAC,CAAA;QACR,CAAC,CAAC;KACH,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { FastifyInstance } from 'fastify';
|
|
2
|
+
import type { Manifold } from '../pipework.js';
|
|
3
|
+
import type { HealthCheck } from './types.js';
|
|
4
|
+
export declare function registerHealthRoutes(app: FastifyInstance, instance: Manifold, checks: readonly HealthCheck[], paths: {
|
|
5
|
+
health: string;
|
|
6
|
+
ready: string;
|
|
7
|
+
}): void;
|
|
8
|
+
//# sourceMappingURL=health.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.d.ts","sourceRoot":"","sources":["../../src/lifecycle/health.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAC9C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAC9C,OAAO,KAAK,EAAE,WAAW,EAAmC,MAAM,YAAY,CAAA;AAK9E,wBAAgB,oBAAoB,CAClC,GAAG,EAAE,eAAe,EACpB,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,SAAS,WAAW,EAAE,EAC9B,KAAK,EAAE;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GACvC,IAAI,CAoCN"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { sql } from '../db/sql.js';
|
|
2
|
+
const startedAt = Date.now();
|
|
3
|
+
export function registerHealthRoutes(app, instance, checks, paths) {
|
|
4
|
+
app.get(paths.health, async (_req, reply) => {
|
|
5
|
+
return reply.status(200).send({ status: 'healthy', uptime: Date.now() - startedAt });
|
|
6
|
+
});
|
|
7
|
+
app.get(paths.ready, async (_req, reply) => {
|
|
8
|
+
const results = {};
|
|
9
|
+
let overall = 'healthy';
|
|
10
|
+
const dbChecks = await checkDatabases(instance);
|
|
11
|
+
for (const [name, result] of Object.entries(dbChecks)) {
|
|
12
|
+
results[name] = result;
|
|
13
|
+
if (result.status === 'unhealthy')
|
|
14
|
+
overall = 'unhealthy';
|
|
15
|
+
else if (result.status === 'degraded' && overall !== 'unhealthy')
|
|
16
|
+
overall = 'degraded';
|
|
17
|
+
}
|
|
18
|
+
for (const check of checks) {
|
|
19
|
+
const start = Date.now();
|
|
20
|
+
try {
|
|
21
|
+
const result = await check.check();
|
|
22
|
+
results[check.name] = { ...result, latencyMs: result.latencyMs ?? (Date.now() - start) };
|
|
23
|
+
if (result.status === 'unhealthy')
|
|
24
|
+
overall = 'unhealthy';
|
|
25
|
+
else if (result.status === 'degraded' && overall !== 'unhealthy')
|
|
26
|
+
overall = 'degraded';
|
|
27
|
+
}
|
|
28
|
+
catch (err) {
|
|
29
|
+
results[check.name] = {
|
|
30
|
+
status: 'unhealthy',
|
|
31
|
+
message: err instanceof Error ? err.message : 'check failed',
|
|
32
|
+
latencyMs: Date.now() - start,
|
|
33
|
+
};
|
|
34
|
+
overall = 'unhealthy';
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
const status = { status: overall, uptime: Date.now() - startedAt, checks: results };
|
|
38
|
+
return reply.status(overall === 'unhealthy' ? 503 : 200).send(status);
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
async function checkDatabases(instance) {
|
|
42
|
+
const results = {};
|
|
43
|
+
const dbNames = instance.config.databaseNames();
|
|
44
|
+
for (const name of dbNames) {
|
|
45
|
+
const start = Date.now();
|
|
46
|
+
try {
|
|
47
|
+
const dbConfig = instance.config.database(name);
|
|
48
|
+
const conn = instance.pool.getOrCreate(dbConfig);
|
|
49
|
+
await conn.drizzle.execute(sql `SELECT 1`);
|
|
50
|
+
results[`db:${name}`] = { status: 'healthy', latencyMs: Date.now() - start };
|
|
51
|
+
}
|
|
52
|
+
catch (err) {
|
|
53
|
+
results[`db:${name}`] = {
|
|
54
|
+
status: 'unhealthy',
|
|
55
|
+
message: err instanceof Error ? err.message : 'connection failed',
|
|
56
|
+
latencyMs: Date.now() - start,
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return results;
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=health.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.js","sourceRoot":"","sources":["../../src/lifecycle/health.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAA;AAElC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;AAE5B,MAAM,UAAU,oBAAoB,CAClC,GAAoB,EACpB,QAAkB,EAClB,MAA8B,EAC9B,KAAwC;IAExC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE;QAC1C,OAAO,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,EAAE,CAAC,CAAA;IACtF,CAAC,CAAC,CAAA;IAEF,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE;QACzC,MAAM,OAAO,GAAsC,EAAE,CAAA;QACrD,IAAI,OAAO,GAA2B,SAAS,CAAA;QAE/C,MAAM,QAAQ,GAAG,MAAM,cAAc,CAAC,QAAQ,CAAC,CAAA;QAC/C,KAAK,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;YACtD,OAAO,CAAC,IAAI,CAAC,GAAG,MAAM,CAAA;YACtB,IAAI,MAAM,CAAC,MAAM,KAAK,WAAW;gBAAE,OAAO,GAAG,WAAW,CAAA;iBACnD,IAAI,MAAM,CAAC,MAAM,KAAK,UAAU,IAAI,OAAO,KAAK,WAAW;gBAAE,OAAO,GAAG,UAAU,CAAA;QACxF,CAAC;QAED,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;YACxB,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,KAAK,EAAE,CAAA;gBAClC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,EAAE,CAAA;gBACxF,IAAI,MAAM,CAAC,MAAM,KAAK,WAAW;oBAAE,OAAO,GAAG,WAAW,CAAA;qBACnD,IAAI,MAAM,CAAC,MAAM,KAAK,UAAU,IAAI,OAAO,KAAK,WAAW;oBAAE,OAAO,GAAG,UAAU,CAAA;YACxF,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG;oBACpB,MAAM,EAAE,WAAW;oBACnB,OAAO,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc;oBAC5D,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;iBAC9B,CAAA;gBACD,OAAO,GAAG,WAAW,CAAA;YACvB,CAAC;QACH,CAAC;QAED,MAAM,MAAM,GAAiB,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,CAAA;QACjG,OAAO,KAAK,CAAC,MAAM,CAAC,OAAO,KAAK,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IACvE,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,KAAK,UAAU,cAAc,CAAC,QAAkB;IAC9C,MAAM,OAAO,GAAsC,EAAE,CAAA;IACrD,MAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,aAAa,EAAE,CAAA;IAE/C,KAAK,MAAM,IAAI,IAAI,OAAO,EAAE,CAAC;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QACxB,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;YAC/C,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAA;YAChD,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAA,UAAU,CAAC,CAAA;YACzC,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,CAAA;QAC9E,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC,GAAG;gBACtB,MAAM,EAAE,WAAW;gBACnB,OAAO,EAAE,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,mBAAmB;gBACjE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK;aAC9B,CAAA;QACH,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAA;AAChB,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { orchestrateStartup, type StartupOptions } from './startup.js';
|
|
2
|
+
export { registerHealthRoutes } from './health.js';
|
|
3
|
+
export { setupDrain, type DrainState } from './drain.js';
|
|
4
|
+
export type { LifecycleConfig, StartupHook, ShutdownHook, HealthCheck, HealthCheckResult, HealthStatus } from './types.js';
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/lifecycle/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,KAAK,cAAc,EAAE,MAAM,cAAc,CAAA;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AAClD,OAAO,EAAE,UAAU,EAAE,KAAK,UAAU,EAAE,MAAM,YAAY,CAAA;AACxD,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,YAAY,EAAE,WAAW,EAAE,iBAAiB,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/lifecycle/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAuB,MAAM,cAAc,CAAA;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AAClD,OAAO,EAAE,UAAU,EAAmB,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { orchestrateStartup } from './startup.js';
|
|
2
|
+
/** Application lifecycle namespace — startup orchestration with hooks and timeouts. */
|
|
3
|
+
export declare const lifecycle: {
|
|
4
|
+
/** Runs pre-start hooks (DB readiness checks, migrations, etc.) with a configurable timeout. */
|
|
5
|
+
orchestrate: typeof orchestrateStartup;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../src/lifecycle/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAA;AAEjD,uFAAuF;AACvF,eAAO,MAAM,SAAS;IACpB,gGAAgG;;CAEjG,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { orchestrateStartup } from './startup.js';
|
|
2
|
+
/** Application lifecycle namespace — startup orchestration with hooks and timeouts. */
|
|
3
|
+
export const lifecycle = {
|
|
4
|
+
/** Runs pre-start hooks (DB readiness checks, migrations, etc.) with a configurable timeout. */
|
|
5
|
+
orchestrate: orchestrateStartup,
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=namespace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../src/lifecycle/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAA;AAEjD,uFAAuF;AACvF,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,gGAAgG;IAChG,WAAW,EAAE,kBAAkB;CAChC,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { Manifold } from '../pipework.js';
|
|
2
|
+
import type { StartupHook } from './types.js';
|
|
3
|
+
export interface StartupOptions {
|
|
4
|
+
readonly hooks?: readonly StartupHook[];
|
|
5
|
+
readonly timeoutMs?: number;
|
|
6
|
+
}
|
|
7
|
+
export declare function orchestrateStartup(instance: Manifold, options?: StartupOptions): Promise<void>;
|
|
8
|
+
//# sourceMappingURL=startup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startup.d.ts","sourceRoot":"","sources":["../../src/lifecycle/startup.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAC9C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AAG7C,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,KAAK,CAAC,EAAE,SAAS,WAAW,EAAE,CAAA;IACvC,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAC5B;AAED,wBAAsB,kBAAkB,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,GAAE,cAAmB,GAAG,OAAO,CAAC,IAAI,CAAC,CA2BxG"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { sql } from '../db/sql.js';
|
|
2
|
+
import { getBaseLogger } from '../logging/index.js';
|
|
3
|
+
export async function orchestrateStartup(instance, options = {}) {
|
|
4
|
+
const logger = getBaseLogger();
|
|
5
|
+
const timeoutMs = options.timeoutMs ?? 30000;
|
|
6
|
+
const doStartupWork = async () => {
|
|
7
|
+
await verifyDatabases(instance, logger);
|
|
8
|
+
if (options.hooks) {
|
|
9
|
+
for (const hook of options.hooks) {
|
|
10
|
+
logger.info({ hook: hook.name }, 'Running pre-start hook');
|
|
11
|
+
await hook.execute();
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
const timeoutPromise = new Promise((_, reject) => {
|
|
16
|
+
const timer = setTimeout(() => {
|
|
17
|
+
reject(new Error(`[pipework] Startup timed out after ${timeoutMs}ms.\n\n` +
|
|
18
|
+
' This usually means a database is unreachable or a pre-start hook is hanging.\n' +
|
|
19
|
+
' Check your DATABASE_URL values and network connectivity.\n'));
|
|
20
|
+
}, timeoutMs);
|
|
21
|
+
timer.unref();
|
|
22
|
+
});
|
|
23
|
+
await Promise.race([doStartupWork(), timeoutPromise]);
|
|
24
|
+
}
|
|
25
|
+
async function verifyDatabases(instance, logger) {
|
|
26
|
+
const dbNames = instance.config.databaseNames();
|
|
27
|
+
for (const name of dbNames) {
|
|
28
|
+
const dbConfig = instance.config.database(name);
|
|
29
|
+
const conn = instance.pool.getOrCreate(dbConfig);
|
|
30
|
+
try {
|
|
31
|
+
await conn.drizzle.execute(sql `SELECT 1`);
|
|
32
|
+
logger.info({ database: name }, 'Database connectivity verified');
|
|
33
|
+
}
|
|
34
|
+
catch (err) {
|
|
35
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
36
|
+
throw new Error(`[pipework] Cannot connect to database "${name}".\n\n` +
|
|
37
|
+
` URL: ${dbConfig.url.replace(/\/\/[^@]+@/, '//***@')}\n` +
|
|
38
|
+
` Error: ${message}\n\n` +
|
|
39
|
+
' Check that the database is running and the URL is correct.\n');
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=startup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"startup.js","sourceRoot":"","sources":["../../src/lifecycle/startup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAA;AAGlC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AAOnD,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,QAAkB,EAAE,UAA0B,EAAE;IACvF,MAAM,MAAM,GAAG,aAAa,EAAE,CAAA;IAC9B,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,KAAK,CAAA;IAE5C,MAAM,aAAa,GAAG,KAAK,IAAI,EAAE;QAC/B,MAAM,eAAe,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAA;QAEvC,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;YAClB,KAAK,MAAM,IAAI,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;gBACjC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,wBAAwB,CAAC,CAAA;gBAC1D,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;YACtB,CAAC;QACH,CAAC;IACH,CAAC,CAAA;IAED,MAAM,cAAc,GAAG,IAAI,OAAO,CAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE;QACtD,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,MAAM,CAAC,IAAI,KAAK,CACd,sCAAsC,SAAS,SAAS;gBACxD,kFAAkF;gBAClF,8DAA8D,CAC/D,CAAC,CAAA;QACJ,CAAC,EAAE,SAAS,CAAC,CAAA;QACb,KAAK,CAAC,KAAK,EAAE,CAAA;IACf,CAAC,CAAC,CAAA;IAEF,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,EAAE,cAAc,CAAC,CAAC,CAAA;AACvD,CAAC;AAED,KAAK,UAAU,eAAe,CAAC,QAAkB,EAAE,MAAkE;IACnH,MAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,aAAa,EAAE,CAAA;IAE/C,KAAK,MAAM,IAAI,IAAI,OAAO,EAAE,CAAC;QAC3B,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;QAC/C,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAA;QAChD,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAA,UAAU,CAAC,CAAA;YACzC,MAAM,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,gCAAgC,CAAC,CAAA;QACnE,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;YAChE,MAAM,IAAI,KAAK,CACb,0CAA0C,IAAI,QAAQ;gBACtD,UAAU,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,YAAY,EAAE,QAAQ,CAAC,IAAI;gBAC1D,YAAY,OAAO,MAAM;gBACzB,gEAAgE,CACjE,CAAA;QACH,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export interface LifecycleConfig {
|
|
2
|
+
readonly preStart?: readonly StartupHook[];
|
|
3
|
+
readonly preShutdown?: readonly ShutdownHook[];
|
|
4
|
+
readonly healthChecks?: readonly HealthCheck[];
|
|
5
|
+
readonly drainTimeoutMs?: number;
|
|
6
|
+
readonly startupTimeoutMs?: number;
|
|
7
|
+
}
|
|
8
|
+
export interface StartupHook {
|
|
9
|
+
readonly name: string;
|
|
10
|
+
execute(): Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
export interface ShutdownHook {
|
|
13
|
+
readonly name: string;
|
|
14
|
+
execute(): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
export interface HealthCheck {
|
|
17
|
+
readonly name: string;
|
|
18
|
+
check(): Promise<HealthCheckResult>;
|
|
19
|
+
}
|
|
20
|
+
export interface HealthCheckResult {
|
|
21
|
+
readonly status: 'healthy' | 'degraded' | 'unhealthy';
|
|
22
|
+
readonly message?: string;
|
|
23
|
+
readonly latencyMs?: number;
|
|
24
|
+
}
|
|
25
|
+
export interface HealthStatus {
|
|
26
|
+
readonly status: 'healthy' | 'degraded' | 'unhealthy';
|
|
27
|
+
readonly uptime: number;
|
|
28
|
+
readonly checks: Record<string, HealthCheckResult>;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/lifecycle/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,QAAQ,CAAC,EAAE,SAAS,WAAW,EAAE,CAAA;IAC1C,QAAQ,CAAC,WAAW,CAAC,EAAE,SAAS,YAAY,EAAE,CAAA;IAC9C,QAAQ,CAAC,YAAY,CAAC,EAAE,SAAS,WAAW,EAAE,CAAA;IAC9C,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAA;IAChC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,MAAM,CAAA;CACnC;AAED,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;CACzB;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;CACzB;AAED,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,KAAK,IAAI,OAAO,CAAC,iBAAiB,CAAC,CAAA;CACpC;AAED,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,UAAU,GAAG,WAAW,CAAA;IACrD,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAA;IACzB,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAC5B;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,UAAU,GAAG,WAAW,CAAA;IACrD,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;IACvB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAA;CACnD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/lifecycle/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { createPipeworkLogger, getLogger, getBaseLogger, setLoggingConfig } from '../logging/logger.js';
|
|
2
|
+
/** Structured logger (Pino) — auto-binds requestId, tenantId, userId, sessionId from ALS context on every log call. */
|
|
3
|
+
export declare const log: import("../index.js").PipeworkLogger & {
|
|
4
|
+
/** Creates a new PipeworkLogger instance with custom config (level, redaction, transport). */
|
|
5
|
+
create: typeof createPipeworkLogger;
|
|
6
|
+
/** Returns the context-aware logger proxy (same as the log export itself). */
|
|
7
|
+
get: typeof getLogger;
|
|
8
|
+
/** Returns the raw Pino logger without ALS context binding. */
|
|
9
|
+
getBase: typeof getBaseLogger;
|
|
10
|
+
/** Sets global logging config (level, redaction paths, custom context fields). */
|
|
11
|
+
configure: typeof setLoggingConfig;
|
|
12
|
+
/** Default redaction paths — password, secret, token, authorization, cookie, etc. */
|
|
13
|
+
REDACT_PATHS: readonly string[];
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../src/log/namespace.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,SAAS,EAAE,aAAa,EAAE,gBAAgB,EAAwB,MAAM,sBAAsB,CAAA;AAE7H,uHAAuH;AACvH,eAAO,MAAM,GAAG;IACd,8FAA8F;;IAE9F,8EAA8E;;IAE9E,+DAA+D;;IAE/D,kFAAkF;;IAElF,qFAAqF;;CAErF,CAAA"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { log as logProxy } from '../logging/proxy.js';
|
|
2
|
+
import { createPipeworkLogger, getLogger, getBaseLogger, setLoggingConfig, DEFAULT_REDACT_PATHS } from '../logging/logger.js';
|
|
3
|
+
/** Structured logger (Pino) — auto-binds requestId, tenantId, userId, sessionId from ALS context on every log call. */
|
|
4
|
+
export const log = Object.assign(logProxy, {
|
|
5
|
+
/** Creates a new PipeworkLogger instance with custom config (level, redaction, transport). */
|
|
6
|
+
create: createPipeworkLogger,
|
|
7
|
+
/** Returns the context-aware logger proxy (same as the log export itself). */
|
|
8
|
+
get: getLogger,
|
|
9
|
+
/** Returns the raw Pino logger without ALS context binding. */
|
|
10
|
+
getBase: getBaseLogger,
|
|
11
|
+
/** Sets global logging config (level, redaction paths, custom context fields). */
|
|
12
|
+
configure: setLoggingConfig,
|
|
13
|
+
/** Default redaction paths — password, secret, token, authorization, cookie, etc. */
|
|
14
|
+
REDACT_PATHS: DEFAULT_REDACT_PATHS,
|
|
15
|
+
});
|
|
16
|
+
//# sourceMappingURL=namespace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../src/log/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,IAAI,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,oBAAoB,EAAE,SAAS,EAAE,aAAa,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAA;AAE7H,uHAAuH;AACvH,MAAM,CAAC,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE;IACzC,8FAA8F;IAC9F,MAAM,EAAE,oBAAoB;IAC5B,8EAA8E;IAC9E,GAAG,EAAE,SAAS;IACd,+DAA+D;IAC/D,OAAO,EAAE,aAAa;IACtB,kFAAkF;IAClF,SAAS,EAAE,gBAAgB;IAC3B,qFAAqF;IACrF,YAAY,EAAE,oBAAoB;CACnC,CAAC,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface CorrelationFields {
|
|
2
|
+
requestId?: string;
|
|
3
|
+
tenantId?: string;
|
|
4
|
+
userId?: string;
|
|
5
|
+
sessionId?: string;
|
|
6
|
+
traceId?: string;
|
|
7
|
+
jobType?: string;
|
|
8
|
+
[key: string]: string | undefined;
|
|
9
|
+
}
|
|
10
|
+
export declare function getCorrelationFields(): CorrelationFields;
|
|
11
|
+
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../src/logging/context.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,iBAAiB;IAChC,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAA;CAClC;AAED,wBAAgB,oBAAoB,IAAI,iBAAiB,CAwCxD"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { getContext } from '../context/store.js';
|
|
2
|
+
import { getLoggingConfig } from './logger.js';
|
|
3
|
+
export function getCorrelationFields() {
|
|
4
|
+
const ctx = getContext();
|
|
5
|
+
if (!ctx)
|
|
6
|
+
return {};
|
|
7
|
+
const config = getLoggingConfig();
|
|
8
|
+
const enabled = config?.contextFields;
|
|
9
|
+
const fields = {};
|
|
10
|
+
if (isEnabled('requestId', enabled) && ctx.requestId !== '') {
|
|
11
|
+
fields.requestId = ctx.requestId;
|
|
12
|
+
}
|
|
13
|
+
if (isEnabled('tenantId', enabled) && ctx.tenant !== null) {
|
|
14
|
+
fields.tenantId = ctx.tenant;
|
|
15
|
+
}
|
|
16
|
+
if (isEnabled('userId', enabled) && ctx.auth !== null && typeof ctx.auth === 'object' && 'userId' in ctx.auth) {
|
|
17
|
+
const userId = ctx.auth.userId;
|
|
18
|
+
if (typeof userId === 'string')
|
|
19
|
+
fields.userId = userId;
|
|
20
|
+
}
|
|
21
|
+
if (isEnabled('sessionId', enabled) && ctx.metadata?.sessionId != null) {
|
|
22
|
+
fields.sessionId = ctx.metadata.sessionId;
|
|
23
|
+
}
|
|
24
|
+
if (isEnabled('traceId', enabled) && ctx.metadata?.traceId != null) {
|
|
25
|
+
fields.traceId = ctx.metadata.traceId;
|
|
26
|
+
}
|
|
27
|
+
if (ctx.jobType !== null) {
|
|
28
|
+
fields.jobType = ctx.jobType;
|
|
29
|
+
}
|
|
30
|
+
if (config?.authFields != null && ctx.auth !== null && typeof ctx.auth === 'object') {
|
|
31
|
+
const auth = ctx.auth;
|
|
32
|
+
for (const field of config.authFields) {
|
|
33
|
+
const value = auth[field];
|
|
34
|
+
if (typeof value === 'string') {
|
|
35
|
+
fields[field] = value;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return fields;
|
|
40
|
+
}
|
|
41
|
+
function isEnabled(field, enabled) {
|
|
42
|
+
if (enabled === undefined)
|
|
43
|
+
return true;
|
|
44
|
+
return enabled.includes(field);
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/logging/context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAa9C,MAAM,UAAU,oBAAoB;IAClC,MAAM,GAAG,GAAG,UAAU,EAAE,CAAA;IACxB,IAAI,CAAC,GAAG;QAAE,OAAO,EAAE,CAAA;IAEnB,MAAM,MAAM,GAAG,gBAAgB,EAAE,CAAA;IACjC,MAAM,OAAO,GAAG,MAAM,EAAE,aAAa,CAAA;IAErC,MAAM,MAAM,GAAsB,EAAE,CAAA;IAEpC,IAAI,SAAS,CAAC,WAAW,EAAE,OAAO,CAAC,IAAI,GAAG,CAAC,SAAS,KAAK,EAAE,EAAE,CAAC;QAC5D,MAAM,CAAC,SAAS,GAAG,GAAG,CAAC,SAAS,CAAA;IAClC,CAAC;IACD,IAAI,SAAS,CAAC,UAAU,EAAE,OAAO,CAAC,IAAI,GAAG,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;QAC1D,MAAM,CAAC,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAA;IAC9B,CAAC;IACD,IAAI,SAAS,CAAC,QAAQ,EAAE,OAAO,CAAC,IAAI,GAAG,CAAC,IAAI,KAAK,IAAI,IAAI,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ,IAAI,QAAQ,IAAI,GAAG,CAAC,IAAI,EAAE,CAAC;QAC9G,MAAM,MAAM,GAAI,GAAG,CAAC,IAA4B,CAAC,MAAM,CAAA;QACvD,IAAI,OAAO,MAAM,KAAK,QAAQ;YAAE,MAAM,CAAC,MAAM,GAAG,MAAM,CAAA;IACxD,CAAC;IACD,IAAI,SAAS,CAAC,WAAW,EAAE,OAAO,CAAC,IAAI,GAAG,CAAC,QAAQ,EAAE,SAAS,IAAI,IAAI,EAAE,CAAC;QACvE,MAAM,CAAC,SAAS,GAAG,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAA;IAC3C,CAAC;IACD,IAAI,SAAS,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,GAAG,CAAC,QAAQ,EAAE,OAAO,IAAI,IAAI,EAAE,CAAC;QACnE,MAAM,CAAC,OAAO,GAAG,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAA;IACvC,CAAC;IACD,IAAI,GAAG,CAAC,OAAO,KAAK,IAAI,EAAE,CAAC;QACzB,MAAM,CAAC,OAAO,GAAG,GAAG,CAAC,OAAO,CAAA;IAC9B,CAAC;IAED,IAAI,MAAM,EAAE,UAAU,IAAI,IAAI,IAAI,GAAG,CAAC,IAAI,KAAK,IAAI,IAAI,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;QACpF,MAAM,IAAI,GAAG,GAAG,CAAC,IAA+B,CAAA;QAChD,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;YACtC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAA;YACzB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBAC9B,MAAM,CAAC,KAAK,CAAC,GAAG,KAAK,CAAA;YACvB,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAA;AACf,CAAC;AAED,SAAS,SAAS,CAAC,KAAmB,EAAE,OAA4C;IAClF,IAAI,OAAO,KAAK,SAAS;QAAE,OAAO,IAAI,CAAA;IACtC,OAAO,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;AAChC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { createPipeworkLogger, getLogger, getBaseLogger, setLoggingConfig, DEFAULT_REDACT_PATHS } from './logger.js';
|
|
2
|
+
export { log } from './proxy.js';
|
|
3
|
+
export type { LoggerConfig, LogLevel, PipeworkLogger, LoggingConfig, ContextField } from './types.js';
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/logging/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,SAAS,EAAE,aAAa,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AACpH,OAAO,EAAE,GAAG,EAAE,MAAM,YAAY,CAAA;AAChC,YAAY,EAAE,YAAY,EAAE,QAAQ,EAAE,cAAc,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/logging/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,SAAS,EAAE,aAAa,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AACpH,OAAO,EAAE,GAAG,EAAE,MAAM,YAAY,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { PipeworkLogger, LoggerConfig, LoggingConfig } from './types.js';
|
|
2
|
+
export declare const DEFAULT_REDACT_PATHS: readonly string[];
|
|
3
|
+
export declare function createPipeworkLogger(config?: LoggerConfig): PipeworkLogger;
|
|
4
|
+
export declare function setLoggingConfig(config: LoggingConfig): void;
|
|
5
|
+
export declare function getLoggingConfig(): LoggingConfig | null;
|
|
6
|
+
export declare function getLogger(): PipeworkLogger;
|
|
7
|
+
export declare function getBaseLogger(): PipeworkLogger;
|
|
8
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logging/logger.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAG7E,eAAO,MAAM,oBAAoB,EAAE,SAAS,MAAM,EAOjD,CAAA;AAKD,wBAAgB,oBAAoB,CAAC,MAAM,GAAE,YAAiB,GAAG,cAAc,CAY9E;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI,CAE5D;AAED,wBAAgB,gBAAgB,IAAI,aAAa,GAAG,IAAI,CAEvD;AAED,wBAAgB,SAAS,IAAI,cAAc,CAM1C;AAED,wBAAgB,aAAa,IAAI,cAAc,CAE9C"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import pino from 'pino';
|
|
2
|
+
import { getCorrelationFields } from './context.js';
|
|
3
|
+
export const DEFAULT_REDACT_PATHS = [
|
|
4
|
+
'password',
|
|
5
|
+
'token',
|
|
6
|
+
'authorization',
|
|
7
|
+
'*.password',
|
|
8
|
+
'*.token',
|
|
9
|
+
'*.authorization',
|
|
10
|
+
];
|
|
11
|
+
let baseLogger = null;
|
|
12
|
+
let loggingConfig = null;
|
|
13
|
+
export function createPipeworkLogger(config = {}) {
|
|
14
|
+
const level = config.level ?? 'info';
|
|
15
|
+
const redact = config.redact ?? [...DEFAULT_REDACT_PATHS];
|
|
16
|
+
const pinoOpts = { level, redact: redact };
|
|
17
|
+
if (config.pretty === true) {
|
|
18
|
+
pinoOpts.transport = { target: 'pino-pretty', options: { colorize: true } };
|
|
19
|
+
}
|
|
20
|
+
baseLogger = pino(pinoOpts);
|
|
21
|
+
return baseLogger;
|
|
22
|
+
}
|
|
23
|
+
export function setLoggingConfig(config) {
|
|
24
|
+
loggingConfig = config;
|
|
25
|
+
}
|
|
26
|
+
export function getLoggingConfig() {
|
|
27
|
+
return loggingConfig;
|
|
28
|
+
}
|
|
29
|
+
export function getLogger() {
|
|
30
|
+
const base = baseLogger ?? pino({ level: 'info' });
|
|
31
|
+
const fields = getCorrelationFields();
|
|
32
|
+
if (Object.keys(fields).length === 0)
|
|
33
|
+
return base;
|
|
34
|
+
return base.child(fields);
|
|
35
|
+
}
|
|
36
|
+
export function getBaseLogger() {
|
|
37
|
+
return baseLogger ?? pino({ level: 'info' });
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logging/logger.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAA;AAEvB,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAA;AAEnD,MAAM,CAAC,MAAM,oBAAoB,GAAsB;IACrD,UAAU;IACV,OAAO;IACP,eAAe;IACf,YAAY;IACZ,SAAS;IACT,iBAAiB;CAClB,CAAA;AAED,IAAI,UAAU,GAA0B,IAAI,CAAA;AAC5C,IAAI,aAAa,GAAyB,IAAI,CAAA;AAE9C,MAAM,UAAU,oBAAoB,CAAC,SAAuB,EAAE;IAC5D,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,MAAM,CAAA;IACpC,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,CAAC,GAAG,oBAAoB,CAAC,CAAA;IAEzD,MAAM,QAAQ,GAAuB,EAAE,KAAK,EAAE,MAAM,EAAE,MAAkB,EAAE,CAAA;IAE1E,IAAI,MAAM,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;QAC3B,QAAQ,CAAC,SAAS,GAAG,EAAE,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,CAAA;IAC7E,CAAC;IAED,UAAU,GAAG,IAAI,CAAC,QAAQ,CAA8B,CAAA;IACxD,OAAO,UAAU,CAAA;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,MAAqB;IACpD,aAAa,GAAG,MAAM,CAAA;AACxB,CAAC;AAED,MAAM,UAAU,gBAAgB;IAC9B,OAAO,aAAa,CAAA;AACtB,CAAC;AAED,MAAM,UAAU,SAAS;IACvB,MAAM,IAAI,GAAG,UAAU,IAAK,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAA+B,CAAA;IACjF,MAAM,MAAM,GAAG,oBAAoB,EAAE,CAAA;IAErC,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAA;IACjD,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;AAC3B,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,UAAU,IAAK,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAA+B,CAAA;AAC7E,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy.d.ts","sourceRoot":"","sources":["../../src/logging/proxy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAGhD,eAAO,MAAM,GAAG,EAAE,cAUhB,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { getLogger } from './logger.js';
|
|
2
|
+
export const log = new Proxy({}, {
|
|
3
|
+
get(target, prop) {
|
|
4
|
+
if (Object.hasOwn(target, prop))
|
|
5
|
+
return target[prop];
|
|
6
|
+
const logger = getLogger();
|
|
7
|
+
const value = logger[prop];
|
|
8
|
+
if (typeof value === 'function') {
|
|
9
|
+
return value.bind(logger);
|
|
10
|
+
}
|
|
11
|
+
return value;
|
|
12
|
+
},
|
|
13
|
+
});
|
|
14
|
+
//# sourceMappingURL=proxy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy.js","sourceRoot":"","sources":["../../src/logging/proxy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAEvC,MAAM,CAAC,MAAM,GAAG,GAAmB,IAAI,KAAK,CAAC,EAAoB,EAAE;IACjE,GAAG,CAAC,MAAM,EAAE,IAAqB;QAC/B,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC;YAAE,OAAQ,MAAsD,CAAC,IAAI,CAAC,CAAA;QACrG,MAAM,MAAM,GAAG,SAAS,EAAE,CAAA;QAC1B,MAAM,KAAK,GAAG,MAAM,CAAC,IAA4B,CAAC,CAAA;QAClD,IAAI,OAAO,KAAK,KAAK,UAAU,EAAE,CAAC;YAChC,OAAQ,KAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QACzC,CAAC;QACD,OAAO,KAAK,CAAA;IACd,CAAC;CACF,CAAC,CAAA"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export type LogLevel = 'fatal' | 'error' | 'warn' | 'info' | 'debug' | 'trace';
|
|
2
|
+
export type ContextField = 'requestId' | 'tenantId' | 'userId' | 'sessionId' | 'traceId';
|
|
3
|
+
export interface PipeworkLogger {
|
|
4
|
+
info(msg: string): void;
|
|
5
|
+
info(obj: Record<string, unknown>, msg?: string): void;
|
|
6
|
+
warn(msg: string): void;
|
|
7
|
+
warn(obj: Record<string, unknown>, msg?: string): void;
|
|
8
|
+
error(msg: string): void;
|
|
9
|
+
error(obj: Record<string, unknown>, msg?: string): void;
|
|
10
|
+
debug(msg: string): void;
|
|
11
|
+
debug(obj: Record<string, unknown>, msg?: string): void;
|
|
12
|
+
fatal(msg: string): void;
|
|
13
|
+
fatal(obj: Record<string, unknown>, msg?: string): void;
|
|
14
|
+
trace(msg: string): void;
|
|
15
|
+
trace(obj: Record<string, unknown>, msg?: string): void;
|
|
16
|
+
child(bindings: Record<string, unknown>): PipeworkLogger;
|
|
17
|
+
silent: boolean;
|
|
18
|
+
}
|
|
19
|
+
export interface LoggerConfig {
|
|
20
|
+
readonly level?: LogLevel;
|
|
21
|
+
readonly pretty?: boolean;
|
|
22
|
+
readonly slowQueryMs?: number;
|
|
23
|
+
readonly redact?: readonly string[] | {
|
|
24
|
+
readonly paths: readonly string[];
|
|
25
|
+
readonly censor?: string;
|
|
26
|
+
readonly remove?: boolean;
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
export interface LoggingConfig {
|
|
30
|
+
readonly traceHeader?: string;
|
|
31
|
+
readonly requestIdHeader?: string;
|
|
32
|
+
readonly sessionHeader?: string;
|
|
33
|
+
readonly authFields?: readonly string[];
|
|
34
|
+
readonly contextFields?: readonly ContextField[];
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/logging/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,CAAA;AAE9E,MAAM,MAAM,YAAY,GAAG,WAAW,GAAG,UAAU,GAAG,QAAQ,GAAG,WAAW,GAAG,SAAS,CAAA;AAExF,MAAM,WAAW,cAAc;IAC7B,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtD,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,cAAc,CAAA;IACxD,MAAM,EAAE,OAAO,CAAA;CAChB;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,KAAK,CAAC,EAAE,QAAQ,CAAA;IACzB,QAAQ,CAAC,MAAM,CAAC,EAAE,OAAO,CAAA;IACzB,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,MAAM,CAAC,EAAE,SAAS,MAAM,EAAE,GAAG;QACpC,QAAQ,CAAC,KAAK,EAAE,SAAS,MAAM,EAAE,CAAA;QACjC,QAAQ,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;QACxB,QAAQ,CAAC,MAAM,CAAC,EAAE,OAAO,CAAA;KAC1B,CAAA;CACF;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,eAAe,CAAC,EAAE,MAAM,CAAA;IACjC,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,CAAA;IAC/B,QAAQ,CAAC,UAAU,CAAC,EAAE,SAAS,MAAM,EAAE,CAAA;IACvC,QAAQ,CAAC,aAAa,CAAC,EAAE,SAAS,YAAY,EAAE,CAAA;CACjD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/logging/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { type MigrationHazard, type Severity } from './safety.js';
|
|
2
|
+
export interface MigrationCheckResult {
|
|
3
|
+
safe: boolean;
|
|
4
|
+
hasDestructive: boolean;
|
|
5
|
+
hasLocking: boolean;
|
|
6
|
+
fileHazards: {
|
|
7
|
+
file: string;
|
|
8
|
+
hazards: MigrationHazard[];
|
|
9
|
+
}[];
|
|
10
|
+
}
|
|
11
|
+
export declare function checkMigrations(migrationsFolder: string): MigrationCheckResult;
|
|
12
|
+
export declare function formatCheckResult(result: MigrationCheckResult): string;
|
|
13
|
+
export type { MigrationHazard, Severity };
|
|
14
|
+
//# sourceMappingURL=check.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check.d.ts","sourceRoot":"","sources":["../../src/migrate/check.ts"],"names":[],"mappings":"AAEA,OAAO,EAA6B,KAAK,eAAe,EAAE,KAAK,QAAQ,EAAE,MAAM,aAAa,CAAA;AAE5F,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,OAAO,CAAA;IACb,cAAc,EAAE,OAAO,CAAA;IACvB,UAAU,EAAE,OAAO,CAAA;IACnB,WAAW,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,eAAe,EAAE,CAAA;KAAE,EAAE,CAAA;CAC5D;AAYD,wBAAgB,eAAe,CAAC,gBAAgB,EAAE,MAAM,GAAG,oBAAoB,CA+B9E;AAED,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,oBAAoB,GAAG,MAAM,CAyBtE;AAED,YAAY,EAAE,eAAe,EAAE,QAAQ,EAAE,CAAA"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { readFileSync, existsSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import { analyzeSQL, formatHazards } from './safety.js';
|
|
4
|
+
export function checkMigrations(migrationsFolder) {
|
|
5
|
+
const journalPath = join(migrationsFolder, 'meta', '_journal.json');
|
|
6
|
+
if (!existsSync(journalPath)) {
|
|
7
|
+
return { safe: true, hasDestructive: false, hasLocking: false, fileHazards: [] };
|
|
8
|
+
}
|
|
9
|
+
const journal = JSON.parse(readFileSync(journalPath, 'utf-8'));
|
|
10
|
+
const fileHazards = [];
|
|
11
|
+
let hasDestructive = false;
|
|
12
|
+
let hasLocking = false;
|
|
13
|
+
for (const entry of journal.entries) {
|
|
14
|
+
const sqlPath = join(migrationsFolder, `${entry.tag}.sql`);
|
|
15
|
+
if (!existsSync(sqlPath))
|
|
16
|
+
continue;
|
|
17
|
+
const sql = readFileSync(sqlPath, 'utf-8');
|
|
18
|
+
const hazards = analyzeSQL(sql);
|
|
19
|
+
if (hazards.length > 0) {
|
|
20
|
+
fileHazards.push({ file: `${entry.tag}.sql`, hazards });
|
|
21
|
+
if (hazards.some(h => h.severity === 'destructive'))
|
|
22
|
+
hasDestructive = true;
|
|
23
|
+
if (hazards.some(h => h.severity === 'locking'))
|
|
24
|
+
hasLocking = true;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return {
|
|
28
|
+
safe: !hasDestructive && !hasLocking,
|
|
29
|
+
hasDestructive,
|
|
30
|
+
hasLocking,
|
|
31
|
+
fileHazards,
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
export function formatCheckResult(result) {
|
|
35
|
+
if (result.safe)
|
|
36
|
+
return '';
|
|
37
|
+
const lines = [];
|
|
38
|
+
const dCount = result.fileHazards.reduce((n, f) => n + f.hazards.filter(h => h.severity === 'destructive').length, 0);
|
|
39
|
+
const lCount = result.fileHazards.reduce((n, f) => n + f.hazards.filter(h => h.severity === 'locking').length, 0);
|
|
40
|
+
const parts = [];
|
|
41
|
+
if (dCount > 0)
|
|
42
|
+
parts.push(`${dCount} destructive`);
|
|
43
|
+
if (lCount > 0)
|
|
44
|
+
parts.push(`${lCount} locking`);
|
|
45
|
+
lines.push(`Migration safety check: ${parts.join(' and ')} operation${dCount + lCount > 1 ? 's' : ''} detected.\n`);
|
|
46
|
+
for (const { file, hazards } of result.fileHazards) {
|
|
47
|
+
lines.push(formatHazards(hazards, file));
|
|
48
|
+
}
|
|
49
|
+
lines.push('');
|
|
50
|
+
if (dCount > 0) {
|
|
51
|
+
lines.push('Pass --allow-destructive to run destructive migrations.');
|
|
52
|
+
}
|
|
53
|
+
if (lCount > 0) {
|
|
54
|
+
lines.push('Pass --acknowledge-lock to run migrations that acquire heavy locks.');
|
|
55
|
+
}
|
|
56
|
+
return lines.join('\n');
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=check.js.map
|