pipework 0.7.13 → 0.7.18
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 +23 -0
- package/README.md +3 -2
- package/REFERENCE.md +327 -296
- package/dist/REFERENCE.md +396 -431
- package/dist/auth/tenant/scope.d.ts +1 -1
- package/dist/auth/tenant/scope.d.ts.map +1 -1
- package/dist/cli/commands/check.d.ts +2 -1
- package/dist/cli/commands/check.d.ts.map +1 -1
- package/dist/cli/commands/check.js +52 -17
- package/dist/cli/commands/check.js.map +1 -1
- package/dist/cli/commands/migrate.d.ts.map +1 -1
- package/dist/cli/commands/migrate.js +3 -6
- package/dist/cli/commands/migrate.js.map +1 -1
- package/dist/cli/commands/scope.d.ts +12 -0
- package/dist/cli/commands/scope.d.ts.map +1 -0
- package/dist/cli/commands/scope.js +25 -0
- package/dist/cli/commands/scope.js.map +1 -0
- package/dist/cli/commands/test.d.ts +3 -0
- package/dist/cli/commands/test.d.ts.map +1 -1
- package/dist/cli/commands/test.js +65 -1
- package/dist/cli/commands/test.js.map +1 -1
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +21 -2
- package/dist/cli/index.js.map +1 -1
- package/dist/config/discover.d.ts.map +1 -1
- package/dist/config/discover.js +0 -14
- package/dist/config/discover.js.map +1 -1
- package/dist/core/config/namespace.d.ts +123 -120
- package/dist/core/config/namespace.d.ts.map +1 -1
- package/dist/core/config/schema.d.ts +8 -0
- package/dist/core/config/schema.d.ts.map +1 -1
- package/dist/core/config/schema.js +2 -0
- package/dist/core/config/schema.js.map +1 -1
- package/dist/data/db/col/index.d.ts +1 -1
- package/dist/data/db/col/index.d.ts.map +1 -1
- package/dist/data/db/col/index.js +1 -1
- package/dist/data/db/col/index.js.map +1 -1
- package/dist/data/db/excluded.js +2 -2
- package/dist/data/db/excluded.js.map +1 -1
- package/dist/data/db/filter.d.ts +12 -12
- package/dist/data/db/generated/drizzle-orm/aggregate.d.ts +1 -1
- package/dist/data/db/generated/drizzle-orm/aggregate.d.ts.map +1 -1
- package/dist/data/db/generated/drizzle-orm/aggregate.js +1 -1
- package/dist/data/db/generated/drizzle-orm/aggregate.js.map +1 -1
- package/dist/data/db/generated/drizzle-orm/introspection.d.ts +1 -1
- package/dist/data/db/generated/drizzle-orm/introspection.d.ts.map +1 -1
- package/dist/data/db/generated/drizzle-orm/introspection.js +1 -1
- package/dist/data/db/generated/drizzle-orm/introspection.js.map +1 -1
- package/dist/data/db/generated/drizzle-orm/operator.d.ts +1 -1
- package/dist/data/db/generated/drizzle-orm/operator.d.ts.map +1 -1
- package/dist/data/db/generated/drizzle-orm/operator.js +1 -1
- package/dist/data/db/generated/drizzle-orm/operator.js.map +1 -1
- package/dist/data/db/generated/drizzle-orm/relation.d.ts +1 -1
- package/dist/data/db/generated/drizzle-orm/relation.d.ts.map +1 -1
- package/dist/data/db/generated/drizzle-orm/relation.js +1 -1
- package/dist/data/db/generated/drizzle-orm/relation.js.map +1 -1
- package/dist/data/db/generated/drizzle-orm/type.d.ts +2 -2
- package/dist/data/db/generated/drizzle-orm/type.d.ts.map +1 -1
- package/dist/data/db/generated/drizzle-orm/type.js +1 -1
- package/dist/data/db/generated/drizzle-orm/type.js.map +1 -1
- package/dist/data/db/generated/pg-core/introspection.d.ts +1 -1
- package/dist/data/db/generated/pg-core/introspection.d.ts.map +1 -1
- package/dist/data/db/generated/pg-core/introspection.js +1 -1
- package/dist/data/db/generated/pg-core/introspection.js.map +1 -1
- package/dist/data/db/generated/pg-core/set-operation.d.ts +1 -1
- package/dist/data/db/generated/pg-core/set-operation.d.ts.map +1 -1
- package/dist/data/db/generated/pg-core/set-operation.js +1 -1
- package/dist/data/db/generated/pg-core/set-operation.js.map +1 -1
- package/dist/data/db/generated/pg-core/type.d.ts +2 -2
- package/dist/data/db/generated/pg-core/type.d.ts.map +1 -1
- package/dist/data/db/generated/pg-core/type.js +1 -1
- package/dist/data/db/generated/pg-core/type.js.map +1 -1
- package/dist/data/db/idx/index.d.ts +1 -1
- package/dist/data/db/idx/index.d.ts.map +1 -1
- package/dist/data/db/idx/index.js +1 -1
- package/dist/data/db/idx/index.js.map +1 -1
- package/dist/data/db/namespace.d.ts +43 -43
- package/dist/data/db/pool.d.ts +1 -1
- package/dist/data/db/pool.d.ts.map +1 -1
- package/dist/data/db/pool.js +1 -1
- package/dist/data/db/pool.js.map +1 -1
- package/dist/data/db/schema-features.d.ts +1 -1
- package/dist/data/db/schema-features.d.ts.map +1 -1
- package/dist/data/db/schema-features.js +1 -1
- package/dist/data/db/schema-features.js.map +1 -1
- package/dist/data/db/sql.d.ts +1 -1
- package/dist/data/db/sql.d.ts.map +1 -1
- package/dist/data/db/sql.js +1 -1
- package/dist/data/db/sql.js.map +1 -1
- package/dist/data/db/types.d.ts +3 -3
- package/dist/data/db/types.d.ts.map +1 -1
- package/dist/data/domain/project-table.d.ts +2 -2
- package/dist/data/domain/project-table.js +2 -2
- package/dist/data/domain/project-table.js.map +1 -1
- package/dist/data/domain/types.d.ts +1 -1
- package/dist/data/domain/types.d.ts.map +1 -1
- package/dist/data/migrate/apply.d.ts +8 -0
- package/dist/data/migrate/apply.d.ts.map +1 -0
- package/dist/data/migrate/apply.js +91 -0
- package/dist/data/migrate/apply.js.map +1 -0
- package/dist/data/migrate/diff.d.ts +118 -0
- package/dist/data/migrate/diff.d.ts.map +1 -0
- package/dist/data/migrate/diff.js +215 -0
- package/dist/data/migrate/diff.js.map +1 -0
- package/dist/data/migrate/generate.d.ts.map +1 -1
- package/dist/data/migrate/generate.js +12 -22
- package/dist/data/migrate/generate.js.map +1 -1
- package/dist/data/migrate/run.d.ts.map +1 -1
- package/dist/data/migrate/run.js +5 -16
- package/dist/data/migrate/run.js.map +1 -1
- package/dist/data/migrate/snapshot.d.ts +87 -0
- package/dist/data/migrate/snapshot.d.ts.map +1 -0
- package/dist/data/migrate/snapshot.js +204 -0
- package/dist/data/migrate/snapshot.js.map +1 -0
- package/dist/data/migrate/sql-emit.d.ts +3 -0
- package/dist/data/migrate/sql-emit.d.ts.map +1 -0
- package/dist/data/migrate/sql-emit.js +220 -0
- package/dist/data/migrate/sql-emit.js.map +1 -0
- package/dist/data/query/alias.d.ts +32 -0
- package/dist/data/query/alias.d.ts.map +1 -0
- package/dist/data/query/alias.js +101 -0
- package/dist/data/query/alias.js.map +1 -0
- package/dist/data/query/batch.d.ts +7 -0
- package/dist/data/query/batch.d.ts.map +1 -0
- package/dist/data/query/batch.js +2 -0
- package/dist/data/query/batch.js.map +1 -0
- package/dist/data/query/cache/core/cache.d.ts +37 -0
- package/dist/data/query/cache/core/cache.d.ts.map +1 -0
- package/dist/data/query/cache/core/cache.js +29 -0
- package/dist/data/query/cache/core/cache.js.map +1 -0
- package/dist/data/query/cache/core/index.d.ts +2 -0
- package/dist/data/query/cache/core/index.d.ts.map +1 -0
- package/dist/data/query/cache/core/index.js +2 -0
- package/dist/data/query/cache/core/index.js.map +1 -0
- package/dist/data/query/cache/core/types.d.ts +34 -0
- package/dist/data/query/cache/core/types.d.ts.map +1 -0
- package/dist/data/query/cache/core/types.js +2 -0
- package/dist/data/query/cache/core/types.js.map +1 -0
- package/dist/data/query/casing.d.ts +17 -0
- package/dist/data/query/casing.d.ts.map +1 -0
- package/dist/data/query/casing.js +62 -0
- package/dist/data/query/casing.js.map +1 -0
- package/dist/data/query/column-builder.d.ts +241 -0
- package/dist/data/query/column-builder.d.ts.map +1 -0
- package/dist/data/query/column-builder.js +105 -0
- package/dist/data/query/column-builder.js.map +1 -0
- package/dist/data/query/column.d.ts +70 -0
- package/dist/data/query/column.d.ts.map +1 -0
- package/dist/data/query/column.js +57 -0
- package/dist/data/query/column.js.map +1 -0
- package/dist/data/query/entity.d.ts +8 -0
- package/dist/data/query/entity.d.ts.map +1 -0
- package/dist/data/query/entity.js +25 -0
- package/dist/data/query/entity.js.map +1 -0
- package/dist/data/query/errors.d.ts +19 -0
- package/dist/data/query/errors.d.ts.map +1 -0
- package/dist/data/query/errors.js +31 -0
- package/dist/data/query/errors.js.map +1 -0
- package/dist/data/query/index.d.ts +15 -0
- package/dist/data/query/index.d.ts.map +1 -0
- package/dist/data/query/index.js +15 -0
- package/dist/data/query/index.js.map +1 -0
- package/dist/data/query/logger.d.ts +24 -0
- package/dist/data/query/logger.d.ts.map +1 -0
- package/dist/data/query/logger.js +33 -0
- package/dist/data/query/logger.js.map +1 -0
- package/dist/data/query/operations.d.ts +25 -0
- package/dist/data/query/operations.d.ts.map +1 -0
- package/dist/data/query/operations.js +2 -0
- package/dist/data/query/operations.js.map +1 -0
- package/dist/data/query/pg-core/alias.d.ts +5 -0
- package/dist/data/query/pg-core/alias.d.ts.map +1 -0
- package/dist/data/query/pg-core/alias.js +5 -0
- package/dist/data/query/pg-core/alias.js.map +1 -0
- package/dist/data/query/pg-core/checks.d.ts +21 -0
- package/dist/data/query/pg-core/checks.d.ts.map +1 -0
- package/dist/data/query/pg-core/checks.js +30 -0
- package/dist/data/query/pg-core/checks.js.map +1 -0
- package/dist/data/query/pg-core/columns/all.d.ts +68 -0
- package/dist/data/query/pg-core/columns/all.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/all.js +69 -0
- package/dist/data/query/pg-core/columns/all.js.map +1 -0
- package/dist/data/query/pg-core/columns/bigint.d.ts +54 -0
- package/dist/data/query/pg-core/columns/bigint.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/bigint.js +54 -0
- package/dist/data/query/pg-core/columns/bigint.js.map +1 -0
- package/dist/data/query/pg-core/columns/bigserial.d.ts +53 -0
- package/dist/data/query/pg-core/columns/bigserial.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/bigserial.js +56 -0
- package/dist/data/query/pg-core/columns/bigserial.js.map +1 -0
- package/dist/data/query/pg-core/columns/boolean.d.ts +28 -0
- package/dist/data/query/pg-core/columns/boolean.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/boolean.js +22 -0
- package/dist/data/query/pg-core/columns/boolean.js.map +1 -0
- package/dist/data/query/pg-core/columns/char.d.ts +53 -0
- package/dist/data/query/pg-core/columns/char.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/char.js +28 -0
- package/dist/data/query/pg-core/columns/char.js.map +1 -0
- package/dist/data/query/pg-core/columns/cidr.d.ts +28 -0
- package/dist/data/query/pg-core/columns/cidr.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/cidr.js +22 -0
- package/dist/data/query/pg-core/columns/cidr.js.map +1 -0
- package/dist/data/query/pg-core/columns/common.d.ts +167 -0
- package/dist/data/query/pg-core/columns/common.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/common.js +190 -0
- package/dist/data/query/pg-core/columns/common.js.map +1 -0
- package/dist/data/query/pg-core/columns/custom.d.ts +160 -0
- package/dist/data/query/pg-core/columns/custom.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/custom.js +46 -0
- package/dist/data/query/pg-core/columns/custom.js.map +1 -0
- package/dist/data/query/pg-core/columns/date.common.d.ts +8 -0
- package/dist/data/query/pg-core/columns/date.common.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/date.common.js +10 -0
- package/dist/data/query/pg-core/columns/date.common.js.map +1 -0
- package/dist/data/query/pg-core/columns/date.d.ts +57 -0
- package/dist/data/query/pg-core/columns/date.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/date.js +57 -0
- package/dist/data/query/pg-core/columns/date.js.map +1 -0
- package/dist/data/query/pg-core/columns/double-precision.d.ts +29 -0
- package/dist/data/query/pg-core/columns/double-precision.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/double-precision.js +28 -0
- package/dist/data/query/pg-core/columns/double-precision.js.map +1 -0
- package/dist/data/query/pg-core/columns/enum.d.ts +102 -0
- package/dist/data/query/pg-core/columns/enum.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/enum.js +78 -0
- package/dist/data/query/pg-core/columns/enum.js.map +1 -0
- package/dist/data/query/pg-core/columns/index.d.ts +36 -0
- package/dist/data/query/pg-core/columns/index.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/index.js +36 -0
- package/dist/data/query/pg-core/columns/index.js.map +1 -0
- package/dist/data/query/pg-core/columns/inet.d.ts +28 -0
- package/dist/data/query/pg-core/columns/inet.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/inet.js +22 -0
- package/dist/data/query/pg-core/columns/inet.js.map +1 -0
- package/dist/data/query/pg-core/columns/int.common.d.ts +16 -0
- package/dist/data/query/pg-core/columns/int.common.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/int.common.js +42 -0
- package/dist/data/query/pg-core/columns/int.common.js.map +1 -0
- package/dist/data/query/pg-core/columns/integer.d.ts +30 -0
- package/dist/data/query/pg-core/columns/integer.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/integer.js +29 -0
- package/dist/data/query/pg-core/columns/integer.js.map +1 -0
- package/dist/data/query/pg-core/columns/interval.d.ts +40 -0
- package/dist/data/query/pg-core/columns/interval.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/interval.js +29 -0
- package/dist/data/query/pg-core/columns/interval.js.map +1 -0
- package/dist/data/query/pg-core/columns/json.d.ts +33 -0
- package/dist/data/query/pg-core/columns/json.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/json.js +39 -0
- package/dist/data/query/pg-core/columns/json.js.map +1 -0
- package/dist/data/query/pg-core/columns/jsonb.d.ts +33 -0
- package/dist/data/query/pg-core/columns/jsonb.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/jsonb.js +39 -0
- package/dist/data/query/pg-core/columns/jsonb.js.map +1 -0
- package/dist/data/query/pg-core/columns/line.d.ts +69 -0
- package/dist/data/query/pg-core/columns/line.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/line.js +57 -0
- package/dist/data/query/pg-core/columns/line.js.map +1 -0
- package/dist/data/query/pg-core/columns/macaddr.d.ts +28 -0
- package/dist/data/query/pg-core/columns/macaddr.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/macaddr.js +22 -0
- package/dist/data/query/pg-core/columns/macaddr.js.map +1 -0
- package/dist/data/query/pg-core/columns/macaddr8.d.ts +28 -0
- package/dist/data/query/pg-core/columns/macaddr8.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/macaddr8.js +22 -0
- package/dist/data/query/pg-core/columns/macaddr8.js.map +1 -0
- package/dist/data/query/pg-core/columns/numeric.d.ts +112 -0
- package/dist/data/query/pg-core/columns/numeric.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/numeric.js +126 -0
- package/dist/data/query/pg-core/columns/numeric.js.map +1 -0
- package/dist/data/query/pg-core/columns/point.d.ts +72 -0
- package/dist/data/query/pg-core/columns/point.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/point.js +63 -0
- package/dist/data/query/pg-core/columns/point.js.map +1 -0
- package/dist/data/query/pg-core/columns/postgis_extension/geometry.d.ts +68 -0
- package/dist/data/query/pg-core/columns/postgis_extension/geometry.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/postgis_extension/geometry.js +57 -0
- package/dist/data/query/pg-core/columns/postgis_extension/geometry.js.map +1 -0
- package/dist/data/query/pg-core/columns/postgis_extension/utils.d.ts +2 -0
- package/dist/data/query/pg-core/columns/postgis_extension/utils.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/postgis_extension/utils.js +39 -0
- package/dist/data/query/pg-core/columns/postgis_extension/utils.js.map +1 -0
- package/dist/data/query/pg-core/columns/real.d.ts +34 -0
- package/dist/data/query/pg-core/columns/real.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/real.js +32 -0
- package/dist/data/query/pg-core/columns/real.js.map +1 -0
- package/dist/data/query/pg-core/columns/serial.d.ts +28 -0
- package/dist/data/query/pg-core/columns/serial.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/serial.js +24 -0
- package/dist/data/query/pg-core/columns/serial.js.map +1 -0
- package/dist/data/query/pg-core/columns/smallint.d.ts +30 -0
- package/dist/data/query/pg-core/columns/smallint.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/smallint.js +29 -0
- package/dist/data/query/pg-core/columns/smallint.js.map +1 -0
- package/dist/data/query/pg-core/columns/smallserial.d.ts +28 -0
- package/dist/data/query/pg-core/columns/smallserial.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/smallserial.js +24 -0
- package/dist/data/query/pg-core/columns/smallserial.js.map +1 -0
- package/dist/data/query/pg-core/columns/text.d.ts +38 -0
- package/dist/data/query/pg-core/columns/text.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/text.js +26 -0
- package/dist/data/query/pg-core/columns/text.js.map +1 -0
- package/dist/data/query/pg-core/columns/time.d.ts +45 -0
- package/dist/data/query/pg-core/columns/time.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/time.js +39 -0
- package/dist/data/query/pg-core/columns/time.js.map +1 -0
- package/dist/data/query/pg-core/columns/timestamp.d.ts +76 -0
- package/dist/data/query/pg-core/columns/timestamp.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/timestamp.js +83 -0
- package/dist/data/query/pg-core/columns/timestamp.js.map +1 -0
- package/dist/data/query/pg-core/columns/uuid.d.ts +32 -0
- package/dist/data/query/pg-core/columns/uuid.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/uuid.js +29 -0
- package/dist/data/query/pg-core/columns/uuid.js.map +1 -0
- package/dist/data/query/pg-core/columns/varchar.d.ts +53 -0
- package/dist/data/query/pg-core/columns/varchar.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/varchar.js +28 -0
- package/dist/data/query/pg-core/columns/varchar.js.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/bit.d.ts +45 -0
- package/dist/data/query/pg-core/columns/vector_extension/bit.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/bit.js +26 -0
- package/dist/data/query/pg-core/columns/vector_extension/bit.js.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/halfvec.d.ts +49 -0
- package/dist/data/query/pg-core/columns/vector_extension/halfvec.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/halfvec.js +35 -0
- package/dist/data/query/pg-core/columns/vector_extension/halfvec.js.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/sparsevec.d.ts +36 -0
- package/dist/data/query/pg-core/columns/vector_extension/sparsevec.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/sparsevec.js +26 -0
- package/dist/data/query/pg-core/columns/vector_extension/sparsevec.js.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/vector.d.ts +49 -0
- package/dist/data/query/pg-core/columns/vector_extension/vector.d.ts.map +1 -0
- package/dist/data/query/pg-core/columns/vector_extension/vector.js +35 -0
- package/dist/data/query/pg-core/columns/vector_extension/vector.js.map +1 -0
- package/dist/data/query/pg-core/db.d.ts +292 -0
- package/dist/data/query/pg-core/db.d.ts.map +1 -0
- package/dist/data/query/pg-core/db.js +377 -0
- package/dist/data/query/pg-core/db.js.map +1 -0
- package/dist/data/query/pg-core/dialect.d.ts +66 -0
- package/dist/data/query/pg-core/dialect.d.ts.map +1 -0
- package/dist/data/query/pg-core/dialect.js +1099 -0
- package/dist/data/query/pg-core/dialect.js.map +1 -0
- package/dist/data/query/pg-core/expressions.d.ts +9 -0
- package/dist/data/query/pg-core/expressions.d.ts.map +1 -0
- package/dist/data/query/pg-core/expressions.js +18 -0
- package/dist/data/query/pg-core/expressions.js.map +1 -0
- package/dist/data/query/pg-core/foreign-keys.d.ts +57 -0
- package/dist/data/query/pg-core/foreign-keys.d.ts.map +1 -0
- package/dist/data/query/pg-core/foreign-keys.js +70 -0
- package/dist/data/query/pg-core/foreign-keys.js.map +1 -0
- package/dist/data/query/pg-core/index.d.ts +22 -0
- package/dist/data/query/pg-core/index.d.ts.map +1 -0
- package/dist/data/query/pg-core/index.js +22 -0
- package/dist/data/query/pg-core/index.js.map +1 -0
- package/dist/data/query/pg-core/indexes.d.ts +84 -0
- package/dist/data/query/pg-core/indexes.d.ts.map +1 -0
- package/dist/data/query/pg-core/indexes.js +100 -0
- package/dist/data/query/pg-core/indexes.js.map +1 -0
- package/dist/data/query/pg-core/policies.d.ts +27 -0
- package/dist/data/query/pg-core/policies.d.ts.map +1 -0
- package/dist/data/query/pg-core/policies.js +30 -0
- package/dist/data/query/pg-core/policies.js.map +1 -0
- package/dist/data/query/pg-core/primary-keys.d.ts +37 -0
- package/dist/data/query/pg-core/primary-keys.d.ts.map +1 -0
- package/dist/data/query/pg-core/primary-keys.js +38 -0
- package/dist/data/query/pg-core/primary-keys.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/count.d.ts +30 -0
- package/dist/data/query/pg-core/query-builders/count.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/count.js +45 -0
- package/dist/data/query/pg-core/query-builders/count.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/delete.d.ts +115 -0
- package/dist/data/query/pg-core/query-builders/delete.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/delete.js +103 -0
- package/dist/data/query/pg-core/query-builders/delete.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/index.d.ts +8 -0
- package/dist/data/query/pg-core/query-builders/index.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/index.js +8 -0
- package/dist/data/query/pg-core/query-builders/index.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/insert.d.ts +189 -0
- package/dist/data/query/pg-core/query-builders/insert.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/insert.js +201 -0
- package/dist/data/query/pg-core/query-builders/insert.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/query-builder.d.ts +38 -0
- package/dist/data/query/pg-core/query-builders/query-builder.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/query-builder.js +83 -0
- package/dist/data/query/pg-core/query-builders/query-builder.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/query.d.ts +56 -0
- package/dist/data/query/pg-core/query-builders/query.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/query.js +104 -0
- package/dist/data/query/pg-core/query-builders/query.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/raw.d.ts +27 -0
- package/dist/data/query/pg-core/query-builders/raw.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/raw.js +34 -0
- package/dist/data/query/pg-core/query-builders/raw.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/refresh-materialized-view.d.ts +38 -0
- package/dist/data/query/pg-core/query-builders/refresh-materialized-view.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/refresh-materialized-view.js +58 -0
- package/dist/data/query/pg-core/query-builders/refresh-materialized-view.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/select.d.ts +811 -0
- package/dist/data/query/pg-core/query-builders/select.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/select.js +993 -0
- package/dist/data/query/pg-core/query-builders/select.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/select.types.d.ts +141 -0
- package/dist/data/query/pg-core/query-builders/select.types.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/select.types.js +2 -0
- package/dist/data/query/pg-core/query-builders/select.types.js.map +1 -0
- package/dist/data/query/pg-core/query-builders/update.d.ts +183 -0
- package/dist/data/query/pg-core/query-builders/update.d.ts.map +1 -0
- package/dist/data/query/pg-core/query-builders/update.js +210 -0
- package/dist/data/query/pg-core/query-builders/update.js.map +1 -0
- package/dist/data/query/pg-core/roles.d.ts +22 -0
- package/dist/data/query/pg-core/roles.d.ts.map +1 -0
- package/dist/data/query/pg-core/roles.js +29 -0
- package/dist/data/query/pg-core/roles.js.map +1 -0
- package/dist/data/query/pg-core/schema.d.ts +23 -0
- package/dist/data/query/pg-core/schema.d.ts.map +1 -0
- package/dist/data/query/pg-core/schema.js +46 -0
- package/dist/data/query/pg-core/schema.js.map +1 -0
- package/dist/data/query/pg-core/sequence.d.ts +21 -0
- package/dist/data/query/pg-core/sequence.d.ts.map +1 -0
- package/dist/data/query/pg-core/sequence.js +23 -0
- package/dist/data/query/pg-core/sequence.js.map +1 -0
- package/dist/data/query/pg-core/session.d.ts +94 -0
- package/dist/data/query/pg-core/session.d.ts.map +1 -0
- package/dist/data/query/pg-core/session.js +169 -0
- package/dist/data/query/pg-core/session.js.map +1 -0
- package/dist/data/query/pg-core/subquery.d.ts +19 -0
- package/dist/data/query/pg-core/subquery.d.ts.map +1 -0
- package/dist/data/query/pg-core/subquery.js +2 -0
- package/dist/data/query/pg-core/subquery.js.map +1 -0
- package/dist/data/query/pg-core/table.d.ts +129 -0
- package/dist/data/query/pg-core/table.d.ts.map +1 -0
- package/dist/data/query/pg-core/table.js +62 -0
- package/dist/data/query/pg-core/table.js.map +1 -0
- package/dist/data/query/pg-core/unique-constraint.d.ts +34 -0
- package/dist/data/query/pg-core/unique-constraint.d.ts.map +1 -0
- package/dist/data/query/pg-core/unique-constraint.js +56 -0
- package/dist/data/query/pg-core/unique-constraint.js.map +1 -0
- package/dist/data/query/pg-core/utils/array.d.ts +4 -0
- package/dist/data/query/pg-core/utils/array.d.ts.map +1 -0
- package/dist/data/query/pg-core/utils/array.js +75 -0
- package/dist/data/query/pg-core/utils/array.js.map +1 -0
- package/dist/data/query/pg-core/utils/index.d.ts +2 -0
- package/dist/data/query/pg-core/utils/index.d.ts.map +1 -0
- package/dist/data/query/pg-core/utils/index.js +2 -0
- package/dist/data/query/pg-core/utils/index.js.map +1 -0
- package/dist/data/query/pg-core/utils.d.ts +56 -0
- package/dist/data/query/pg-core/utils.d.ts.map +1 -0
- package/dist/data/query/pg-core/utils.js +88 -0
- package/dist/data/query/pg-core/utils.js.map +1 -0
- package/dist/data/query/pg-core/view-base.d.ts +9 -0
- package/dist/data/query/pg-core/view-base.d.ts.map +1 -0
- package/dist/data/query/pg-core/view-base.js +6 -0
- package/dist/data/query/pg-core/view-base.js.map +1 -0
- package/dist/data/query/pg-core/view-common.d.ts +2 -0
- package/dist/data/query/pg-core/view-common.d.ts.map +1 -0
- package/dist/data/query/pg-core/view-common.js +2 -0
- package/dist/data/query/pg-core/view-common.js.map +1 -0
- package/dist/data/query/pg-core/view.d.ts +161 -0
- package/dist/data/query/pg-core/view.d.ts.map +1 -0
- package/dist/data/query/pg-core/view.js +243 -0
- package/dist/data/query/pg-core/view.js.map +1 -0
- package/dist/data/query/postgres-js/driver.d.ts +30 -0
- package/dist/data/query/postgres-js/driver.d.ts.map +1 -0
- package/dist/data/query/postgres-js/driver.js +77 -0
- package/dist/data/query/postgres-js/driver.js.map +1 -0
- package/dist/data/query/postgres-js/index.d.ts +3 -0
- package/dist/data/query/postgres-js/index.d.ts.map +1 -0
- package/dist/data/query/postgres-js/index.js +3 -0
- package/dist/data/query/postgres-js/index.js.map +1 -0
- package/dist/data/query/postgres-js/session.d.ts +67 -0
- package/dist/data/query/postgres-js/session.d.ts.map +1 -0
- package/dist/data/query/postgres-js/session.js +139 -0
- package/dist/data/query/postgres-js/session.js.map +1 -0
- package/dist/data/query/primary-key.d.ts +11 -0
- package/dist/data/query/primary-key.d.ts.map +1 -0
- package/dist/data/query/primary-key.js +11 -0
- package/dist/data/query/primary-key.js.map +1 -0
- package/dist/data/query/query-builders/query-builder.d.ts +14 -0
- package/dist/data/query/query-builders/query-builder.d.ts.map +1 -0
- package/dist/data/query/query-builders/query-builder.js +9 -0
- package/dist/data/query/query-builders/query-builder.js.map +1 -0
- package/dist/data/query/query-builders/select.types.d.ts +59 -0
- package/dist/data/query/query-builders/select.types.d.ts.map +1 -0
- package/dist/data/query/query-builders/select.types.js +2 -0
- package/dist/data/query/query-builders/select.types.js.map +1 -0
- package/dist/data/query/query-promise.d.ts +10 -0
- package/dist/data/query/query-promise.d.ts.map +1 -0
- package/dist/data/query/query-promise.js +21 -0
- package/dist/data/query/query-promise.js.map +1 -0
- package/dist/data/query/relations.d.ts +216 -0
- package/dist/data/query/relations.d.ts.map +1 -0
- package/dist/data/query/relations.js +257 -0
- package/dist/data/query/relations.js.map +1 -0
- package/dist/data/query/runnable-query.d.ts +11 -0
- package/dist/data/query/runnable-query.d.ts.map +1 -0
- package/dist/data/query/runnable-query.js +2 -0
- package/dist/data/query/runnable-query.js.map +1 -0
- package/dist/data/query/selection-proxy.d.ts +10 -0
- package/dist/data/query/selection-proxy.d.ts.map +1 -0
- package/dist/data/query/selection-proxy.js +62 -0
- package/dist/data/query/selection-proxy.js.map +1 -0
- package/dist/data/query/session.d.ts +8 -0
- package/dist/data/query/session.d.ts.map +1 -0
- package/dist/data/query/session.js +2 -0
- package/dist/data/query/session.js.map +1 -0
- package/dist/data/query/sql/expressions/conditions.d.ts +454 -0
- package/dist/data/query/sql/expressions/conditions.d.ts.map +1 -0
- package/dist/data/query/sql/expressions/conditions.js +393 -0
- package/dist/data/query/sql/expressions/conditions.js.map +1 -0
- package/dist/data/query/sql/expressions/index.d.ts +3 -0
- package/dist/data/query/sql/expressions/index.d.ts.map +1 -0
- package/dist/data/query/sql/expressions/index.js +3 -0
- package/dist/data/query/sql/expressions/index.js.map +1 -0
- package/dist/data/query/sql/expressions/select.d.ts +39 -0
- package/dist/data/query/sql/expressions/select.d.ts.map +1 -0
- package/dist/data/query/sql/expressions/select.js +42 -0
- package/dist/data/query/sql/expressions/select.js.map +1 -0
- package/dist/data/query/sql/functions/aggregate.d.ts +105 -0
- package/dist/data/query/sql/functions/aggregate.d.ts.map +1 -0
- package/dist/data/query/sql/functions/aggregate.js +122 -0
- package/dist/data/query/sql/functions/aggregate.js.map +1 -0
- package/dist/data/query/sql/functions/index.d.ts +3 -0
- package/dist/data/query/sql/functions/index.d.ts.map +1 -0
- package/dist/data/query/sql/functions/index.js +3 -0
- package/dist/data/query/sql/functions/index.js.map +1 -0
- package/dist/data/query/sql/functions/vector.d.ts +121 -0
- package/dist/data/query/sql/functions/vector.d.ts.map +1 -0
- package/dist/data/query/sql/functions/vector.js +152 -0
- package/dist/data/query/sql/functions/vector.js.map +1 -0
- package/dist/data/query/sql/index.d.ts +4 -0
- package/dist/data/query/sql/index.d.ts.map +1 -0
- package/dist/data/query/sql/index.js +4 -0
- package/dist/data/query/sql/index.js.map +1 -0
- package/dist/data/query/sql/sql.d.ts +254 -0
- package/dist/data/query/sql/sql.d.ts.map +1 -0
- package/dist/data/query/sql/sql.js +478 -0
- package/dist/data/query/sql/sql.js.map +1 -0
- package/dist/data/query/subquery.d.ts +21 -0
- package/dist/data/query/subquery.d.ts.map +1 -0
- package/dist/data/query/subquery.js +18 -0
- package/dist/data/query/subquery.js.map +1 -0
- package/dist/data/query/table.d.ts +142 -0
- package/dist/data/query/table.d.ts.map +1 -0
- package/dist/data/query/table.js +73 -0
- package/dist/data/query/table.js.map +1 -0
- package/dist/data/query/table.utils.d.ts +3 -0
- package/dist/data/query/table.utils.d.ts.map +1 -0
- package/dist/data/query/table.utils.js +3 -0
- package/dist/data/query/table.utils.js.map +1 -0
- package/dist/data/query/tracing-utils.d.ts +2 -0
- package/dist/data/query/tracing-utils.d.ts.map +1 -0
- package/dist/data/query/tracing-utils.js +4 -0
- package/dist/data/query/tracing-utils.js.map +1 -0
- package/dist/data/query/tracing.d.ts +10 -0
- package/dist/data/query/tracing.d.ts.map +1 -0
- package/dist/data/query/tracing.js +7 -0
- package/dist/data/query/tracing.js.map +1 -0
- package/dist/data/query/utils.d.ts +81 -0
- package/dist/data/query/utils.d.ts.map +1 -0
- package/dist/data/query/utils.js +193 -0
- package/dist/data/query/utils.js.map +1 -0
- package/dist/data/query/version.d.ts +3 -0
- package/dist/data/query/version.d.ts.map +1 -0
- package/dist/data/query/version.js +5 -0
- package/dist/data/query/version.js.map +1 -0
- package/dist/data/query/view-common.d.ts +2 -0
- package/dist/data/query/view-common.d.ts.map +1 -0
- package/dist/data/query/view-common.js +2 -0
- package/dist/data/query/view-common.js.map +1 -0
- package/dist/data/schema/namespace.d.ts +2 -2
- package/dist/data/temporal/columns.d.ts +4 -4
- package/dist/data/vector/types.d.ts +2 -2
- package/dist/db/index.d.ts +0 -1
- package/dist/db/index.d.ts.map +1 -1
- package/dist/db/index.js +0 -1
- package/dist/db/index.js.map +1 -1
- package/dist/db/namespace.d.ts +0 -5
- package/dist/db/namespace.d.ts.map +1 -1
- package/dist/db/namespace.js +0 -5
- package/dist/db/namespace.js.map +1 -1
- package/dist/domain/define.d.ts.map +1 -1
- package/dist/domain/define.js.map +1 -1
- package/dist/domain/field.d.ts +2 -4
- package/dist/domain/field.d.ts.map +1 -1
- package/dist/domain/field.js.map +1 -1
- package/dist/domain/index.d.ts +1 -1
- package/dist/domain/index.d.ts.map +1 -1
- package/dist/domain/types.d.ts +9 -37
- package/dist/domain/types.d.ts.map +1 -1
- package/dist/drizzle/index.d.ts +3 -0
- package/dist/drizzle/index.d.ts.map +1 -0
- package/dist/drizzle/index.js +3 -0
- package/dist/drizzle/index.js.map +1 -0
- package/dist/log/namespace.d.ts +1 -1
- package/dist/logging/index.d.ts +1 -1
- package/dist/logging/index.d.ts.map +1 -1
- package/dist/logging/proxy.d.ts +2 -2
- package/dist/logging/proxy.d.ts.map +1 -1
- package/dist/logging/proxy.js +2 -9
- package/dist/logging/proxy.js.map +1 -1
- package/dist/logging/types.d.ts +0 -7
- package/dist/logging/types.d.ts.map +1 -1
- package/dist/resource/batch.d.ts +17 -0
- package/dist/resource/batch.d.ts.map +1 -0
- package/dist/resource/batch.js +47 -0
- package/dist/resource/batch.js.map +1 -0
- package/dist/resource/builder.d.ts +11 -0
- package/dist/resource/builder.d.ts.map +1 -0
- package/dist/resource/builder.js +12 -0
- package/dist/resource/builder.js.map +1 -0
- package/dist/resource/errors.d.ts +7 -0
- package/dist/resource/errors.d.ts.map +1 -0
- package/dist/resource/errors.js +9 -0
- package/dist/resource/errors.js.map +1 -0
- package/dist/resource/index.d.ts +9 -0
- package/dist/resource/index.d.ts.map +1 -0
- package/dist/resource/index.js +6 -0
- package/dist/resource/index.js.map +1 -0
- package/dist/resource/paginate.d.ts +13 -0
- package/dist/resource/paginate.d.ts.map +1 -0
- package/dist/resource/paginate.js +29 -0
- package/dist/resource/paginate.js.map +1 -0
- package/dist/resource/register.d.ts +16 -0
- package/dist/resource/register.d.ts.map +1 -0
- package/dist/resource/register.js +181 -0
- package/dist/resource/register.js.map +1 -0
- package/dist/resource/types.d.ts +69 -0
- package/dist/resource/types.d.ts.map +1 -0
- package/dist/resource/types.js +2 -0
- package/dist/resource/types.js.map +1 -0
- package/dist/surface/http.d.ts +2 -2
- package/dist/surface/http.d.ts.map +1 -1
- package/dist/surface/http.js +8 -25
- package/dist/surface/http.js.map +1 -1
- package/dist/surface/index.d.ts +1 -1
- package/dist/surface/index.d.ts.map +1 -1
- package/dist/surface/namespace.d.ts +1 -1
- package/dist/surface/namespace.d.ts.map +1 -1
- package/dist/surface/namespace.js +1 -1
- package/dist/surface/namespace.js.map +1 -1
- package/dist/surface/types.d.ts +0 -7
- package/dist/surface/types.d.ts.map +1 -1
- package/dist/temporal/definition-queries.d.ts +5 -5
- package/dist/temporal/definition-queries.d.ts.map +1 -1
- package/dist/temporal/definition-queries.js.map +1 -1
- package/dist/test/plugin.d.ts +2 -1
- package/dist/test/plugin.d.ts.map +1 -1
- package/dist/test/plugin.js +10 -2
- package/dist/test/plugin.js.map +1 -1
- package/dist/test/setup.d.ts.map +1 -1
- package/dist/test/setup.js +6 -4
- package/dist/test/setup.js.map +1 -1
- package/dist/test/vitest.d.ts +2 -2
- package/dist/test/vitest.d.ts.map +1 -1
- package/dist/test/vitest.js +6 -3
- package/dist/test/vitest.js.map +1 -1
- package/dist/trunk.d.ts +35 -0
- package/dist/trunk.d.ts.map +1 -0
- package/dist/trunk.js +102 -0
- package/dist/trunk.js.map +1 -0
- package/dist/validation/surface.d.ts +4 -0
- package/dist/validation/surface.d.ts.map +1 -0
- package/dist/validation/surface.js +55 -0
- package/dist/validation/surface.js.map +1 -0
- package/dist/vector/index.d.ts +1 -2
- package/dist/vector/index.d.ts.map +1 -1
- package/dist/vector/index.js +1 -1
- package/dist/vector/index.js.map +1 -1
- package/dist/vector/namespace.d.ts +4 -10
- package/dist/vector/namespace.d.ts.map +1 -1
- package/dist/vector/namespace.js +4 -10
- package/dist/vector/namespace.js.map +1 -1
- package/dist/vector/query.d.ts +2 -15
- package/dist/vector/query.d.ts.map +1 -1
- package/dist/vector/query.js +1 -39
- package/dist/vector/query.js.map +1 -1
- package/dist/webhook/verify.d.ts +3 -5
- package/dist/webhook/verify.d.ts.map +1 -1
- package/dist/webhook/verify.js +2 -5
- package/dist/webhook/verify.js.map +1 -1
- package/dist/workspace/affected.d.ts +17 -0
- package/dist/workspace/affected.d.ts.map +1 -0
- package/dist/workspace/affected.js +29 -0
- package/dist/workspace/affected.js.map +1 -0
- package/dist/workspace/changed-files.d.ts +7 -0
- package/dist/workspace/changed-files.d.ts.map +1 -0
- package/dist/workspace/changed-files.js +38 -0
- package/dist/workspace/changed-files.js.map +1 -0
- package/dist/workspace/dependency-graph.d.ts +8 -0
- package/dist/workspace/dependency-graph.d.ts.map +1 -0
- package/dist/workspace/dependency-graph.js +54 -0
- package/dist/workspace/dependency-graph.js.map +1 -0
- package/dist/workspace/generate.d.ts +1 -0
- package/dist/workspace/generate.d.ts.map +1 -1
- package/dist/workspace/generate.js +1 -0
- package/dist/workspace/generate.js.map +1 -1
- package/dist/workspace/index.d.ts +3 -0
- package/dist/workspace/index.d.ts.map +1 -1
- package/dist/workspace/index.js +3 -0
- package/dist/workspace/index.js.map +1 -1
- package/dist/workspace/sync.d.ts.map +1 -1
- package/dist/workspace/sync.js +1 -0
- package/dist/workspace/sync.js.map +1 -1
- package/package.json +33 -24
- package/dist/config/ts-register.d.ts +0 -2
- package/dist/config/ts-register.d.ts.map +0 -1
- package/dist/config/ts-register.js +0 -3
- package/dist/config/ts-register.js.map +0 -1
- package/dist/config/ts-resolve-hooks.d.ts +0 -10
- package/dist/config/ts-resolve-hooks.d.ts.map +0 -1
- package/dist/config/ts-resolve-hooks.js +0 -14
- package/dist/config/ts-resolve-hooks.js.map +0 -1
- package/dist/db/excluded.d.ts +0 -7
- package/dist/db/excluded.d.ts.map +0 -1
- package/dist/db/excluded.js +0 -11
- package/dist/db/excluded.js.map +0 -1
- package/dist/jsonb/index.d.ts +0 -2
- package/dist/jsonb/index.d.ts.map +0 -1
- package/dist/jsonb/index.js +0 -2
- package/dist/jsonb/index.js.map +0 -1
- package/dist/jsonb/namespace.d.ts +0 -11
- package/dist/jsonb/namespace.d.ts.map +0 -1
- package/dist/jsonb/namespace.js +0 -11
- package/dist/jsonb/namespace.js.map +0 -1
- package/dist/jsonb/query.d.ts +0 -5
- package/dist/jsonb/query.d.ts.map +0 -1
- package/dist/jsonb/query.js +0 -11
- package/dist/jsonb/query.js.map +0 -1
- package/dist/validation/doctrine.d.ts +0 -13
- package/dist/validation/doctrine.d.ts.map +0 -1
- package/dist/validation/doctrine.js +0 -115
- package/dist/validation/doctrine.js.map +0 -1
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { readFileSync, existsSync } from 'node:fs';
|
|
2
|
+
import { createHash } from 'node:crypto';
|
|
3
|
+
import postgres from 'postgres';
|
|
4
|
+
const NO_TRANSACTION_PRAGMA = '-- pipework:no-transaction';
|
|
5
|
+
const STATEMENT_BREAKPOINT = '--> statement-breakpoint';
|
|
6
|
+
export async function applyMigrations(options) {
|
|
7
|
+
const migrations = readMigrations(options);
|
|
8
|
+
if (migrations.length === 0)
|
|
9
|
+
return 0;
|
|
10
|
+
const client = postgres(options.connectionUrl, { max: 1, onnotice: () => { } });
|
|
11
|
+
try {
|
|
12
|
+
await client.unsafe(`
|
|
13
|
+
CREATE TABLE IF NOT EXISTS ${quoteIdent(options.migrationsTable)} (
|
|
14
|
+
id SERIAL PRIMARY KEY,
|
|
15
|
+
hash text NOT NULL,
|
|
16
|
+
created_at bigint
|
|
17
|
+
)
|
|
18
|
+
`);
|
|
19
|
+
const rows = await client.unsafe(`SELECT created_at FROM ${quoteIdent(options.migrationsTable)} ORDER BY created_at DESC LIMIT 1`);
|
|
20
|
+
const lastApplied = rows[0] !== undefined ? Number(rows[0].created_at) : -1;
|
|
21
|
+
let applied = 0;
|
|
22
|
+
for (const migration of migrations) {
|
|
23
|
+
if (migration.folderMillis <= lastApplied)
|
|
24
|
+
continue;
|
|
25
|
+
if (migration.noTransaction) {
|
|
26
|
+
for (const stmt of migration.statements) {
|
|
27
|
+
const trimmed = stmt.trim();
|
|
28
|
+
if (trimmed.length === 0 || trimmed.startsWith('--'))
|
|
29
|
+
continue;
|
|
30
|
+
await client.unsafe(trimmed);
|
|
31
|
+
}
|
|
32
|
+
await client.unsafe(`INSERT INTO ${quoteIdent(options.migrationsTable)} ("hash", "created_at") VALUES ($1, $2)`, [migration.hash, migration.folderMillis]);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
await client.begin(async (tx) => {
|
|
36
|
+
for (const stmt of migration.statements) {
|
|
37
|
+
const trimmed = stmt.trim();
|
|
38
|
+
if (trimmed.length === 0 || trimmed.startsWith('--'))
|
|
39
|
+
continue;
|
|
40
|
+
await tx.unsafe(trimmed);
|
|
41
|
+
}
|
|
42
|
+
await tx.unsafe(`INSERT INTO ${quoteIdent(options.migrationsTable)} ("hash", "created_at") VALUES ($1, $2)`, [migration.hash, migration.folderMillis]);
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
applied++;
|
|
46
|
+
}
|
|
47
|
+
return applied;
|
|
48
|
+
}
|
|
49
|
+
finally {
|
|
50
|
+
await client.end();
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
function readMigrations(options) {
|
|
54
|
+
const journalPath = `${options.migrationsFolder}/meta/_journal.json`;
|
|
55
|
+
if (!existsSync(journalPath)) {
|
|
56
|
+
throw new Error(`No migration journal found at ${journalPath}.\n\n` +
|
|
57
|
+
` Run \`pipework generate\` to create migrations.\n`);
|
|
58
|
+
}
|
|
59
|
+
const journal = JSON.parse(readFileSync(journalPath, 'utf-8'));
|
|
60
|
+
const migrations = [];
|
|
61
|
+
for (const entry of journal.entries) {
|
|
62
|
+
const filePath = `${options.migrationsFolder}/${entry.tag}.sql`;
|
|
63
|
+
if (!existsSync(filePath)) {
|
|
64
|
+
throw new Error(`Missing migration file: ${filePath}`);
|
|
65
|
+
}
|
|
66
|
+
let raw = readFileSync(filePath, 'utf-8');
|
|
67
|
+
const noTransaction = raw.includes(NO_TRANSACTION_PRAGMA);
|
|
68
|
+
if (options.stripConcurrently === true) {
|
|
69
|
+
raw = raw.replace(/\bCONCURRENTLY\s+/gi, '');
|
|
70
|
+
}
|
|
71
|
+
const statements = raw
|
|
72
|
+
.split(STATEMENT_BREAKPOINT)
|
|
73
|
+
.flatMap(chunk => chunk.split(';'))
|
|
74
|
+
.filter(s => {
|
|
75
|
+
const t = s.trim();
|
|
76
|
+
return t.length > 0 && !t.startsWith('--');
|
|
77
|
+
});
|
|
78
|
+
migrations.push({
|
|
79
|
+
tag: entry.tag,
|
|
80
|
+
hash: createHash('sha256').update(readFileSync(filePath, 'utf-8')).digest('hex'),
|
|
81
|
+
folderMillis: entry.when,
|
|
82
|
+
statements,
|
|
83
|
+
noTransaction,
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
return migrations;
|
|
87
|
+
}
|
|
88
|
+
function quoteIdent(name) {
|
|
89
|
+
return `"${name.replace(/"/g, '""')}"`;
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=apply.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apply.js","sourceRoot":"","sources":["../../../src/data/migrate/apply.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import type { PwSnapshot, PwTableSnapshot, PwColumnSnapshot, PwIndexSnapshot, PwForeignKeySnapshot, PwCheckSnapshot, PwUniqueSnapshot, PwCompositePKSnapshot } from './snapshot.js';
|
|
2
|
+
export type DiffOp = {
|
|
3
|
+
type: 'create_table';
|
|
4
|
+
table: PwTableSnapshot;
|
|
5
|
+
} | {
|
|
6
|
+
type: 'drop_table';
|
|
7
|
+
table: PwTableSnapshot;
|
|
8
|
+
} | {
|
|
9
|
+
type: 'add_column';
|
|
10
|
+
tableName: string;
|
|
11
|
+
tableSchema: string;
|
|
12
|
+
column: PwColumnSnapshot;
|
|
13
|
+
} | {
|
|
14
|
+
type: 'drop_column';
|
|
15
|
+
tableName: string;
|
|
16
|
+
tableSchema: string;
|
|
17
|
+
column: PwColumnSnapshot;
|
|
18
|
+
} | {
|
|
19
|
+
type: 'alter_column_type';
|
|
20
|
+
tableName: string;
|
|
21
|
+
tableSchema: string;
|
|
22
|
+
column: string;
|
|
23
|
+
from: string;
|
|
24
|
+
to: string;
|
|
25
|
+
} | {
|
|
26
|
+
type: 'alter_column_set_not_null';
|
|
27
|
+
tableName: string;
|
|
28
|
+
tableSchema: string;
|
|
29
|
+
column: string;
|
|
30
|
+
} | {
|
|
31
|
+
type: 'alter_column_drop_not_null';
|
|
32
|
+
tableName: string;
|
|
33
|
+
tableSchema: string;
|
|
34
|
+
column: string;
|
|
35
|
+
} | {
|
|
36
|
+
type: 'alter_column_set_default';
|
|
37
|
+
tableName: string;
|
|
38
|
+
tableSchema: string;
|
|
39
|
+
column: string;
|
|
40
|
+
value: string;
|
|
41
|
+
} | {
|
|
42
|
+
type: 'alter_column_drop_default';
|
|
43
|
+
tableName: string;
|
|
44
|
+
tableSchema: string;
|
|
45
|
+
column: string;
|
|
46
|
+
} | {
|
|
47
|
+
type: 'alter_column_set_generated';
|
|
48
|
+
tableName: string;
|
|
49
|
+
tableSchema: string;
|
|
50
|
+
column: PwColumnSnapshot;
|
|
51
|
+
} | {
|
|
52
|
+
type: 'alter_column_drop_generated';
|
|
53
|
+
tableName: string;
|
|
54
|
+
tableSchema: string;
|
|
55
|
+
column: string;
|
|
56
|
+
} | {
|
|
57
|
+
type: 'alter_column_set_identity';
|
|
58
|
+
tableName: string;
|
|
59
|
+
tableSchema: string;
|
|
60
|
+
column: PwColumnSnapshot;
|
|
61
|
+
} | {
|
|
62
|
+
type: 'alter_column_drop_identity';
|
|
63
|
+
tableName: string;
|
|
64
|
+
tableSchema: string;
|
|
65
|
+
column: string;
|
|
66
|
+
} | {
|
|
67
|
+
type: 'create_index';
|
|
68
|
+
tableName: string;
|
|
69
|
+
tableSchema: string;
|
|
70
|
+
index: PwIndexSnapshot;
|
|
71
|
+
} | {
|
|
72
|
+
type: 'drop_index';
|
|
73
|
+
tableName: string;
|
|
74
|
+
tableSchema: string;
|
|
75
|
+
index: PwIndexSnapshot;
|
|
76
|
+
} | {
|
|
77
|
+
type: 'add_foreign_key';
|
|
78
|
+
tableName: string;
|
|
79
|
+
tableSchema: string;
|
|
80
|
+
fk: PwForeignKeySnapshot;
|
|
81
|
+
} | {
|
|
82
|
+
type: 'drop_foreign_key';
|
|
83
|
+
tableName: string;
|
|
84
|
+
tableSchema: string;
|
|
85
|
+
fk: PwForeignKeySnapshot;
|
|
86
|
+
} | {
|
|
87
|
+
type: 'add_check';
|
|
88
|
+
tableName: string;
|
|
89
|
+
tableSchema: string;
|
|
90
|
+
check: PwCheckSnapshot;
|
|
91
|
+
} | {
|
|
92
|
+
type: 'drop_check';
|
|
93
|
+
tableName: string;
|
|
94
|
+
tableSchema: string;
|
|
95
|
+
check: PwCheckSnapshot;
|
|
96
|
+
} | {
|
|
97
|
+
type: 'add_unique';
|
|
98
|
+
tableName: string;
|
|
99
|
+
tableSchema: string;
|
|
100
|
+
unique: PwUniqueSnapshot;
|
|
101
|
+
} | {
|
|
102
|
+
type: 'drop_unique';
|
|
103
|
+
tableName: string;
|
|
104
|
+
tableSchema: string;
|
|
105
|
+
unique: PwUniqueSnapshot;
|
|
106
|
+
} | {
|
|
107
|
+
type: 'add_composite_pk';
|
|
108
|
+
tableName: string;
|
|
109
|
+
tableSchema: string;
|
|
110
|
+
pk: PwCompositePKSnapshot;
|
|
111
|
+
} | {
|
|
112
|
+
type: 'drop_composite_pk';
|
|
113
|
+
tableName: string;
|
|
114
|
+
tableSchema: string;
|
|
115
|
+
pk: PwCompositePKSnapshot;
|
|
116
|
+
};
|
|
117
|
+
export declare function diffSnapshots(prev: PwSnapshot, cur: PwSnapshot): DiffOp[];
|
|
118
|
+
//# sourceMappingURL=diff.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.d.ts","sourceRoot":"","sources":["../../../src/data/migrate/diff.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
export function diffSnapshots(prev, cur) {
|
|
2
|
+
const ops = [];
|
|
3
|
+
const prevKeys = new Set(Object.keys(prev.tables));
|
|
4
|
+
const curKeys = new Set(Object.keys(cur.tables));
|
|
5
|
+
// Phase 1: Drop constraints and indexes from tables that will be modified or dropped
|
|
6
|
+
for (const key of prevKeys) {
|
|
7
|
+
if (!curKeys.has(key))
|
|
8
|
+
continue;
|
|
9
|
+
const prevTable = prev.tables[key];
|
|
10
|
+
const curTable = cur.tables[key];
|
|
11
|
+
diffDropConstraints(prevTable, curTable, ops);
|
|
12
|
+
}
|
|
13
|
+
// Phase 2: Drop tables
|
|
14
|
+
for (const key of prevKeys) {
|
|
15
|
+
if (!curKeys.has(key)) {
|
|
16
|
+
ops.push({ type: 'drop_table', table: prev.tables[key] });
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
// Phase 3: Create tables
|
|
20
|
+
for (const key of curKeys) {
|
|
21
|
+
if (!prevKeys.has(key)) {
|
|
22
|
+
ops.push({ type: 'create_table', table: cur.tables[key] });
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
// Phase 4: Alter columns on shared tables
|
|
26
|
+
for (const key of prevKeys) {
|
|
27
|
+
if (!curKeys.has(key))
|
|
28
|
+
continue;
|
|
29
|
+
const prevTable = prev.tables[key];
|
|
30
|
+
const curTable = cur.tables[key];
|
|
31
|
+
diffColumns(prevTable, curTable, ops);
|
|
32
|
+
}
|
|
33
|
+
// Phase 5: Add constraints and indexes to modified or new tables
|
|
34
|
+
for (const key of prevKeys) {
|
|
35
|
+
if (!curKeys.has(key))
|
|
36
|
+
continue;
|
|
37
|
+
const prevTable = prev.tables[key];
|
|
38
|
+
const curTable = cur.tables[key];
|
|
39
|
+
diffAddConstraints(prevTable, curTable, ops);
|
|
40
|
+
}
|
|
41
|
+
return ops;
|
|
42
|
+
}
|
|
43
|
+
function diffDropConstraints(prev, cur, ops) {
|
|
44
|
+
const tn = prev.name;
|
|
45
|
+
const ts = prev.schema;
|
|
46
|
+
for (const name of Object.keys(prev.foreignKeys)) {
|
|
47
|
+
const prevFk = prev.foreignKeys[name];
|
|
48
|
+
const curFk = cur.foreignKeys[name];
|
|
49
|
+
if (curFk === undefined || !fkEqual(prevFk, curFk)) {
|
|
50
|
+
ops.push({ type: 'drop_foreign_key', tableName: tn, tableSchema: ts, fk: prevFk });
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
for (const name of Object.keys(prev.indexes)) {
|
|
54
|
+
const prevIdx = prev.indexes[name];
|
|
55
|
+
const curIdx = cur.indexes[name];
|
|
56
|
+
if (curIdx === undefined || !indexEqual(prevIdx, curIdx)) {
|
|
57
|
+
ops.push({ type: 'drop_index', tableName: tn, tableSchema: ts, index: prevIdx });
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
for (const name of Object.keys(prev.checks)) {
|
|
61
|
+
const prevChk = prev.checks[name];
|
|
62
|
+
const curChk = cur.checks[name];
|
|
63
|
+
if (curChk === undefined || prevChk.value !== curChk.value) {
|
|
64
|
+
ops.push({ type: 'drop_check', tableName: tn, tableSchema: ts, check: prevChk });
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
for (const name of Object.keys(prev.uniqueConstraints)) {
|
|
68
|
+
const prevUc = prev.uniqueConstraints[name];
|
|
69
|
+
const curUc = cur.uniqueConstraints[name];
|
|
70
|
+
if (curUc === undefined || !uniqueEqual(prevUc, curUc)) {
|
|
71
|
+
ops.push({ type: 'drop_unique', tableName: tn, tableSchema: ts, unique: prevUc });
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
for (const name of Object.keys(prev.compositePrimaryKeys)) {
|
|
75
|
+
const prevPk = prev.compositePrimaryKeys[name];
|
|
76
|
+
const curPk = cur.compositePrimaryKeys[name];
|
|
77
|
+
if (curPk === undefined || !arraysEqual(prevPk.columns, curPk.columns)) {
|
|
78
|
+
ops.push({ type: 'drop_composite_pk', tableName: tn, tableSchema: ts, pk: prevPk });
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
function diffColumns(prev, cur, ops) {
|
|
83
|
+
const tn = prev.name;
|
|
84
|
+
const ts = prev.schema;
|
|
85
|
+
const prevCols = new Set(Object.keys(prev.columns));
|
|
86
|
+
const curCols = new Set(Object.keys(cur.columns));
|
|
87
|
+
for (const name of prevCols) {
|
|
88
|
+
if (!curCols.has(name)) {
|
|
89
|
+
ops.push({ type: 'drop_column', tableName: tn, tableSchema: ts, column: prev.columns[name] });
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
for (const name of curCols) {
|
|
93
|
+
if (!prevCols.has(name)) {
|
|
94
|
+
ops.push({ type: 'add_column', tableName: tn, tableSchema: ts, column: cur.columns[name] });
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
for (const name of prevCols) {
|
|
98
|
+
if (!curCols.has(name))
|
|
99
|
+
continue;
|
|
100
|
+
const prevCol = prev.columns[name];
|
|
101
|
+
const curCol = cur.columns[name];
|
|
102
|
+
if (prevCol.type !== curCol.type) {
|
|
103
|
+
ops.push({ type: 'alter_column_type', tableName: tn, tableSchema: ts, column: name, from: prevCol.type, to: curCol.type });
|
|
104
|
+
}
|
|
105
|
+
if (!prevCol.notNull && curCol.notNull) {
|
|
106
|
+
ops.push({ type: 'alter_column_set_not_null', tableName: tn, tableSchema: ts, column: name });
|
|
107
|
+
}
|
|
108
|
+
if (prevCol.notNull && !curCol.notNull) {
|
|
109
|
+
ops.push({ type: 'alter_column_drop_not_null', tableName: tn, tableSchema: ts, column: name });
|
|
110
|
+
}
|
|
111
|
+
if (prevCol.default !== curCol.default) {
|
|
112
|
+
if (curCol.default !== undefined) {
|
|
113
|
+
ops.push({ type: 'alter_column_set_default', tableName: tn, tableSchema: ts, column: name, value: curCol.default });
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
ops.push({ type: 'alter_column_drop_default', tableName: tn, tableSchema: ts, column: name });
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
if (prevCol.generated === undefined && curCol.generated !== undefined) {
|
|
120
|
+
ops.push({ type: 'alter_column_set_generated', tableName: tn, tableSchema: ts, column: curCol });
|
|
121
|
+
}
|
|
122
|
+
if (prevCol.generated !== undefined && curCol.generated === undefined) {
|
|
123
|
+
ops.push({ type: 'alter_column_drop_generated', tableName: tn, tableSchema: ts, column: name });
|
|
124
|
+
}
|
|
125
|
+
if (prevCol.generated !== undefined && curCol.generated !== undefined && prevCol.generated.as !== curCol.generated.as) {
|
|
126
|
+
ops.push({ type: 'alter_column_drop_generated', tableName: tn, tableSchema: ts, column: name });
|
|
127
|
+
ops.push({ type: 'alter_column_set_generated', tableName: tn, tableSchema: ts, column: curCol });
|
|
128
|
+
}
|
|
129
|
+
if (prevCol.identity === undefined && curCol.identity !== undefined) {
|
|
130
|
+
ops.push({ type: 'alter_column_set_identity', tableName: tn, tableSchema: ts, column: curCol });
|
|
131
|
+
}
|
|
132
|
+
if (prevCol.identity !== undefined && curCol.identity === undefined) {
|
|
133
|
+
ops.push({ type: 'alter_column_drop_identity', tableName: tn, tableSchema: ts, column: name });
|
|
134
|
+
}
|
|
135
|
+
if (prevCol.identity !== undefined && curCol.identity !== undefined && prevCol.identity.type !== curCol.identity.type) {
|
|
136
|
+
ops.push({ type: 'alter_column_drop_identity', tableName: tn, tableSchema: ts, column: name });
|
|
137
|
+
ops.push({ type: 'alter_column_set_identity', tableName: tn, tableSchema: ts, column: curCol });
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
function diffAddConstraints(prev, cur, ops) {
|
|
142
|
+
const tn = cur.name;
|
|
143
|
+
const ts = cur.schema;
|
|
144
|
+
for (const name of Object.keys(cur.compositePrimaryKeys)) {
|
|
145
|
+
const prevPk = prev.compositePrimaryKeys[name];
|
|
146
|
+
const curPk = cur.compositePrimaryKeys[name];
|
|
147
|
+
if (prevPk === undefined || !arraysEqual(prevPk.columns, curPk.columns)) {
|
|
148
|
+
ops.push({ type: 'add_composite_pk', tableName: tn, tableSchema: ts, pk: curPk });
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
for (const name of Object.keys(cur.uniqueConstraints)) {
|
|
152
|
+
const prevUc = prev.uniqueConstraints[name];
|
|
153
|
+
const curUc = cur.uniqueConstraints[name];
|
|
154
|
+
if (prevUc === undefined || !uniqueEqual(prevUc, curUc)) {
|
|
155
|
+
ops.push({ type: 'add_unique', tableName: tn, tableSchema: ts, unique: curUc });
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
for (const name of Object.keys(cur.checks)) {
|
|
159
|
+
const prevChk = prev.checks[name];
|
|
160
|
+
const curChk = cur.checks[name];
|
|
161
|
+
if (prevChk === undefined || prevChk.value !== curChk.value) {
|
|
162
|
+
ops.push({ type: 'add_check', tableName: tn, tableSchema: ts, check: curChk });
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
for (const name of Object.keys(cur.indexes)) {
|
|
166
|
+
const prevIdx = prev.indexes[name];
|
|
167
|
+
const curIdx = cur.indexes[name];
|
|
168
|
+
if (prevIdx === undefined || !indexEqual(prevIdx, curIdx)) {
|
|
169
|
+
ops.push({ type: 'create_index', tableName: tn, tableSchema: ts, index: curIdx });
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
for (const name of Object.keys(cur.foreignKeys)) {
|
|
173
|
+
const prevFk = prev.foreignKeys[name];
|
|
174
|
+
const curFk = cur.foreignKeys[name];
|
|
175
|
+
if (prevFk === undefined || !fkEqual(prevFk, curFk)) {
|
|
176
|
+
ops.push({ type: 'add_foreign_key', tableName: tn, tableSchema: ts, fk: curFk });
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
function fkEqual(a, b) {
|
|
181
|
+
return a.foreignTable === b.foreignTable
|
|
182
|
+
&& a.foreignSchema === b.foreignSchema
|
|
183
|
+
&& a.onUpdate === b.onUpdate
|
|
184
|
+
&& a.onDelete === b.onDelete
|
|
185
|
+
&& arraysEqual(a.columns, b.columns)
|
|
186
|
+
&& arraysEqual(a.foreignColumns, b.foreignColumns);
|
|
187
|
+
}
|
|
188
|
+
function indexEqual(a, b) {
|
|
189
|
+
if (a.unique !== b.unique || a.method !== b.method || a.where !== b.where)
|
|
190
|
+
return false;
|
|
191
|
+
if (a.columns.length !== b.columns.length)
|
|
192
|
+
return false;
|
|
193
|
+
for (let i = 0; i < a.columns.length; i++) {
|
|
194
|
+
const ac = a.columns[i];
|
|
195
|
+
const bc = b.columns[i];
|
|
196
|
+
if (ac.expression !== bc.expression || ac.isExpression !== bc.isExpression
|
|
197
|
+
|| ac.order !== bc.order || ac.nulls !== bc.nulls || ac.opClass !== bc.opClass) {
|
|
198
|
+
return false;
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
return true;
|
|
202
|
+
}
|
|
203
|
+
function uniqueEqual(a, b) {
|
|
204
|
+
return a.nullsNotDistinct === b.nullsNotDistinct && arraysEqual(a.columns, b.columns);
|
|
205
|
+
}
|
|
206
|
+
function arraysEqual(a, b) {
|
|
207
|
+
if (a.length !== b.length)
|
|
208
|
+
return false;
|
|
209
|
+
for (let i = 0; i < a.length; i++) {
|
|
210
|
+
if (a[i] !== b[i])
|
|
211
|
+
return false;
|
|
212
|
+
}
|
|
213
|
+
return true;
|
|
214
|
+
}
|
|
215
|
+
//# sourceMappingURL=diff.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.js","sourceRoot":"","sources":["../../../src/data/migrate/diff.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generate.d.ts","sourceRoot":"","sources":["../../../src/data/migrate/generate.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"generate.d.ts","sourceRoot":"","sources":["../../../src/data/migrate/generate.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AASjE,MAAM,WAAW,cAAc;IAC7B,QAAQ,EAAE,MAAM,CAAA;IAChB,aAAa,EAAE,MAAM,GAAG,IAAI,CAAA;IAC5B,YAAY,EAAE,MAAM,CAAA;IACpB,UAAU,EAAE,MAAM,CAAA;CACnB;AAgBD,wBAAsB,mBAAmB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,GAAG,EAAE,MAAM,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,CAyFlI"}
|
|
@@ -1,26 +1,14 @@
|
|
|
1
1
|
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
|
|
2
2
|
import { join, resolve } from 'node:path';
|
|
3
3
|
import { pathToFileURL } from 'node:url';
|
|
4
|
-
import { randomUUID } from 'node:crypto';
|
|
5
4
|
import { glob } from 'node:fs/promises';
|
|
6
5
|
import { ConfigError } from '../../core/config/resolve.js';
|
|
7
6
|
import { postProcessMigration } from './post-process.js';
|
|
8
7
|
import { generateRlsStatements } from './rls-generate.js';
|
|
9
8
|
import { definitions } from '../domain/index.js';
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
version: '7',
|
|
14
|
-
dialect: 'postgresql',
|
|
15
|
-
tables: {},
|
|
16
|
-
enums: {},
|
|
17
|
-
schemas: {},
|
|
18
|
-
views: {},
|
|
19
|
-
sequences: {},
|
|
20
|
-
roles: {},
|
|
21
|
-
policies: {},
|
|
22
|
-
_meta: { schemas: {}, tables: {}, columns: {} },
|
|
23
|
-
};
|
|
9
|
+
import { buildSnapshot, EMPTY_SNAPSHOT } from './snapshot.js';
|
|
10
|
+
import { diffSnapshots } from './diff.js';
|
|
11
|
+
import { emitSQL } from './sql-emit.js';
|
|
24
12
|
export async function generateForDatabase(dbConfig, cwd, migrationName) {
|
|
25
13
|
if (dbConfig.schema === undefined) {
|
|
26
14
|
throw new ConfigError(`Database "${dbConfig.name}" has no schema path configured.`, `Add a schema path to your database config:\n\n` +
|
|
@@ -50,7 +38,6 @@ export async function generateForDatabase(dbConfig, cwd, migrationName) {
|
|
|
50
38
|
const migrationsDir = resolve(cwd, dbConfig.migrations);
|
|
51
39
|
const metaDir = join(migrationsDir, 'meta');
|
|
52
40
|
mkdirSync(metaDir, { recursive: true });
|
|
53
|
-
const { generateDrizzleJson, generateMigration } = await import('drizzle-kit/api');
|
|
54
41
|
const imports = {};
|
|
55
42
|
const cacheBust = Date.now();
|
|
56
43
|
for (const file of schemaFiles) {
|
|
@@ -61,8 +48,9 @@ export async function generateForDatabase(dbConfig, cwd, migrationName) {
|
|
|
61
48
|
}
|
|
62
49
|
}
|
|
63
50
|
const prevSnapshot = readPreviousSnapshot(metaDir);
|
|
64
|
-
const currentSnapshot =
|
|
65
|
-
const
|
|
51
|
+
const currentSnapshot = buildSnapshot(imports, prevSnapshot.id);
|
|
52
|
+
const ops = diffSnapshots(prevSnapshot, currentSnapshot);
|
|
53
|
+
const statements = emitSQL(ops);
|
|
66
54
|
if (statements.length === 0) {
|
|
67
55
|
const snapshotFile = writeSnapshot(metaDir, currentSnapshot, readJournal(metaDir));
|
|
68
56
|
return {
|
|
@@ -98,24 +86,26 @@ function readPreviousSnapshot(metaDir) {
|
|
|
98
86
|
const snapshotPath = join(metaDir, `${String(lastEntry.idx).padStart(4, '0')}_snapshot.json`);
|
|
99
87
|
if (!existsSync(snapshotPath))
|
|
100
88
|
return EMPTY_SNAPSHOT;
|
|
101
|
-
|
|
89
|
+
const raw = JSON.parse(readFileSync(snapshotPath, 'utf-8'));
|
|
90
|
+
if (raw.version === '7')
|
|
91
|
+
return EMPTY_SNAPSHOT;
|
|
92
|
+
return raw;
|
|
102
93
|
}
|
|
103
94
|
function readJournal(metaDir) {
|
|
104
95
|
const journalPath = join(metaDir, '_journal.json');
|
|
105
96
|
if (!existsSync(journalPath)) {
|
|
106
|
-
return { version: '
|
|
97
|
+
return { version: 'pw1', dialect: 'postgresql', entries: [] };
|
|
107
98
|
}
|
|
108
99
|
return JSON.parse(readFileSync(journalPath, 'utf-8'));
|
|
109
100
|
}
|
|
110
101
|
function writeSnapshot(metaDir, snapshot, journal, idx, tag) {
|
|
111
102
|
const snapshotIdx = idx ?? journal.entries.length;
|
|
112
103
|
const snapshotFile = join(metaDir, `${String(snapshotIdx).padStart(4, '0')}_snapshot.json`);
|
|
113
|
-
snapshot.id = randomUUID();
|
|
114
104
|
writeFileSync(snapshotFile, JSON.stringify(snapshot, null, 2), 'utf-8');
|
|
115
105
|
if (idx !== undefined && tag !== undefined) {
|
|
116
106
|
journal.entries.push({
|
|
117
107
|
idx,
|
|
118
|
-
version: '
|
|
108
|
+
version: 'pw1',
|
|
119
109
|
when: Date.now(),
|
|
120
110
|
tag,
|
|
121
111
|
breakpoints: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generate.js","sourceRoot":"","sources":["../../../src/data/migrate/generate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAC5E,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AACxC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"generate.js","sourceRoot":"","sources":["../../../src/data/migrate/generate.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../../src/data/migrate/run.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../../src/data/migrate/run.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAA;AACtD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAA;AAElE,OAAO,EAAmB,KAAK,oBAAoB,EAAE,MAAM,YAAY,CAAA;AAGvE,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,CA2CrI"}
|
package/dist/data/migrate/run.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { sql } from 'drizzle-orm';
|
|
1
|
+
import { sql } from '../query/index.js';
|
|
3
2
|
import { quoteIdentifier } from '../db/identifiers.js';
|
|
4
3
|
import { checkMigrations } from './check.js';
|
|
4
|
+
import { applyMigrations } from './apply.js';
|
|
5
5
|
export class UnsafeMigrationError extends Error {
|
|
6
6
|
check;
|
|
7
7
|
name = 'UnsafeMigrationError';
|
|
@@ -40,27 +40,16 @@ export async function migrateOne(instance, dbConfig, options = {}) {
|
|
|
40
40
|
}
|
|
41
41
|
extensionsCreated = [...dbConfig.extensions];
|
|
42
42
|
}
|
|
43
|
-
const
|
|
44
|
-
await drizzleMigrate(conn.drizzle, {
|
|
43
|
+
const migrationsRun = await applyMigrations({
|
|
45
44
|
migrationsFolder: dbConfig.migrations,
|
|
46
45
|
migrationsTable: dbConfig.migrationTable,
|
|
46
|
+
connectionUrl: dbConfig.url,
|
|
47
47
|
});
|
|
48
|
-
const afterTables = await getMigrationCount(conn.drizzle, dbConfig.migrationTable);
|
|
49
48
|
return {
|
|
50
49
|
database: dbConfig.name,
|
|
51
|
-
migrationsRun
|
|
50
|
+
migrationsRun,
|
|
52
51
|
extensions: extensionsCreated,
|
|
53
52
|
safetyCheck,
|
|
54
53
|
};
|
|
55
54
|
}
|
|
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
55
|
//# sourceMappingURL=run.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../../src/data/migrate/run.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../../src/data/migrate/run.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAA;AAGvC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAE,eAAe,EAA6B,MAAM,YAAY,CAAA;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAc5C,MAAM,OAAO,oBAAqB,SAAQ,KAAK;IAG3B;IAFA,IAAI,GAAG,sBAAsB,CAAA;IAC/C,YACkB,KAA2B,EAC3C,OAAe;QAEf,KAAK,CAAC,OAAO,CAAC,CAAA;QAHE,UAAK,GAAL,KAAK,CAAsB;IAI7C,CAAC;CACF;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,QAAkB,EAAE,UAA0B,EAAE;IAC/E,MAAM,OAAO,GAAoB,EAAE,CAAA;IAEnC,KAAK,MAAM,CAAC,EAAE,QAAQ,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,SAAS,EAAE,EAAE,CAAC;QACvD,IAAI,QAAQ,CAAC,UAAU,KAAK,SAAS;YAAE,SAAQ;QAC/C,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAA;QAC5D,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IACtB,CAAC;IAED,OAAO,OAAO,CAAA;AAChB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,QAAkB,EAAE,QAA0B,EAAE,UAA0B,EAAE;IAC3G,MAAM,WAAW,GAAG,QAAQ,CAAC,UAAU,KAAK,SAAS;QACnD,CAAC,CAAC,eAAe,CAAC,QAAQ,CAAC,UAAU,CAAC;QACtC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAA0B,CAAA;IAErG,IAAI,WAAW,CAAC,cAAc,IAAI,OAAO,CAAC,gBAAgB,KAAK,IAAI,EAAE,CAAC;QACpE,MAAM,IAAI,oBAAoB,CAC5B,WAAW,EACX,kBAAkB,QAAQ,CAAC,IAAI,qEAAqE;YACpG,mFAAmF,CACpF,CAAA;IACH,CAAC;IAED,IAAI,WAAW,CAAC,UAAU,IAAI,OAAO,CAAC,eAAe,KAAK,IAAI,EAAE,CAAC;QAC/D,MAAM,IAAI,oBAAoB,CAC5B,WAAW,EACX,kBAAkB,QAAQ,CAAC,IAAI,kDAAkD;YACjF,iFAAiF,CAClF,CAAA;IACH,CAAC;IAED,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAA;IAChD,IAAI,iBAAiB,GAAa,EAAE,CAAA;IAEpC,IAAI,QAAQ,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACnC,KAAK,MAAM,GAAG,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC;YACtC,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,kCAAkC,eAAe,CAAC,GAAG,EAAE,WAAW,CAAC,EAAE,CAAC,CAAC,CAAA;QAC5G,CAAC;QACD,iBAAiB,GAAG,CAAC,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAA;IAC9C,CAAC;IAED,MAAM,aAAa,GAAG,MAAM,eAAe,CAAC;QAC1C,gBAAgB,EAAE,QAAQ,CAAC,UAAW;QACtC,eAAe,EAAE,QAAQ,CAAC,cAAc;QACxC,aAAa,EAAE,QAAQ,CAAC,GAAG;KAC5B,CAAC,CAAA;IAEF,OAAO;QACL,QAAQ,EAAE,QAAQ,CAAC,IAAI;QACvB,aAAa;QACb,UAAU,EAAE,iBAAiB;QAC7B,WAAW;KACZ,CAAA;AACH,CAAC"}
|