@warlock.js/cascade 4.0.174 → 4.1.2
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/README.md +6 -5
- package/bin/cascadejs +3 -0
- package/esm/cli/commands/migrate-export-sql.mjs +48 -0
- package/esm/cli/commands/migrate-export-sql.mjs.map +1 -0
- package/esm/cli/commands/migrate-list.mjs +26 -0
- package/esm/cli/commands/migrate-list.mjs.map +1 -0
- package/esm/cli/commands/migrate-rollback.mjs +50 -0
- package/esm/cli/commands/migrate-rollback.mjs.map +1 -0
- package/esm/cli/commands/migrate.mjs +65 -0
- package/esm/cli/commands/migrate.mjs.map +1 -0
- package/esm/cli/connection-from-env.mjs +181 -0
- package/esm/cli/connection-from-env.mjs.map +1 -0
- package/esm/cli/index.mjs +31 -0
- package/esm/cli/index.mjs.map +1 -0
- package/esm/cli/load-migrations.mjs +78 -0
- package/esm/cli/load-migrations.mjs.map +1 -0
- package/esm/cli/printers.mjs +57 -0
- package/esm/cli/printers.mjs.map +1 -0
- package/esm/cli/setup-logger.mjs +30 -0
- package/esm/cli/setup-logger.mjs.map +1 -0
- package/esm/cli/with-cli-connection.mjs +39 -0
- package/esm/cli/with-cli-connection.mjs.map +1 -0
- package/esm/cli.d.mts +1 -0
- package/esm/cli.mjs +26 -0
- package/esm/cli.mjs.map +1 -0
- package/esm/context/database-data-source-context.d.mts +32 -0
- package/esm/context/database-data-source-context.d.mts.map +1 -0
- package/esm/context/database-data-source-context.mjs +35 -0
- package/esm/context/database-data-source-context.mjs.map +1 -0
- package/esm/context/database-transaction-context.d.mts +38 -0
- package/esm/context/database-transaction-context.d.mts.map +1 -0
- package/esm/context/database-transaction-context.mjs +47 -0
- package/esm/context/database-transaction-context.mjs.map +1 -0
- package/esm/contracts/database-driver.contract.d.mts +443 -0
- package/esm/contracts/database-driver.contract.d.mts.map +1 -0
- package/esm/contracts/database-id-generator.contract.d.mts +109 -0
- package/esm/contracts/database-id-generator.contract.d.mts.map +1 -0
- package/esm/contracts/database-remover.contract.d.mts +108 -0
- package/esm/contracts/database-remover.contract.d.mts.map +1 -0
- package/esm/contracts/database-restorer.contract.d.mts +145 -0
- package/esm/contracts/database-restorer.contract.d.mts.map +1 -0
- package/esm/contracts/database-writer.contract.d.mts +123 -0
- package/esm/contracts/database-writer.contract.d.mts.map +1 -0
- package/esm/contracts/driver-blueprint.contract.d.mts +52 -0
- package/esm/contracts/driver-blueprint.contract.d.mts.map +1 -0
- package/esm/contracts/index.d.mts +9 -0
- package/esm/contracts/migration-driver.contract.d.mts +476 -0
- package/esm/contracts/migration-driver.contract.d.mts.map +1 -0
- package/esm/contracts/query-builder.contract.d.mts +1663 -0
- package/esm/contracts/query-builder.contract.d.mts.map +1 -0
- package/esm/contracts/sync-adapter.contract.d.mts +49 -0
- package/esm/contracts/sync-adapter.contract.d.mts.map +1 -0
- package/esm/data-source/data-source-registry.d.mts +111 -0
- package/esm/data-source/data-source-registry.d.mts.map +1 -0
- package/esm/data-source/data-source-registry.mjs +142 -0
- package/esm/data-source/data-source-registry.mjs.map +1 -0
- package/esm/data-source/data-source.d.mts +160 -0
- package/esm/data-source/data-source.d.mts.map +1 -0
- package/esm/data-source/data-source.mjs +87 -0
- package/esm/data-source/data-source.mjs.map +1 -0
- package/esm/database-dirty-tracker.d.mts +254 -0
- package/esm/database-dirty-tracker.d.mts.map +1 -0
- package/esm/database-dirty-tracker.mjs +356 -0
- package/esm/database-dirty-tracker.mjs.map +1 -0
- package/esm/drivers/mongodb/mongodb-blueprint.mjs +54 -0
- package/esm/drivers/mongodb/mongodb-blueprint.mjs.map +1 -0
- package/esm/drivers/mongodb/mongodb-driver.d.mts +334 -0
- package/esm/drivers/mongodb/mongodb-driver.d.mts.map +1 -0
- package/esm/drivers/mongodb/mongodb-driver.mjs +716 -0
- package/esm/drivers/mongodb/mongodb-driver.mjs.map +1 -0
- package/esm/drivers/mongodb/mongodb-id-generator.d.mts +120 -0
- package/esm/drivers/mongodb/mongodb-id-generator.d.mts.map +1 -0
- package/esm/drivers/mongodb/mongodb-id-generator.mjs +141 -0
- package/esm/drivers/mongodb/mongodb-id-generator.mjs.map +1 -0
- package/esm/drivers/mongodb/mongodb-migration-driver.d.mts +322 -0
- package/esm/drivers/mongodb/mongodb-migration-driver.d.mts.map +1 -0
- package/esm/drivers/mongodb/mongodb-migration-driver.mjs +531 -0
- package/esm/drivers/mongodb/mongodb-migration-driver.mjs.map +1 -0
- package/esm/drivers/mongodb/mongodb-query-builder.d.mts +1117 -0
- package/esm/drivers/mongodb/mongodb-query-builder.d.mts.map +1 -0
- package/esm/drivers/mongodb/mongodb-query-builder.mjs +1828 -0
- package/esm/drivers/mongodb/mongodb-query-builder.mjs.map +1 -0
- package/esm/drivers/mongodb/mongodb-query-operations.d.mts +230 -0
- package/esm/drivers/mongodb/mongodb-query-operations.d.mts.map +1 -0
- package/esm/drivers/mongodb/mongodb-query-operations.mjs +275 -0
- package/esm/drivers/mongodb/mongodb-query-operations.mjs.map +1 -0
- package/esm/drivers/mongodb/mongodb-query-parser.d.mts +263 -0
- package/esm/drivers/mongodb/mongodb-query-parser.d.mts.map +1 -0
- package/esm/drivers/mongodb/mongodb-query-parser.mjs +965 -0
- package/esm/drivers/mongodb/mongodb-query-parser.mjs.map +1 -0
- package/esm/drivers/mongodb/mongodb-sync-adapter.d.mts +78 -0
- package/esm/drivers/mongodb/mongodb-sync-adapter.d.mts.map +1 -0
- package/esm/drivers/mongodb/mongodb-sync-adapter.mjs +118 -0
- package/esm/drivers/mongodb/mongodb-sync-adapter.mjs.map +1 -0
- package/esm/drivers/mongodb/types.d.mts +43 -0
- package/esm/drivers/mongodb/types.d.mts.map +1 -0
- package/esm/drivers/postgres/index.d.mts +8 -0
- package/esm/drivers/postgres/index.mjs +9 -0
- package/esm/drivers/postgres/postgres-blueprint.d.mts +60 -0
- package/esm/drivers/postgres/postgres-blueprint.d.mts.map +1 -0
- package/esm/drivers/postgres/postgres-blueprint.mjs +105 -0
- package/esm/drivers/postgres/postgres-blueprint.mjs.map +1 -0
- package/esm/drivers/postgres/postgres-dialect.d.mts +144 -0
- package/esm/drivers/postgres/postgres-dialect.d.mts.map +1 -0
- package/esm/drivers/postgres/postgres-dialect.mjs +227 -0
- package/esm/drivers/postgres/postgres-dialect.mjs.map +1 -0
- package/esm/drivers/postgres/postgres-driver.d.mts +424 -0
- package/esm/drivers/postgres/postgres-driver.d.mts.map +1 -0
- package/esm/drivers/postgres/postgres-driver.mjs +845 -0
- package/esm/drivers/postgres/postgres-driver.mjs.map +1 -0
- package/esm/drivers/postgres/postgres-migration-driver.d.mts +393 -0
- package/esm/drivers/postgres/postgres-migration-driver.d.mts.map +1 -0
- package/esm/drivers/postgres/postgres-migration-driver.mjs +760 -0
- package/esm/drivers/postgres/postgres-migration-driver.mjs.map +1 -0
- package/esm/drivers/postgres/postgres-query-builder.d.mts +399 -0
- package/esm/drivers/postgres/postgres-query-builder.d.mts.map +1 -0
- package/esm/drivers/postgres/postgres-query-builder.mjs +1105 -0
- package/esm/drivers/postgres/postgres-query-builder.mjs.map +1 -0
- package/esm/drivers/postgres/postgres-query-parser.d.mts +351 -0
- package/esm/drivers/postgres/postgres-query-parser.d.mts.map +1 -0
- package/esm/drivers/postgres/postgres-query-parser.mjs +796 -0
- package/esm/drivers/postgres/postgres-query-parser.mjs.map +1 -0
- package/esm/drivers/postgres/postgres-sql-serializer.mjs +260 -0
- package/esm/drivers/postgres/postgres-sql-serializer.mjs.map +1 -0
- package/esm/drivers/postgres/postgres-sync-adapter.d.mts +79 -0
- package/esm/drivers/postgres/postgres-sync-adapter.d.mts.map +1 -0
- package/esm/drivers/postgres/postgres-sync-adapter.mjs +162 -0
- package/esm/drivers/postgres/postgres-sync-adapter.mjs.map +1 -0
- package/esm/drivers/postgres/types.d.mts +105 -0
- package/esm/drivers/postgres/types.d.mts.map +1 -0
- package/esm/drivers/sql/sql-dialect.contract.d.mts +221 -0
- package/esm/drivers/sql/sql-dialect.contract.d.mts.map +1 -0
- package/esm/drivers/sql/sql-types.d.mts +150 -0
- package/esm/drivers/sql/sql-types.d.mts.map +1 -0
- package/esm/errors/missing-data-source.error.d.mts +25 -0
- package/esm/errors/missing-data-source.error.d.mts.map +1 -0
- package/esm/errors/missing-data-source.error.mjs +31 -0
- package/esm/errors/missing-data-source.error.mjs.map +1 -0
- package/esm/errors/transaction-rollback.error.d.mts +23 -0
- package/esm/errors/transaction-rollback.error.d.mts.map +1 -0
- package/esm/errors/transaction-rollback.error.mjs +29 -0
- package/esm/errors/transaction-rollback.error.mjs.map +1 -0
- package/esm/events/model-events.d.mts +234 -0
- package/esm/events/model-events.d.mts.map +1 -0
- package/esm/events/model-events.mjs +254 -0
- package/esm/events/model-events.mjs.map +1 -0
- package/esm/expressions/aggregate-expressions.d.mts +224 -0
- package/esm/expressions/aggregate-expressions.d.mts.map +1 -0
- package/esm/expressions/aggregate-expressions.mjs +232 -0
- package/esm/expressions/aggregate-expressions.mjs.map +1 -0
- package/esm/index.d.mts +67 -0
- package/esm/index.mjs +53 -0
- package/esm/migration/column-builder.d.mts +420 -0
- package/esm/migration/column-builder.d.mts.map +1 -0
- package/esm/migration/column-builder.mjs +532 -0
- package/esm/migration/column-builder.mjs.map +1 -0
- package/esm/migration/column-helpers.d.mts +280 -0
- package/esm/migration/column-helpers.d.mts.map +1 -0
- package/esm/migration/column-helpers.mjs +376 -0
- package/esm/migration/column-helpers.mjs.map +1 -0
- package/esm/migration/foreign-key-builder.d.mts +106 -0
- package/esm/migration/foreign-key-builder.d.mts.map +1 -0
- package/esm/migration/foreign-key-builder.mjs +126 -0
- package/esm/migration/foreign-key-builder.mjs.map +1 -0
- package/esm/migration/index.d.mts +6 -0
- package/esm/migration/index.mjs +7 -0
- package/esm/migration/migration-runner.d.mts +279 -0
- package/esm/migration/migration-runner.d.mts.map +1 -0
- package/esm/migration/migration-runner.mjs +662 -0
- package/esm/migration/migration-runner.mjs.map +1 -0
- package/esm/migration/migration.d.mts +2035 -0
- package/esm/migration/migration.d.mts.map +1 -0
- package/esm/migration/migration.mjs +2083 -0
- package/esm/migration/migration.mjs.map +1 -0
- package/esm/migration/sql-grammar.mjs +115 -0
- package/esm/migration/sql-grammar.mjs.map +1 -0
- package/esm/migration/sql-serializer.d.mts +26 -0
- package/esm/migration/sql-serializer.d.mts.map +1 -0
- package/esm/migration/sql-serializer.mjs +26 -0
- package/esm/migration/sql-serializer.mjs.map +1 -0
- package/esm/migration/types.d.mts +136 -0
- package/esm/migration/types.d.mts.map +1 -0
- package/esm/model/methods/accessor-methods.mjs +54 -0
- package/esm/model/methods/accessor-methods.mjs.map +1 -0
- package/esm/model/methods/delete-methods.mjs +16 -0
- package/esm/model/methods/delete-methods.mjs.map +1 -0
- package/esm/model/methods/dirty-methods.mjs +20 -0
- package/esm/model/methods/dirty-methods.mjs.map +1 -0
- package/esm/model/methods/hydration-methods.mjs +51 -0
- package/esm/model/methods/hydration-methods.mjs.map +1 -0
- package/esm/model/methods/instance-event-methods.mjs +22 -0
- package/esm/model/methods/instance-event-methods.mjs.map +1 -0
- package/esm/model/methods/meta-methods.mjs +36 -0
- package/esm/model/methods/meta-methods.mjs.map +1 -0
- package/esm/model/methods/pivot-methods.mjs +48 -0
- package/esm/model/methods/pivot-methods.mjs.map +1 -0
- package/esm/model/methods/query-methods.mjs +121 -0
- package/esm/model/methods/query-methods.mjs.map +1 -0
- package/esm/model/methods/restore-methods.mjs +16 -0
- package/esm/model/methods/restore-methods.mjs.map +1 -0
- package/esm/model/methods/scope-methods.mjs +20 -0
- package/esm/model/methods/scope-methods.mjs.map +1 -0
- package/esm/model/methods/serialization-methods.mjs +20 -0
- package/esm/model/methods/serialization-methods.mjs.map +1 -0
- package/esm/model/methods/static-event-methods.mjs +37 -0
- package/esm/model/methods/static-event-methods.mjs.map +1 -0
- package/esm/model/methods/write-methods.mjs +69 -0
- package/esm/model/methods/write-methods.mjs.map +1 -0
- package/esm/model/model.d.mts +1778 -0
- package/esm/model/model.d.mts.map +1 -0
- package/esm/model/model.mjs +1762 -0
- package/esm/model/model.mjs.map +1 -0
- package/esm/model/model.types.d.mts +47 -0
- package/esm/model/model.types.d.mts.map +1 -0
- package/esm/model/register-model.d.mts +140 -0
- package/esm/model/register-model.d.mts.map +1 -0
- package/esm/model/register-model.mjs +175 -0
- package/esm/model/register-model.mjs.map +1 -0
- package/esm/model/relation-decorators.d.mts +88 -0
- package/esm/model/relation-decorators.d.mts.map +1 -0
- package/esm/model/relation-decorators.mjs +191 -0
- package/esm/model/relation-decorators.mjs.map +1 -0
- package/esm/operations/database.d.mts +46 -0
- package/esm/operations/database.d.mts.map +1 -0
- package/esm/operations/database.mjs +40 -0
- package/esm/operations/database.mjs.map +1 -0
- package/esm/operations/index.d.mts +2 -0
- package/esm/operations/index.mjs +4 -0
- package/esm/operations/migrations.d.mts +71 -0
- package/esm/operations/migrations.d.mts.map +1 -0
- package/esm/operations/migrations.mjs +70 -0
- package/esm/operations/migrations.mjs.map +1 -0
- package/esm/query-builder/query-builder.d.mts +564 -0
- package/esm/query-builder/query-builder.d.mts.map +1 -0
- package/esm/query-builder/query-builder.mjs +1097 -0
- package/esm/query-builder/query-builder.mjs.map +1 -0
- package/esm/relations/index.d.mts +4 -0
- package/esm/relations/index.mjs +5 -0
- package/esm/relations/key-conventions.mjs +119 -0
- package/esm/relations/key-conventions.mjs.map +1 -0
- package/esm/relations/pivot-operations.d.mts +155 -0
- package/esm/relations/pivot-operations.d.mts.map +1 -0
- package/esm/relations/pivot-operations.mjs +232 -0
- package/esm/relations/pivot-operations.mjs.map +1 -0
- package/esm/relations/relation-hydrator.d.mts +55 -0
- package/esm/relations/relation-hydrator.d.mts.map +1 -0
- package/esm/relations/relation-hydrator.mjs +52 -0
- package/esm/relations/relation-hydrator.mjs.map +1 -0
- package/esm/relations/relation-loader.d.mts +190 -0
- package/esm/relations/relation-loader.d.mts.map +1 -0
- package/esm/relations/relation-loader.mjs +416 -0
- package/esm/relations/relation-loader.mjs.map +1 -0
- package/esm/relations/types.d.mts +317 -0
- package/esm/relations/types.d.mts.map +1 -0
- package/esm/remover/database-remover.d.mts +104 -0
- package/esm/remover/database-remover.d.mts.map +1 -0
- package/esm/remover/database-remover.mjs +174 -0
- package/esm/remover/database-remover.mjs.map +1 -0
- package/esm/restorer/database-restorer.d.mts +135 -0
- package/esm/restorer/database-restorer.d.mts.map +1 -0
- package/esm/restorer/database-restorer.mjs +316 -0
- package/esm/restorer/database-restorer.mjs.map +1 -0
- package/esm/sql-database-dirty-tracker.d.mts +17 -0
- package/esm/sql-database-dirty-tracker.d.mts.map +1 -0
- package/esm/sql-database-dirty-tracker.mjs +20 -0
- package/esm/sql-database-dirty-tracker.mjs.map +1 -0
- package/esm/sync/model-events.mjs +46 -0
- package/esm/sync/model-events.mjs.map +1 -0
- package/esm/sync/model-sync-operation.d.mts +159 -0
- package/esm/sync/model-sync-operation.d.mts.map +1 -0
- package/esm/sync/model-sync-operation.mjs +257 -0
- package/esm/sync/model-sync-operation.mjs.map +1 -0
- package/esm/sync/model-sync.d.mts +126 -0
- package/esm/sync/model-sync.d.mts.map +1 -0
- package/esm/sync/model-sync.mjs +157 -0
- package/esm/sync/model-sync.mjs.map +1 -0
- package/esm/sync/sync-context.d.mts +69 -0
- package/esm/sync/sync-context.d.mts.map +1 -0
- package/esm/sync/sync-context.mjs +95 -0
- package/esm/sync/sync-context.mjs.map +1 -0
- package/esm/sync/sync-manager.d.mts +213 -0
- package/esm/sync/sync-manager.d.mts.map +1 -0
- package/esm/sync/sync-manager.mjs +597 -0
- package/esm/sync/sync-manager.mjs.map +1 -0
- package/esm/sync/types.d.mts +215 -0
- package/esm/sync/types.d.mts.map +1 -0
- package/esm/types.d.mts +423 -0
- package/esm/types.d.mts.map +1 -0
- package/esm/utils/connect-to-database.d.mts +328 -0
- package/esm/utils/connect-to-database.d.mts.map +1 -0
- package/esm/utils/connect-to-database.mjs +130 -0
- package/esm/utils/connect-to-database.mjs.map +1 -0
- package/esm/utils/database-writer.utils.d.mts +18 -0
- package/esm/utils/database-writer.utils.d.mts.map +1 -0
- package/esm/utils/database-writer.utils.mjs +25 -0
- package/esm/utils/database-writer.utils.mjs.map +1 -0
- package/esm/utils/define-model.d.mts +185 -0
- package/esm/utils/define-model.d.mts.map +1 -0
- package/esm/utils/define-model.mjs +105 -0
- package/esm/utils/define-model.mjs.map +1 -0
- package/esm/utils/is-valid-date-value.mjs +22 -0
- package/esm/utils/is-valid-date-value.mjs.map +1 -0
- package/esm/utils/once-connected.d.mts +150 -0
- package/esm/utils/once-connected.d.mts.map +1 -0
- package/esm/utils/once-connected.mjs +203 -0
- package/esm/utils/once-connected.mjs.map +1 -0
- package/esm/validation/database-seal-plugins.d.mts +1 -0
- package/esm/validation/database-seal-plugins.mjs +11 -0
- package/esm/validation/database-seal-plugins.mjs.map +1 -0
- package/esm/validation/database-writer-validation-error.d.mts +101 -0
- package/esm/validation/database-writer-validation-error.d.mts.map +1 -0
- package/esm/validation/database-writer-validation-error.mjs +153 -0
- package/esm/validation/database-writer-validation-error.mjs.map +1 -0
- package/esm/validation/index.d.mts +2 -0
- package/esm/validation/index.mjs +4 -0
- package/esm/validation/mutators/embed-mutator.mjs +26 -0
- package/esm/validation/mutators/embed-mutator.mjs.map +1 -0
- package/esm/validation/plugins/database-rules-plugin.d.mts +28 -0
- package/esm/validation/plugins/database-rules-plugin.d.mts.map +1 -0
- package/esm/validation/plugins/database-rules-plugin.mjs +43 -0
- package/esm/validation/plugins/database-rules-plugin.mjs.map +1 -0
- package/esm/validation/plugins/embed-validator-plugin.d.mts +17 -0
- package/esm/validation/plugins/embed-validator-plugin.d.mts.map +1 -0
- package/esm/validation/plugins/embed-validator-plugin.mjs +20 -0
- package/esm/validation/plugins/embed-validator-plugin.mjs.map +1 -0
- package/esm/validation/rules/database-model-rule.mjs +32 -0
- package/esm/validation/rules/database-model-rule.mjs.map +1 -0
- package/esm/validation/rules/exists-rule.mjs +29 -0
- package/esm/validation/rules/exists-rule.mjs.map +1 -0
- package/esm/validation/rules/unique-rule.mjs +43 -0
- package/esm/validation/rules/unique-rule.mjs.map +1 -0
- package/esm/validation/transformers/embed-model-transformer.mjs +17 -0
- package/esm/validation/transformers/embed-model-transformer.mjs.map +1 -0
- package/esm/validation/types.d.mts +43 -0
- package/esm/validation/types.d.mts.map +1 -0
- package/esm/validation/validators/embed-validator.d.mts +25 -0
- package/esm/validation/validators/embed-validator.d.mts.map +1 -0
- package/esm/validation/validators/embed-validator.mjs +42 -0
- package/esm/validation/validators/embed-validator.mjs.map +1 -0
- package/esm/writer/database-writer.d.mts +178 -0
- package/esm/writer/database-writer.d.mts.map +1 -0
- package/esm/writer/database-writer.mjs +317 -0
- package/esm/writer/database-writer.mjs.map +1 -0
- package/llms-full.txt +2027 -0
- package/llms.txt +23 -0
- package/package.json +60 -51
- package/skills/README.md +65 -0
- package/skills/aggregate-data/SKILL.md +102 -0
- package/skills/cascade-basics/SKILL.md +93 -0
- package/skills/configure-delete-strategy/SKILL.md +126 -0
- package/skills/define-model/SKILL.md +170 -0
- package/skills/define-relations/SKILL.md +171 -0
- package/skills/manage-data-sources/SKILL.md +140 -0
- package/skills/manage-transactions/SKILL.md +118 -0
- package/skills/paginate-results/SKILL.md +122 -0
- package/skills/perform-atomic-ops/SKILL.md +98 -0
- package/skills/query-data/SKILL.md +168 -0
- package/skills/run-cascade-cli/SKILL.md +125 -0
- package/skills/search-by-vector/SKILL.md +127 -0
- package/skills/subscribe-to-model-events/SKILL.md +148 -0
- package/skills/track-changes/SKILL.md +109 -0
- package/skills/write-migration/SKILL.md +144 -0
- package/cjs/context/database-data-source-context.d.ts +0 -29
- package/cjs/context/database-data-source-context.d.ts.map +0 -1
- package/cjs/context/database-data-source-context.js +0 -28
- package/cjs/context/database-data-source-context.js.map +0 -1
- package/cjs/context/database-transaction-context.d.ts +0 -35
- package/cjs/context/database-transaction-context.d.ts.map +0 -1
- package/cjs/context/database-transaction-context.js +0 -40
- package/cjs/context/database-transaction-context.js.map +0 -1
- package/cjs/contracts/database-driver.contract.d.ts +0 -450
- package/cjs/contracts/database-driver.contract.d.ts.map +0 -1
- package/cjs/contracts/database-id-generator.contract.d.ts +0 -109
- package/cjs/contracts/database-id-generator.contract.d.ts.map +0 -1
- package/cjs/contracts/database-remover.contract.d.ts +0 -104
- package/cjs/contracts/database-remover.contract.d.ts.map +0 -1
- package/cjs/contracts/database-restorer.contract.d.ts +0 -143
- package/cjs/contracts/database-restorer.contract.d.ts.map +0 -1
- package/cjs/contracts/database-writer.contract.d.ts +0 -119
- package/cjs/contracts/database-writer.contract.d.ts.map +0 -1
- package/cjs/contracts/driver-blueprint.contract.d.ts +0 -49
- package/cjs/contracts/driver-blueprint.contract.d.ts.map +0 -1
- package/cjs/contracts/index.d.ts +0 -10
- package/cjs/contracts/index.d.ts.map +0 -1
- package/cjs/contracts/migration-driver.contract.d.ts +0 -522
- package/cjs/contracts/migration-driver.contract.d.ts.map +0 -1
- package/cjs/contracts/query-builder.contract.d.ts +0 -1609
- package/cjs/contracts/query-builder.contract.d.ts.map +0 -1
- package/cjs/contracts/sync-adapter.contract.d.ts +0 -58
- package/cjs/contracts/sync-adapter.contract.d.ts.map +0 -1
- package/cjs/data-source/data-source-registry.d.ts +0 -108
- package/cjs/data-source/data-source-registry.d.ts.map +0 -1
- package/cjs/data-source/data-source-registry.js +0 -145
- package/cjs/data-source/data-source-registry.js.map +0 -1
- package/cjs/data-source/data-source.d.ts +0 -147
- package/cjs/data-source/data-source.d.ts.map +0 -1
- package/cjs/data-source/data-source.js +0 -83
- package/cjs/data-source/data-source.js.map +0 -1
- package/cjs/database-dirty-tracker.d.ts +0 -252
- package/cjs/database-dirty-tracker.d.ts.map +0 -1
- package/cjs/database-dirty-tracker.js +0 -386
- package/cjs/database-dirty-tracker.js.map +0 -1
- package/cjs/drivers/mongodb/mongodb-blueprint.d.ts +0 -30
- package/cjs/drivers/mongodb/mongodb-blueprint.d.ts.map +0 -1
- package/cjs/drivers/mongodb/mongodb-blueprint.js +0 -51
- package/cjs/drivers/mongodb/mongodb-blueprint.js.map +0 -1
- package/cjs/drivers/mongodb/mongodb-driver.d.ts +0 -325
- package/cjs/drivers/mongodb/mongodb-driver.d.ts.map +0 -1
- package/cjs/drivers/mongodb/mongodb-driver.js +0 -845
- package/cjs/drivers/mongodb/mongodb-driver.js.map +0 -1
- package/cjs/drivers/mongodb/mongodb-id-generator.d.ts +0 -116
- package/cjs/drivers/mongodb/mongodb-id-generator.d.ts.map +0 -1
- package/cjs/drivers/mongodb/mongodb-id-generator.js +0 -149
- package/cjs/drivers/mongodb/mongodb-id-generator.js.map +0 -1
- package/cjs/drivers/mongodb/mongodb-migration-driver.d.ts +0 -317
- package/cjs/drivers/mongodb/mongodb-migration-driver.d.ts.map +0 -1
- package/cjs/drivers/mongodb/mongodb-migration-driver.js +0 -666
- package/cjs/drivers/mongodb/mongodb-migration-driver.js.map +0 -1
- package/cjs/drivers/mongodb/mongodb-query-builder.d.ts +0 -1122
- package/cjs/drivers/mongodb/mongodb-query-builder.d.ts.map +0 -1
- package/cjs/drivers/mongodb/mongodb-query-builder.js +0 -1988
- package/cjs/drivers/mongodb/mongodb-query-builder.js.map +0 -1
- package/cjs/drivers/mongodb/mongodb-query-operations.d.ts +0 -226
- package/cjs/drivers/mongodb/mongodb-query-operations.d.ts.map +0 -1
- package/cjs/drivers/mongodb/mongodb-query-operations.js +0 -270
- package/cjs/drivers/mongodb/mongodb-query-operations.js.map +0 -1
- package/cjs/drivers/mongodb/mongodb-query-parser.d.ts +0 -262
- package/cjs/drivers/mongodb/mongodb-query-parser.d.ts.map +0 -1
- package/cjs/drivers/mongodb/mongodb-query-parser.js +0 -1351
- package/cjs/drivers/mongodb/mongodb-query-parser.js.map +0 -1
- package/cjs/drivers/mongodb/mongodb-sync-adapter.d.ts +0 -79
- package/cjs/drivers/mongodb/mongodb-sync-adapter.d.ts.map +0 -1
- package/cjs/drivers/mongodb/mongodb-sync-adapter.js +0 -146
- package/cjs/drivers/mongodb/mongodb-sync-adapter.js.map +0 -1
- package/cjs/drivers/mongodb/types.d.ts +0 -43
- package/cjs/drivers/mongodb/types.d.ts.map +0 -1
- package/cjs/drivers/postgres/index.d.ts +0 -16
- package/cjs/drivers/postgres/index.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-blueprint.d.ts +0 -64
- package/cjs/drivers/postgres/postgres-blueprint.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-blueprint.js +0 -121
- package/cjs/drivers/postgres/postgres-blueprint.js.map +0 -1
- package/cjs/drivers/postgres/postgres-dialect.d.ts +0 -136
- package/cjs/drivers/postgres/postgres-dialect.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-dialect.js +0 -268
- package/cjs/drivers/postgres/postgres-dialect.js.map +0 -1
- package/cjs/drivers/postgres/postgres-driver.d.ts +0 -432
- package/cjs/drivers/postgres/postgres-driver.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-driver.js +0 -1008
- package/cjs/drivers/postgres/postgres-driver.js.map +0 -1
- package/cjs/drivers/postgres/postgres-migration-driver.d.ts +0 -397
- package/cjs/drivers/postgres/postgres-migration-driver.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-migration-driver.js +0 -900
- package/cjs/drivers/postgres/postgres-migration-driver.js.map +0 -1
- package/cjs/drivers/postgres/postgres-query-builder.d.ts +0 -254
- package/cjs/drivers/postgres/postgres-query-builder.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-query-builder.js +0 -933
- package/cjs/drivers/postgres/postgres-query-builder.js.map +0 -1
- package/cjs/drivers/postgres/postgres-query-parser.d.ts +0 -328
- package/cjs/drivers/postgres/postgres-query-parser.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-query-parser.js +0 -868
- package/cjs/drivers/postgres/postgres-query-parser.js.map +0 -1
- package/cjs/drivers/postgres/postgres-sql-serializer.d.ts +0 -37
- package/cjs/drivers/postgres/postgres-sql-serializer.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-sql-serializer.js +0 -400
- package/cjs/drivers/postgres/postgres-sql-serializer.js.map +0 -1
- package/cjs/drivers/postgres/postgres-sync-adapter.d.ts +0 -83
- package/cjs/drivers/postgres/postgres-sync-adapter.d.ts.map +0 -1
- package/cjs/drivers/postgres/postgres-sync-adapter.js +0 -204
- package/cjs/drivers/postgres/postgres-sync-adapter.js.map +0 -1
- package/cjs/drivers/postgres/types.d.ts +0 -144
- package/cjs/drivers/postgres/types.d.ts.map +0 -1
- package/cjs/drivers/sql/index.d.ts +0 -10
- package/cjs/drivers/sql/index.d.ts.map +0 -1
- package/cjs/drivers/sql/sql-dialect.contract.d.ts +0 -204
- package/cjs/drivers/sql/sql-dialect.contract.d.ts.map +0 -1
- package/cjs/drivers/sql/sql-types.d.ts +0 -202
- package/cjs/drivers/sql/sql-types.d.ts.map +0 -1
- package/cjs/errors/missing-data-source.error.d.ts +0 -22
- package/cjs/errors/missing-data-source.error.d.ts.map +0 -1
- package/cjs/errors/missing-data-source.error.js +0 -29
- package/cjs/errors/missing-data-source.error.js.map +0 -1
- package/cjs/errors/transaction-rollback.error.d.ts +0 -20
- package/cjs/errors/transaction-rollback.error.d.ts.map +0 -1
- package/cjs/errors/transaction-rollback.error.js +0 -27
- package/cjs/errors/transaction-rollback.error.js.map +0 -1
- package/cjs/events/model-events.d.ts +0 -231
- package/cjs/events/model-events.d.ts.map +0 -1
- package/cjs/events/model-events.js +0 -259
- package/cjs/events/model-events.js.map +0 -1
- package/cjs/expressions/aggregate-expressions.d.ts +0 -215
- package/cjs/expressions/aggregate-expressions.d.ts.map +0 -1
- package/cjs/expressions/aggregate-expressions.js +0 -221
- package/cjs/expressions/aggregate-expressions.js.map +0 -1
- package/cjs/expressions/index.d.ts +0 -2
- package/cjs/expressions/index.d.ts.map +0 -1
- package/cjs/index.d.ts +0 -45
- package/cjs/index.d.ts.map +0 -1
- package/cjs/index.js +0 -1
- package/cjs/index.js.map +0 -1
- package/cjs/migration/column-builder.d.ts +0 -417
- package/cjs/migration/column-builder.d.ts.map +0 -1
- package/cjs/migration/column-builder.js +0 -586
- package/cjs/migration/column-builder.js.map +0 -1
- package/cjs/migration/column-helpers.d.ts +0 -275
- package/cjs/migration/column-helpers.d.ts.map +0 -1
- package/cjs/migration/column-helpers.js +0 -389
- package/cjs/migration/column-helpers.js.map +0 -1
- package/cjs/migration/foreign-key-builder.d.ts +0 -103
- package/cjs/migration/foreign-key-builder.d.ts.map +0 -1
- package/cjs/migration/foreign-key-builder.js +0 -121
- package/cjs/migration/foreign-key-builder.js.map +0 -1
- package/cjs/migration/index.d.ts +0 -7
- package/cjs/migration/index.d.ts.map +0 -1
- package/cjs/migration/migration-runner.d.ts +0 -278
- package/cjs/migration/migration-runner.d.ts.map +0 -1
- package/cjs/migration/migration-runner.js +0 -815
- package/cjs/migration/migration-runner.js.map +0 -1
- package/cjs/migration/migration.d.ts +0 -1988
- package/cjs/migration/migration.d.ts.map +0 -1
- package/cjs/migration/migration.js +0 -2162
- package/cjs/migration/migration.js.map +0 -1
- package/cjs/migration/sql-grammar.d.ts +0 -61
- package/cjs/migration/sql-grammar.d.ts.map +0 -1
- package/cjs/migration/sql-grammar.js +0 -164
- package/cjs/migration/sql-grammar.js.map +0 -1
- package/cjs/migration/sql-serializer.d.ts +0 -22
- package/cjs/migration/sql-serializer.d.ts.map +0 -1
- package/cjs/migration/sql-serializer.js +0 -26
- package/cjs/migration/sql-serializer.js.map +0 -1
- package/cjs/migration/types.d.ts +0 -155
- package/cjs/migration/types.d.ts.map +0 -1
- package/cjs/model/methods/accessor-methods.d.ts +0 -13
- package/cjs/model/methods/accessor-methods.d.ts.map +0 -1
- package/cjs/model/methods/accessor-methods.js +0 -51
- package/cjs/model/methods/accessor-methods.js.map +0 -1
- package/cjs/model/methods/delete-methods.d.ts +0 -10
- package/cjs/model/methods/delete-methods.d.ts.map +0 -1
- package/cjs/model/methods/delete-methods.js +0 -10
- package/cjs/model/methods/delete-methods.js.map +0 -1
- package/cjs/model/methods/dirty-methods.d.ts +0 -10
- package/cjs/model/methods/dirty-methods.d.ts.map +0 -1
- package/cjs/model/methods/dirty-methods.js +0 -15
- package/cjs/model/methods/dirty-methods.js.map +0 -1
- package/cjs/model/methods/hydration-methods.d.ts +0 -10
- package/cjs/model/methods/hydration-methods.d.ts.map +0 -1
- package/cjs/model/methods/hydration-methods.js +0 -57
- package/cjs/model/methods/hydration-methods.js.map +0 -1
- package/cjs/model/methods/instance-event-methods.d.ts +0 -7
- package/cjs/model/methods/instance-event-methods.d.ts.map +0 -1
- package/cjs/model/methods/instance-event-methods.js +0 -15
- package/cjs/model/methods/instance-event-methods.js.map +0 -1
- package/cjs/model/methods/meta-methods.d.ts +0 -7
- package/cjs/model/methods/meta-methods.d.ts.map +0 -1
- package/cjs/model/methods/meta-methods.js +0 -78
- package/cjs/model/methods/meta-methods.js.map +0 -1
- package/cjs/model/methods/query-methods.d.ts +0 -24
- package/cjs/model/methods/query-methods.d.ts.map +0 -1
- package/cjs/model/methods/query-methods.js +0 -164
- package/cjs/model/methods/query-methods.js.map +0 -1
- package/cjs/model/methods/restore-methods.d.ts +0 -10
- package/cjs/model/methods/restore-methods.d.ts.map +0 -1
- package/cjs/model/methods/restore-methods.js +0 -13
- package/cjs/model/methods/restore-methods.js.map +0 -1
- package/cjs/model/methods/scope-methods.d.ts +0 -7
- package/cjs/model/methods/scope-methods.d.ts.map +0 -1
- package/cjs/model/methods/scope-methods.js +0 -15
- package/cjs/model/methods/scope-methods.js.map +0 -1
- package/cjs/model/methods/serialization-methods.d.ts +0 -3
- package/cjs/model/methods/serialization-methods.d.ts.map +0 -1
- package/cjs/model/methods/serialization-methods.js +0 -27
- package/cjs/model/methods/serialization-methods.js.map +0 -1
- package/cjs/model/methods/static-event-methods.d.ts +0 -9
- package/cjs/model/methods/static-event-methods.d.ts.map +0 -1
- package/cjs/model/methods/static-event-methods.js +0 -29
- package/cjs/model/methods/static-event-methods.js.map +0 -1
- package/cjs/model/methods/write-methods.d.ts +0 -10
- package/cjs/model/methods/write-methods.d.ts.map +0 -1
- package/cjs/model/methods/write-methods.js +0 -52
- package/cjs/model/methods/write-methods.js.map +0 -1
- package/cjs/model/model.d.ts +0 -1647
- package/cjs/model/model.d.ts.map +0 -1
- package/cjs/model/model.js +0 -1657
- package/cjs/model/model.js.map +0 -1
- package/cjs/model/model.types.d.ts +0 -44
- package/cjs/model/model.types.d.ts.map +0 -1
- package/cjs/model/register-model.d.ts +0 -81
- package/cjs/model/register-model.d.ts.map +0 -1
- package/cjs/model/register-model.js +0 -94
- package/cjs/model/register-model.js.map +0 -1
- package/cjs/query-builder/query-builder.d.ts +0 -556
- package/cjs/query-builder/query-builder.d.ts.map +0 -1
- package/cjs/query-builder/query-builder.js +0 -1070
- package/cjs/query-builder/query-builder.js.map +0 -1
- package/cjs/relations/helpers.d.ts +0 -156
- package/cjs/relations/helpers.d.ts.map +0 -1
- package/cjs/relations/helpers.js +0 -202
- package/cjs/relations/helpers.js.map +0 -1
- package/cjs/relations/index.d.ts +0 -35
- package/cjs/relations/index.d.ts.map +0 -1
- package/cjs/relations/pivot-operations.d.ts +0 -160
- package/cjs/relations/pivot-operations.d.ts.map +0 -1
- package/cjs/relations/pivot-operations.js +0 -293
- package/cjs/relations/pivot-operations.js.map +0 -1
- package/cjs/relations/relation-hydrator.d.ts +0 -68
- package/cjs/relations/relation-hydrator.d.ts.map +0 -1
- package/cjs/relations/relation-hydrator.js +0 -81
- package/cjs/relations/relation-hydrator.js.map +0 -1
- package/cjs/relations/relation-loader.d.ts +0 -194
- package/cjs/relations/relation-loader.d.ts.map +0 -1
- package/cjs/relations/relation-loader.js +0 -466
- package/cjs/relations/relation-loader.js.map +0 -1
- package/cjs/relations/types.d.ts +0 -306
- package/cjs/relations/types.d.ts.map +0 -1
- package/cjs/remover/database-remover.d.ts +0 -100
- package/cjs/remover/database-remover.d.ts.map +0 -1
- package/cjs/remover/database-remover.js +0 -214
- package/cjs/remover/database-remover.js.map +0 -1
- package/cjs/restorer/database-restorer.d.ts +0 -131
- package/cjs/restorer/database-restorer.d.ts.map +0 -1
- package/cjs/restorer/database-restorer.js +0 -434
- package/cjs/restorer/database-restorer.js.map +0 -1
- package/cjs/sql-database-dirty-tracker.d.ts +0 -13
- package/cjs/sql-database-dirty-tracker.d.ts.map +0 -1
- package/cjs/sql-database-dirty-tracker.js +0 -14
- package/cjs/sql-database-dirty-tracker.js.map +0 -1
- package/cjs/sync/index.d.ts +0 -12
- package/cjs/sync/index.d.ts.map +0 -1
- package/cjs/sync/model-events.d.ts +0 -62
- package/cjs/sync/model-events.d.ts.map +0 -1
- package/cjs/sync/model-events.js +0 -49
- package/cjs/sync/model-events.js.map +0 -1
- package/cjs/sync/model-sync-operation.d.ts +0 -163
- package/cjs/sync/model-sync-operation.d.ts.map +0 -1
- package/cjs/sync/model-sync-operation.js +0 -292
- package/cjs/sync/model-sync-operation.js.map +0 -1
- package/cjs/sync/model-sync.d.ts +0 -130
- package/cjs/sync/model-sync.d.ts.map +0 -1
- package/cjs/sync/model-sync.js +0 -178
- package/cjs/sync/model-sync.js.map +0 -1
- package/cjs/sync/sync-context.d.ts +0 -70
- package/cjs/sync/sync-context.d.ts.map +0 -1
- package/cjs/sync/sync-context.js +0 -101
- package/cjs/sync/sync-context.js.map +0 -1
- package/cjs/sync/sync-manager.d.ts +0 -213
- package/cjs/sync/sync-manager.d.ts.map +0 -1
- package/cjs/sync/sync-manager.js +0 -689
- package/cjs/sync/sync-manager.js.map +0 -1
- package/cjs/sync/types.d.ts +0 -289
- package/cjs/sync/types.d.ts.map +0 -1
- package/cjs/test-migrations/test-enhanced-features.migration.d.ts +0 -15
- package/cjs/test-migrations/test-enhanced-features.migration.d.ts.map +0 -1
- package/cjs/types.d.ts +0 -371
- package/cjs/types.d.ts.map +0 -1
- package/cjs/utils/connect-to-database.d.ts +0 -307
- package/cjs/utils/connect-to-database.d.ts.map +0 -1
- package/cjs/utils/connect-to-database.js +0 -130
- package/cjs/utils/connect-to-database.js.map +0 -1
- package/cjs/utils/database-writer.utils.d.ts +0 -15
- package/cjs/utils/database-writer.utils.d.ts.map +0 -1
- package/cjs/utils/database-writer.utils.js +0 -14
- package/cjs/utils/database-writer.utils.js.map +0 -1
- package/cjs/utils/define-model.js +0 -100
- package/cjs/utils/define-model.js.map +0 -1
- package/cjs/utils/is-valid-date-value.d.ts +0 -5
- package/cjs/utils/is-valid-date-value.d.ts.map +0 -1
- package/cjs/utils/is-valid-date-value.js +0 -25
- package/cjs/utils/is-valid-date-value.js.map +0 -1
- package/cjs/utils/once-connected.d.ts +0 -146
- package/cjs/utils/once-connected.d.ts.map +0 -1
- package/cjs/utils/once-connected.js +0 -251
- package/cjs/utils/once-connected.js.map +0 -1
- package/cjs/validation/database-seal-plugins.d.ts +0 -12
- package/cjs/validation/database-seal-plugins.d.ts.map +0 -1
- package/cjs/validation/database-seal-plugins.js +0 -1
- package/cjs/validation/database-seal-plugins.js.map +0 -1
- package/cjs/validation/database-writer-validation-error.d.ts +0 -97
- package/cjs/validation/database-writer-validation-error.d.ts.map +0 -1
- package/cjs/validation/database-writer-validation-error.js +0 -160
- package/cjs/validation/database-writer-validation-error.js.map +0 -1
- package/cjs/validation/index.d.ts +0 -3
- package/cjs/validation/index.d.ts.map +0 -1
- package/cjs/validation/mutators/embed-mutator.d.ts +0 -9
- package/cjs/validation/mutators/embed-mutator.d.ts.map +0 -1
- package/cjs/validation/mutators/embed-mutator.js +0 -33
- package/cjs/validation/mutators/embed-mutator.js.map +0 -1
- package/cjs/validation/plugins/embed-validator-plugin.d.ts +0 -24
- package/cjs/validation/plugins/embed-validator-plugin.d.ts.map +0 -1
- package/cjs/validation/plugins/embed-validator-plugin.js +0 -18
- package/cjs/validation/plugins/embed-validator-plugin.js.map +0 -1
- package/cjs/validation/rules/database-model-rule.d.ts +0 -7
- package/cjs/validation/rules/database-model-rule.d.ts.map +0 -1
- package/cjs/validation/rules/database-model-rule.js +0 -27
- package/cjs/validation/rules/database-model-rule.js.map +0 -1
- package/cjs/validation/transformers/embed-model-transformer.d.ts +0 -3
- package/cjs/validation/transformers/embed-model-transformer.d.ts.map +0 -1
- package/cjs/validation/transformers/embed-model-transformer.js +0 -18
- package/cjs/validation/transformers/embed-model-transformer.js.map +0 -1
- package/cjs/validation/validators/embed-validator.d.ts +0 -21
- package/cjs/validation/validators/embed-validator.d.ts.map +0 -1
- package/cjs/validation/validators/embed-validator.js +0 -43
- package/cjs/validation/validators/embed-validator.js.map +0 -1
- package/cjs/writer/database-writer.d.ts +0 -174
- package/cjs/writer/database-writer.d.ts.map +0 -1
- package/cjs/writer/database-writer.js +0 -400
- package/cjs/writer/database-writer.js.map +0 -1
- package/esm/context/database-data-source-context.d.ts +0 -29
- package/esm/context/database-data-source-context.d.ts.map +0 -1
- package/esm/context/database-data-source-context.js +0 -28
- package/esm/context/database-data-source-context.js.map +0 -1
- package/esm/context/database-transaction-context.d.ts +0 -35
- package/esm/context/database-transaction-context.d.ts.map +0 -1
- package/esm/context/database-transaction-context.js +0 -40
- package/esm/context/database-transaction-context.js.map +0 -1
- package/esm/contracts/database-driver.contract.d.ts +0 -450
- package/esm/contracts/database-driver.contract.d.ts.map +0 -1
- package/esm/contracts/database-id-generator.contract.d.ts +0 -109
- package/esm/contracts/database-id-generator.contract.d.ts.map +0 -1
- package/esm/contracts/database-remover.contract.d.ts +0 -104
- package/esm/contracts/database-remover.contract.d.ts.map +0 -1
- package/esm/contracts/database-restorer.contract.d.ts +0 -143
- package/esm/contracts/database-restorer.contract.d.ts.map +0 -1
- package/esm/contracts/database-writer.contract.d.ts +0 -119
- package/esm/contracts/database-writer.contract.d.ts.map +0 -1
- package/esm/contracts/driver-blueprint.contract.d.ts +0 -49
- package/esm/contracts/driver-blueprint.contract.d.ts.map +0 -1
- package/esm/contracts/index.d.ts +0 -10
- package/esm/contracts/index.d.ts.map +0 -1
- package/esm/contracts/migration-driver.contract.d.ts +0 -522
- package/esm/contracts/migration-driver.contract.d.ts.map +0 -1
- package/esm/contracts/query-builder.contract.d.ts +0 -1609
- package/esm/contracts/query-builder.contract.d.ts.map +0 -1
- package/esm/contracts/sync-adapter.contract.d.ts +0 -58
- package/esm/contracts/sync-adapter.contract.d.ts.map +0 -1
- package/esm/data-source/data-source-registry.d.ts +0 -108
- package/esm/data-source/data-source-registry.d.ts.map +0 -1
- package/esm/data-source/data-source-registry.js +0 -145
- package/esm/data-source/data-source-registry.js.map +0 -1
- package/esm/data-source/data-source.d.ts +0 -147
- package/esm/data-source/data-source.d.ts.map +0 -1
- package/esm/data-source/data-source.js +0 -83
- package/esm/data-source/data-source.js.map +0 -1
- package/esm/database-dirty-tracker.d.ts +0 -252
- package/esm/database-dirty-tracker.d.ts.map +0 -1
- package/esm/database-dirty-tracker.js +0 -386
- package/esm/database-dirty-tracker.js.map +0 -1
- package/esm/drivers/mongodb/mongodb-blueprint.d.ts +0 -30
- package/esm/drivers/mongodb/mongodb-blueprint.d.ts.map +0 -1
- package/esm/drivers/mongodb/mongodb-blueprint.js +0 -51
- package/esm/drivers/mongodb/mongodb-blueprint.js.map +0 -1
- package/esm/drivers/mongodb/mongodb-driver.d.ts +0 -325
- package/esm/drivers/mongodb/mongodb-driver.d.ts.map +0 -1
- package/esm/drivers/mongodb/mongodb-driver.js +0 -845
- package/esm/drivers/mongodb/mongodb-driver.js.map +0 -1
- package/esm/drivers/mongodb/mongodb-id-generator.d.ts +0 -116
- package/esm/drivers/mongodb/mongodb-id-generator.d.ts.map +0 -1
- package/esm/drivers/mongodb/mongodb-id-generator.js +0 -149
- package/esm/drivers/mongodb/mongodb-id-generator.js.map +0 -1
- package/esm/drivers/mongodb/mongodb-migration-driver.d.ts +0 -317
- package/esm/drivers/mongodb/mongodb-migration-driver.d.ts.map +0 -1
- package/esm/drivers/mongodb/mongodb-migration-driver.js +0 -666
- package/esm/drivers/mongodb/mongodb-migration-driver.js.map +0 -1
- package/esm/drivers/mongodb/mongodb-query-builder.d.ts +0 -1122
- package/esm/drivers/mongodb/mongodb-query-builder.d.ts.map +0 -1
- package/esm/drivers/mongodb/mongodb-query-builder.js +0 -1988
- package/esm/drivers/mongodb/mongodb-query-builder.js.map +0 -1
- package/esm/drivers/mongodb/mongodb-query-operations.d.ts +0 -226
- package/esm/drivers/mongodb/mongodb-query-operations.d.ts.map +0 -1
- package/esm/drivers/mongodb/mongodb-query-operations.js +0 -270
- package/esm/drivers/mongodb/mongodb-query-operations.js.map +0 -1
- package/esm/drivers/mongodb/mongodb-query-parser.d.ts +0 -262
- package/esm/drivers/mongodb/mongodb-query-parser.d.ts.map +0 -1
- package/esm/drivers/mongodb/mongodb-query-parser.js +0 -1351
- package/esm/drivers/mongodb/mongodb-query-parser.js.map +0 -1
- package/esm/drivers/mongodb/mongodb-sync-adapter.d.ts +0 -79
- package/esm/drivers/mongodb/mongodb-sync-adapter.d.ts.map +0 -1
- package/esm/drivers/mongodb/mongodb-sync-adapter.js +0 -146
- package/esm/drivers/mongodb/mongodb-sync-adapter.js.map +0 -1
- package/esm/drivers/mongodb/types.d.ts +0 -43
- package/esm/drivers/mongodb/types.d.ts.map +0 -1
- package/esm/drivers/postgres/index.d.ts +0 -16
- package/esm/drivers/postgres/index.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-blueprint.d.ts +0 -64
- package/esm/drivers/postgres/postgres-blueprint.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-blueprint.js +0 -121
- package/esm/drivers/postgres/postgres-blueprint.js.map +0 -1
- package/esm/drivers/postgres/postgres-dialect.d.ts +0 -136
- package/esm/drivers/postgres/postgres-dialect.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-dialect.js +0 -268
- package/esm/drivers/postgres/postgres-dialect.js.map +0 -1
- package/esm/drivers/postgres/postgres-driver.d.ts +0 -432
- package/esm/drivers/postgres/postgres-driver.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-driver.js +0 -1008
- package/esm/drivers/postgres/postgres-driver.js.map +0 -1
- package/esm/drivers/postgres/postgres-migration-driver.d.ts +0 -397
- package/esm/drivers/postgres/postgres-migration-driver.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-migration-driver.js +0 -900
- package/esm/drivers/postgres/postgres-migration-driver.js.map +0 -1
- package/esm/drivers/postgres/postgres-query-builder.d.ts +0 -254
- package/esm/drivers/postgres/postgres-query-builder.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-query-builder.js +0 -933
- package/esm/drivers/postgres/postgres-query-builder.js.map +0 -1
- package/esm/drivers/postgres/postgres-query-parser.d.ts +0 -328
- package/esm/drivers/postgres/postgres-query-parser.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-query-parser.js +0 -868
- package/esm/drivers/postgres/postgres-query-parser.js.map +0 -1
- package/esm/drivers/postgres/postgres-sql-serializer.d.ts +0 -37
- package/esm/drivers/postgres/postgres-sql-serializer.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-sql-serializer.js +0 -400
- package/esm/drivers/postgres/postgres-sql-serializer.js.map +0 -1
- package/esm/drivers/postgres/postgres-sync-adapter.d.ts +0 -83
- package/esm/drivers/postgres/postgres-sync-adapter.d.ts.map +0 -1
- package/esm/drivers/postgres/postgres-sync-adapter.js +0 -204
- package/esm/drivers/postgres/postgres-sync-adapter.js.map +0 -1
- package/esm/drivers/postgres/types.d.ts +0 -144
- package/esm/drivers/postgres/types.d.ts.map +0 -1
- package/esm/drivers/sql/index.d.ts +0 -10
- package/esm/drivers/sql/index.d.ts.map +0 -1
- package/esm/drivers/sql/sql-dialect.contract.d.ts +0 -204
- package/esm/drivers/sql/sql-dialect.contract.d.ts.map +0 -1
- package/esm/drivers/sql/sql-types.d.ts +0 -202
- package/esm/drivers/sql/sql-types.d.ts.map +0 -1
- package/esm/errors/missing-data-source.error.d.ts +0 -22
- package/esm/errors/missing-data-source.error.d.ts.map +0 -1
- package/esm/errors/missing-data-source.error.js +0 -29
- package/esm/errors/missing-data-source.error.js.map +0 -1
- package/esm/errors/transaction-rollback.error.d.ts +0 -20
- package/esm/errors/transaction-rollback.error.d.ts.map +0 -1
- package/esm/errors/transaction-rollback.error.js +0 -27
- package/esm/errors/transaction-rollback.error.js.map +0 -1
- package/esm/events/model-events.d.ts +0 -231
- package/esm/events/model-events.d.ts.map +0 -1
- package/esm/events/model-events.js +0 -259
- package/esm/events/model-events.js.map +0 -1
- package/esm/expressions/aggregate-expressions.d.ts +0 -215
- package/esm/expressions/aggregate-expressions.d.ts.map +0 -1
- package/esm/expressions/aggregate-expressions.js +0 -221
- package/esm/expressions/aggregate-expressions.js.map +0 -1
- package/esm/expressions/index.d.ts +0 -2
- package/esm/expressions/index.d.ts.map +0 -1
- package/esm/index.d.ts +0 -45
- package/esm/index.d.ts.map +0 -1
- package/esm/index.js +0 -1
- package/esm/index.js.map +0 -1
- package/esm/migration/column-builder.d.ts +0 -417
- package/esm/migration/column-builder.d.ts.map +0 -1
- package/esm/migration/column-builder.js +0 -586
- package/esm/migration/column-builder.js.map +0 -1
- package/esm/migration/column-helpers.d.ts +0 -275
- package/esm/migration/column-helpers.d.ts.map +0 -1
- package/esm/migration/column-helpers.js +0 -389
- package/esm/migration/column-helpers.js.map +0 -1
- package/esm/migration/foreign-key-builder.d.ts +0 -103
- package/esm/migration/foreign-key-builder.d.ts.map +0 -1
- package/esm/migration/foreign-key-builder.js +0 -121
- package/esm/migration/foreign-key-builder.js.map +0 -1
- package/esm/migration/index.d.ts +0 -7
- package/esm/migration/index.d.ts.map +0 -1
- package/esm/migration/migration-runner.d.ts +0 -278
- package/esm/migration/migration-runner.d.ts.map +0 -1
- package/esm/migration/migration-runner.js +0 -815
- package/esm/migration/migration-runner.js.map +0 -1
- package/esm/migration/migration.d.ts +0 -1988
- package/esm/migration/migration.d.ts.map +0 -1
- package/esm/migration/migration.js +0 -2162
- package/esm/migration/migration.js.map +0 -1
- package/esm/migration/sql-grammar.d.ts +0 -61
- package/esm/migration/sql-grammar.d.ts.map +0 -1
- package/esm/migration/sql-grammar.js +0 -164
- package/esm/migration/sql-grammar.js.map +0 -1
- package/esm/migration/sql-serializer.d.ts +0 -22
- package/esm/migration/sql-serializer.d.ts.map +0 -1
- package/esm/migration/sql-serializer.js +0 -26
- package/esm/migration/sql-serializer.js.map +0 -1
- package/esm/migration/types.d.ts +0 -155
- package/esm/migration/types.d.ts.map +0 -1
- package/esm/model/methods/accessor-methods.d.ts +0 -13
- package/esm/model/methods/accessor-methods.d.ts.map +0 -1
- package/esm/model/methods/accessor-methods.js +0 -51
- package/esm/model/methods/accessor-methods.js.map +0 -1
- package/esm/model/methods/delete-methods.d.ts +0 -10
- package/esm/model/methods/delete-methods.d.ts.map +0 -1
- package/esm/model/methods/delete-methods.js +0 -10
- package/esm/model/methods/delete-methods.js.map +0 -1
- package/esm/model/methods/dirty-methods.d.ts +0 -10
- package/esm/model/methods/dirty-methods.d.ts.map +0 -1
- package/esm/model/methods/dirty-methods.js +0 -15
- package/esm/model/methods/dirty-methods.js.map +0 -1
- package/esm/model/methods/hydration-methods.d.ts +0 -10
- package/esm/model/methods/hydration-methods.d.ts.map +0 -1
- package/esm/model/methods/hydration-methods.js +0 -57
- package/esm/model/methods/hydration-methods.js.map +0 -1
- package/esm/model/methods/instance-event-methods.d.ts +0 -7
- package/esm/model/methods/instance-event-methods.d.ts.map +0 -1
- package/esm/model/methods/instance-event-methods.js +0 -15
- package/esm/model/methods/instance-event-methods.js.map +0 -1
- package/esm/model/methods/meta-methods.d.ts +0 -7
- package/esm/model/methods/meta-methods.d.ts.map +0 -1
- package/esm/model/methods/meta-methods.js +0 -78
- package/esm/model/methods/meta-methods.js.map +0 -1
- package/esm/model/methods/query-methods.d.ts +0 -24
- package/esm/model/methods/query-methods.d.ts.map +0 -1
- package/esm/model/methods/query-methods.js +0 -164
- package/esm/model/methods/query-methods.js.map +0 -1
- package/esm/model/methods/restore-methods.d.ts +0 -10
- package/esm/model/methods/restore-methods.d.ts.map +0 -1
- package/esm/model/methods/restore-methods.js +0 -13
- package/esm/model/methods/restore-methods.js.map +0 -1
- package/esm/model/methods/scope-methods.d.ts +0 -7
- package/esm/model/methods/scope-methods.d.ts.map +0 -1
- package/esm/model/methods/scope-methods.js +0 -15
- package/esm/model/methods/scope-methods.js.map +0 -1
- package/esm/model/methods/serialization-methods.d.ts +0 -3
- package/esm/model/methods/serialization-methods.d.ts.map +0 -1
- package/esm/model/methods/serialization-methods.js +0 -27
- package/esm/model/methods/serialization-methods.js.map +0 -1
- package/esm/model/methods/static-event-methods.d.ts +0 -9
- package/esm/model/methods/static-event-methods.d.ts.map +0 -1
- package/esm/model/methods/static-event-methods.js +0 -29
- package/esm/model/methods/static-event-methods.js.map +0 -1
- package/esm/model/methods/write-methods.d.ts +0 -10
- package/esm/model/methods/write-methods.d.ts.map +0 -1
- package/esm/model/methods/write-methods.js +0 -52
- package/esm/model/methods/write-methods.js.map +0 -1
- package/esm/model/model.d.ts +0 -1647
- package/esm/model/model.d.ts.map +0 -1
- package/esm/model/model.js +0 -1657
- package/esm/model/model.js.map +0 -1
- package/esm/model/model.types.d.ts +0 -44
- package/esm/model/model.types.d.ts.map +0 -1
- package/esm/model/register-model.d.ts +0 -81
- package/esm/model/register-model.d.ts.map +0 -1
- package/esm/model/register-model.js +0 -94
- package/esm/model/register-model.js.map +0 -1
- package/esm/query-builder/query-builder.d.ts +0 -556
- package/esm/query-builder/query-builder.d.ts.map +0 -1
- package/esm/query-builder/query-builder.js +0 -1070
- package/esm/query-builder/query-builder.js.map +0 -1
- package/esm/relations/helpers.d.ts +0 -156
- package/esm/relations/helpers.d.ts.map +0 -1
- package/esm/relations/helpers.js +0 -202
- package/esm/relations/helpers.js.map +0 -1
- package/esm/relations/index.d.ts +0 -35
- package/esm/relations/index.d.ts.map +0 -1
- package/esm/relations/pivot-operations.d.ts +0 -160
- package/esm/relations/pivot-operations.d.ts.map +0 -1
- package/esm/relations/pivot-operations.js +0 -293
- package/esm/relations/pivot-operations.js.map +0 -1
- package/esm/relations/relation-hydrator.d.ts +0 -68
- package/esm/relations/relation-hydrator.d.ts.map +0 -1
- package/esm/relations/relation-hydrator.js +0 -81
- package/esm/relations/relation-hydrator.js.map +0 -1
- package/esm/relations/relation-loader.d.ts +0 -194
- package/esm/relations/relation-loader.d.ts.map +0 -1
- package/esm/relations/relation-loader.js +0 -466
- package/esm/relations/relation-loader.js.map +0 -1
- package/esm/relations/types.d.ts +0 -306
- package/esm/relations/types.d.ts.map +0 -1
- package/esm/remover/database-remover.d.ts +0 -100
- package/esm/remover/database-remover.d.ts.map +0 -1
- package/esm/remover/database-remover.js +0 -214
- package/esm/remover/database-remover.js.map +0 -1
- package/esm/restorer/database-restorer.d.ts +0 -131
- package/esm/restorer/database-restorer.d.ts.map +0 -1
- package/esm/restorer/database-restorer.js +0 -434
- package/esm/restorer/database-restorer.js.map +0 -1
- package/esm/sql-database-dirty-tracker.d.ts +0 -13
- package/esm/sql-database-dirty-tracker.d.ts.map +0 -1
- package/esm/sql-database-dirty-tracker.js +0 -14
- package/esm/sql-database-dirty-tracker.js.map +0 -1
- package/esm/sync/index.d.ts +0 -12
- package/esm/sync/index.d.ts.map +0 -1
- package/esm/sync/model-events.d.ts +0 -62
- package/esm/sync/model-events.d.ts.map +0 -1
- package/esm/sync/model-events.js +0 -49
- package/esm/sync/model-events.js.map +0 -1
- package/esm/sync/model-sync-operation.d.ts +0 -163
- package/esm/sync/model-sync-operation.d.ts.map +0 -1
- package/esm/sync/model-sync-operation.js +0 -292
- package/esm/sync/model-sync-operation.js.map +0 -1
- package/esm/sync/model-sync.d.ts +0 -130
- package/esm/sync/model-sync.d.ts.map +0 -1
- package/esm/sync/model-sync.js +0 -178
- package/esm/sync/model-sync.js.map +0 -1
- package/esm/sync/sync-context.d.ts +0 -70
- package/esm/sync/sync-context.d.ts.map +0 -1
- package/esm/sync/sync-context.js +0 -101
- package/esm/sync/sync-context.js.map +0 -1
- package/esm/sync/sync-manager.d.ts +0 -213
- package/esm/sync/sync-manager.d.ts.map +0 -1
- package/esm/sync/sync-manager.js +0 -689
- package/esm/sync/sync-manager.js.map +0 -1
- package/esm/sync/types.d.ts +0 -289
- package/esm/sync/types.d.ts.map +0 -1
- package/esm/test-migrations/test-enhanced-features.migration.d.ts +0 -15
- package/esm/test-migrations/test-enhanced-features.migration.d.ts.map +0 -1
- package/esm/types.d.ts +0 -371
- package/esm/types.d.ts.map +0 -1
- package/esm/utils/connect-to-database.d.ts +0 -307
- package/esm/utils/connect-to-database.d.ts.map +0 -1
- package/esm/utils/connect-to-database.js +0 -130
- package/esm/utils/connect-to-database.js.map +0 -1
- package/esm/utils/database-writer.utils.d.ts +0 -15
- package/esm/utils/database-writer.utils.d.ts.map +0 -1
- package/esm/utils/database-writer.utils.js +0 -14
- package/esm/utils/database-writer.utils.js.map +0 -1
- package/esm/utils/define-model.js +0 -100
- package/esm/utils/define-model.js.map +0 -1
- package/esm/utils/is-valid-date-value.d.ts +0 -5
- package/esm/utils/is-valid-date-value.d.ts.map +0 -1
- package/esm/utils/is-valid-date-value.js +0 -25
- package/esm/utils/is-valid-date-value.js.map +0 -1
- package/esm/utils/once-connected.d.ts +0 -146
- package/esm/utils/once-connected.d.ts.map +0 -1
- package/esm/utils/once-connected.js +0 -251
- package/esm/utils/once-connected.js.map +0 -1
- package/esm/validation/database-seal-plugins.d.ts +0 -12
- package/esm/validation/database-seal-plugins.d.ts.map +0 -1
- package/esm/validation/database-seal-plugins.js +0 -1
- package/esm/validation/database-seal-plugins.js.map +0 -1
- package/esm/validation/database-writer-validation-error.d.ts +0 -97
- package/esm/validation/database-writer-validation-error.d.ts.map +0 -1
- package/esm/validation/database-writer-validation-error.js +0 -160
- package/esm/validation/database-writer-validation-error.js.map +0 -1
- package/esm/validation/index.d.ts +0 -3
- package/esm/validation/index.d.ts.map +0 -1
- package/esm/validation/mutators/embed-mutator.d.ts +0 -9
- package/esm/validation/mutators/embed-mutator.d.ts.map +0 -1
- package/esm/validation/mutators/embed-mutator.js +0 -33
- package/esm/validation/mutators/embed-mutator.js.map +0 -1
- package/esm/validation/plugins/embed-validator-plugin.d.ts +0 -24
- package/esm/validation/plugins/embed-validator-plugin.d.ts.map +0 -1
- package/esm/validation/plugins/embed-validator-plugin.js +0 -18
- package/esm/validation/plugins/embed-validator-plugin.js.map +0 -1
- package/esm/validation/rules/database-model-rule.d.ts +0 -7
- package/esm/validation/rules/database-model-rule.d.ts.map +0 -1
- package/esm/validation/rules/database-model-rule.js +0 -27
- package/esm/validation/rules/database-model-rule.js.map +0 -1
- package/esm/validation/transformers/embed-model-transformer.d.ts +0 -3
- package/esm/validation/transformers/embed-model-transformer.d.ts.map +0 -1
- package/esm/validation/transformers/embed-model-transformer.js +0 -18
- package/esm/validation/transformers/embed-model-transformer.js.map +0 -1
- package/esm/validation/validators/embed-validator.d.ts +0 -21
- package/esm/validation/validators/embed-validator.d.ts.map +0 -1
- package/esm/validation/validators/embed-validator.js +0 -43
- package/esm/validation/validators/embed-validator.js.map +0 -1
- package/esm/writer/database-writer.d.ts +0 -174
- package/esm/writer/database-writer.d.ts.map +0 -1
- package/esm/writer/database-writer.js +0 -400
- package/esm/writer/database-writer.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-query-parser.mjs","names":[],"sources":["../../../../../../../@warlock.js/cascade/src/drivers/postgres/postgres-query-parser.ts"],"sourcesContent":["/**\n * PostgreSQL Query Parser\n *\n * Translates Cascade query operations into PostgreSQL SQL queries.\n * Mirrors the MongoQueryParser pattern but generates SQL instead\n * of MongoDB aggregation pipelines.\n *\n * @module cascade/drivers/postgres\n */\n\nimport type {\n DriverQuery,\n JoinOptions,\n WhereOperator,\n} from \"../../contracts/query-builder.contract\";\nimport type { SqlDialectContract } from \"../sql/sql-dialect.contract\";\n\nimport { PostgresDialect } from \"./postgres-dialect\";\n\n/**\n * Operation types supported by the query parser.\n */\nexport type PostgresOperationType =\n // WHERE operations\n | \"where\"\n | \"orWhere\"\n | \"whereRaw\"\n | \"orWhereRaw\"\n | \"whereIn\"\n | \"whereNotIn\"\n | \"whereNull\"\n | \"whereNotNull\"\n | \"whereBetween\"\n | \"whereNotBetween\"\n | \"whereLike\"\n | \"whereNotLike\"\n | \"whereColumn\"\n | \"orWhereColumn\"\n | \"whereExists\"\n | \"whereNotExists\"\n | \"whereDate\"\n | \"whereDateBefore\"\n | \"whereDateAfter\"\n | \"whereDateBetween\"\n | \"whereJsonContains\"\n | \"whereJsonDoesntContain\"\n | \"whereFullText\"\n // SELECT operations\n | \"select\"\n | \"selectRaw\"\n | \"deselect\"\n // JOIN operations\n | \"join\"\n | \"leftJoin\"\n | \"rightJoin\"\n | \"innerJoin\"\n | \"fullJoin\"\n | \"crossJoin\"\n | \"joinRaw\"\n // ORDER operations\n | \"orderBy\"\n | \"orderByRaw\"\n // GROUP operations\n | \"groupBy\"\n | \"having\"\n | \"havingRaw\"\n // LIMIT operations\n | \"limit\"\n | \"offset\"\n // RELATION operations\n | \"has\"\n | \"whereHas\"\n | \"doesntHave\"\n | \"whereDoesntHave\"\n // joinWith operations\n | \"selectRelatedColumns\"\n // Other\n | \"distinct\";\n\n/**\n * Internal operation representation.\n */\nexport type PostgresParserOperation = {\n /** Operation type */\n readonly type: PostgresOperationType;\n /** Operation data/parameters */\n readonly data: Record<string, unknown>;\n};\n\n/**\n * Parser configuration options.\n */\nexport type PostgresParserOptions = {\n /** Target table name */\n readonly table: string;\n /** Table alias (optional) */\n readonly alias?: string;\n /** Operations to parse */\n readonly operations: PostgresParserOperation[];\n /** SQL dialect for syntax generation */\n readonly dialect?: SqlDialectContract;\n /** Factory for creating sub-parsers (for nested queries) */\n readonly createSubParser?: (table: string) => PostgresQueryParser;\n};\n\n/**\n * PostgreSQL Query Parser.\n *\n * Converts a list of query operations into a SQL query string with parameters.\n * Handles SELECT, WHERE, JOIN, ORDER BY, GROUP BY, LIMIT/OFFSET clauses.\n *\n * @example\n * ```typescript\n * const parser = new PostgresQueryParser({\n * table: 'users',\n * operations: [\n * { type: 'where', data: { field: 'name', operator: '=', value: 'Alice' } },\n * { type: 'orderBy', data: { field: 'createdAt', direction: 'desc' } },\n * { type: 'limit', data: { value: 10 } }\n * ]\n * });\n *\n * const { sql, params } = parser.parse();\n * // sql: 'SELECT * FROM \"users\" WHERE \"name\" = $1 ORDER BY \"createdAt\" DESC LIMIT 10'\n * // params: ['Alice']\n * ```\n */\nexport class PostgresQueryParser {\n /**\n * Target table name.\n */\n private readonly table: string;\n\n /**\n * Table alias.\n */\n private readonly alias?: string;\n\n /**\n * Operations to process.\n */\n private readonly operations: PostgresParserOperation[];\n\n /**\n * SQL dialect for syntax.\n */\n private readonly dialect: SqlDialectContract;\n\n /**\n * Current parameter index (1-based for PostgreSQL).\n */\n private paramIndex = 1;\n\n /**\n * Collected parameters.\n */\n private readonly params: unknown[] = [];\n\n /**\n * SELECT columns.\n */\n public selectColumns: string[] = [];\n\n /**\n * Deselected (excluded) columns.\n */\n private deselectColumns: string[] = [];\n\n /**\n * Raw SELECT expressions.\n */\n private selectRaw: string[] = [];\n\n /**\n * WHERE clauses.\n */\n public whereClauses: string[] = [];\n\n /**\n * JOIN clauses.\n */\n private joinClauses: string[] = [];\n\n /**\n * ORDER BY clauses.\n */\n public orderClauses: string[] = [];\n\n /**\n * GROUP BY columns.\n */\n private groupColumns: string[] = [];\n\n /**\n * HAVING clauses.\n */\n private havingClauses: string[] = [];\n\n /**\n * LIMIT value.\n */\n public limitValue?: number;\n\n /**\n * OFFSET value.\n */\n public offsetValue?: number;\n\n /**\n * DISTINCT flag.\n */\n private isDistinct = false;\n\n /**\n * Whether the query has any JOIN operations (pre-scanned before processing).\n * Used by qualifyColumn() to decide whether to prefix columns with the main table.\n */\n private hasJoins = false;\n\n /**\n * Tracked joined tables (for table reference detection).\n */\n private readonly joinedTables = new Set<string>();\n\n /**\n * Create a new query parser.\n *\n * @param options - Parser configuration\n */\n public constructor(options: PostgresParserOptions) {\n this.table = options.table;\n this.alias = options.alias;\n this.operations = options.operations;\n this.dialect = options.dialect ?? new PostgresDialect();\n }\n\n /**\n * Parse all operations and build the SQL query.\n *\n * @returns DriverQuery with `query` (SQL string) and `bindings` (parameter values)\n */\n public parse(): DriverQuery {\n // Pre-scan for any join operations so qualifyColumn() can prefix columns\n // correctly even when WHERE clauses appear before JOINs in the operations list.\n const JOIN_TYPES = new Set([\n \"join\",\n \"leftJoin\",\n \"rightJoin\",\n \"innerJoin\",\n \"fullJoin\",\n \"crossJoin\",\n \"joinRaw\",\n ]);\n\n this.hasJoins = false;\n\n // First pass: locate all joins and populate joinedTables for accurate JSON path detection\n for (const operation of this.operations) {\n if (JOIN_TYPES.has(operation.type)) {\n this.hasJoins = true;\n const data = operation.data as any;\n const joinTable = data.table as string;\n const alias = data.alias as string;\n\n if (joinTable) this.joinedTables.add(joinTable);\n if (alias) this.joinedTables.add(alias);\n }\n }\n\n // Process each operation\n for (const operation of this.operations) {\n this.processOperation(operation);\n }\n\n // Build the final SQL query\n const query = this.buildSql();\n\n return { query, bindings: this.params };\n }\n\n /**\n * Get a formatted string representation of the query.\n *\n * @returns Formatted SQL with bindings\n */\n public toPrettyString(): string {\n const { query = \"\", bindings } = this.parse();\n return `${query}\\n-- Bindings: ${JSON.stringify(bindings ?? [])}`;\n }\n\n /**\n * Process a single operation.\n *\n * @param operation - The operation to process\n */\n private processOperation(operation: PostgresParserOperation): void {\n const { type, data } = operation;\n\n switch (type) {\n // WHERE operations\n case \"where\":\n this.processWhere(data, \"AND\");\n break;\n case \"orWhere\":\n this.processWhere(data, \"OR\");\n break;\n case \"whereRaw\":\n this.processWhereRaw(data, \"AND\");\n break;\n case \"orWhereRaw\":\n this.processWhereRaw(data, \"OR\");\n break;\n case \"whereIn\":\n this.processWhereIn(data, false);\n break;\n case \"whereNotIn\":\n this.processWhereIn(data, true);\n break;\n case \"whereNull\":\n this.processWhereNull(data, false);\n break;\n case \"whereNotNull\":\n this.processWhereNull(data, true);\n break;\n case \"whereBetween\":\n this.processWhereBetween(data, false);\n break;\n case \"whereNotBetween\":\n this.processWhereBetween(data, true);\n break;\n case \"whereLike\":\n this.processWhereLike(data, false);\n break;\n case \"whereNotLike\":\n this.processWhereLike(data, true);\n break;\n case \"whereColumn\":\n this.processWhereColumn(data, \"AND\");\n break;\n case \"orWhereColumn\":\n this.processWhereColumn(data, \"OR\");\n break;\n case \"whereJsonContains\":\n this.processWhereJsonContains(data, false);\n break;\n case \"whereJsonDoesntContain\":\n this.processWhereJsonContains(data, true);\n break;\n case \"whereFullText\":\n this.processWhereFullText(data);\n break;\n\n // SELECT operations\n case \"select\":\n this.processSelect(data);\n break;\n case \"selectRaw\":\n this.processSelectRaw(data);\n break;\n case \"deselect\":\n this.processDeselect(data);\n break;\n\n // JOIN operations\n case \"join\":\n case \"innerJoin\":\n this.processJoin(data, \"INNER\");\n break;\n case \"leftJoin\":\n this.processJoin(data, \"LEFT\");\n break;\n case \"rightJoin\":\n this.processJoin(data, \"RIGHT\");\n break;\n case \"fullJoin\":\n this.processJoin(data, \"FULL OUTER\");\n break;\n case \"crossJoin\":\n this.processCrossJoin(data);\n break;\n case \"joinRaw\":\n this.processJoinRaw(data);\n break;\n\n // ORDER operations\n case \"orderBy\":\n this.processOrderBy(data);\n break;\n case \"orderByRaw\":\n this.processOrderByRaw(data);\n break;\n\n // GROUP operations\n case \"groupBy\":\n this.processGroupBy(data);\n break;\n case \"having\":\n this.processHaving(data);\n break;\n case \"havingRaw\":\n this.processHavingRaw(data);\n break;\n\n // LIMIT operations\n case \"limit\":\n this.limitValue = data.value as number;\n break;\n case \"offset\":\n this.offsetValue = data.value as number;\n break;\n\n // Other\n case \"distinct\":\n this.isDistinct = true;\n break;\n\n // joinWith select related columns\n case \"selectRelatedColumns\":\n this.processSelectRelatedColumns(data);\n break;\n\n default:\n // Unknown operation - ignore or throw\n break;\n }\n }\n\n /**\n * Build the final SQL query from collected clauses.\n *\n * @returns Complete SQL query string\n */\n private buildSql(): string {\n const parts: string[] = [];\n\n // SELECT clause\n parts.push(this.buildSelectClause());\n\n // FROM clause\n const quotedTable = this.dialect.quoteIdentifier(this.table);\n const fromClause = this.alias\n ? `FROM ${quotedTable} AS ${this.dialect.quoteIdentifier(this.alias)}`\n : `FROM ${quotedTable}`;\n parts.push(fromClause);\n\n // JOIN clauses\n if (this.joinClauses.length > 0) {\n parts.push(this.joinClauses.join(\" \"));\n }\n\n // WHERE clause\n if (this.whereClauses.length > 0) {\n parts.push(`WHERE ${this.whereClauses.join(\" \")}`);\n }\n\n // GROUP BY clause\n if (this.groupColumns.length > 0) {\n const quotedCols = this.groupColumns.map((c) => this.dialect.quoteIdentifier(c));\n parts.push(`GROUP BY ${quotedCols.join(\", \")}`);\n }\n\n // HAVING clause\n if (this.havingClauses.length > 0) {\n parts.push(`HAVING ${this.havingClauses.join(\" AND \")}`);\n }\n\n // ORDER BY clause\n if (this.orderClauses.length > 0) {\n parts.push(`ORDER BY ${this.orderClauses.join(\", \")}`);\n }\n\n // LIMIT/OFFSET\n const limitOffset = this.dialect.limitOffset(this.limitValue, this.offsetValue);\n if (limitOffset) {\n parts.push(limitOffset);\n }\n\n return parts.join(\" \");\n }\n\n /**\n * Build the SELECT clause.\n *\n * @returns SELECT clause string\n */\n private buildSelectClause(): string {\n const distinct = this.isDistinct ? \"DISTINCT \" : \"\";\n\n // If no specific columns, select all — qualify with main table when joins present\n if (this.selectColumns.length === 0 && this.selectRaw.length === 0) {\n return this.hasJoins\n ? `SELECT ${distinct}${this.dialect.quoteIdentifier(this.table)}.*`\n : `SELECT ${distinct}*`;\n }\n\n const columns: string[] = [];\n\n // Add selected columns — prefix with main table when joins present to avoid ambiguity\n for (const col of this.selectColumns) {\n if (!this.deselectColumns.includes(col)) {\n columns.push(this.parseColumnIdentifier(col, this.table, this.alias));\n }\n }\n\n // Add raw expressions\n columns.push(...this.selectRaw);\n\n return `SELECT ${distinct}${columns.join(\", \")}`;\n }\n\n /**\n * Add a placeholder and parameter.\n *\n * @param value - Parameter value\n * @returns Placeholder string ($1, $2, etc.)\n */\n private addParam(value: unknown): string {\n this.params.push(value);\n return this.dialect.placeholder(this.paramIndex++);\n }\n\n /**\n * Absorb a sub-parser's params into this parser, returning a rewriter\n * function that translates the sub-parser's `$N` placeholders into freshly\n * numbered placeholders in this parser's namespace.\n *\n * Required whenever sub-parser SQL fragments (e.g. WHERE clauses produced\n * for a `joinWith` constraint) are spliced into the outer query — without\n * the rewrite the embedded `$N` references point at parameters this\n * parser has no knowledge of, leaving them dangling in the final SQL.\n *\n * The sub-parser's `params[i]` corresponds to its `$(i+1)` placeholder\n * (its `paramIndex` always starts at 1), so we map sequentially.\n *\n * @example\n * const renumber = this.absorbSubParserParams(subParser);\n * const fragment = renumber(subParser.whereClauses.join(\" \"));\n */\n private absorbSubParserParams(subParser: PostgresQueryParser): (sql: string) => string {\n if (subParser.params.length === 0) {\n return (sql) => sql;\n }\n\n const oldToNew = new Map<string, string>();\n\n for (let index = 0; index < subParser.params.length; index++) {\n const newPlaceholder = this.addParam(subParser.params[index]);\n oldToNew.set(`$${index + 1}`, newPlaceholder);\n }\n\n return (sql) => sql.replace(/\\$\\d+/g, (match) => oldToNew.get(match) ?? match);\n }\n\n /**\n * Process a basic WHERE operation.\n *\n * Delegates to specialised processors for operators that require more than a\n * single placeholder (between, in, like-variants, exists, etc.).\n */\n private processWhere(data: Record<string, unknown>, boolean: \"AND\" | \"OR\"): void {\n const field = data.field as string;\n const operator = (data.operator as WhereOperator) ?? \"=\";\n const value = data.value;\n\n // Delegate to specialised processors for operators that need it\n switch (operator) {\n case \"between\":\n return this.processWhereBetween({ field, range: value as [unknown, unknown] }, false);\n case \"notBetween\":\n return this.processWhereBetween({ field, range: value as [unknown, unknown] }, true);\n case \"in\":\n return this.processWhereIn({ field, values: value as unknown[] }, false);\n case \"notIn\":\n return this.processWhereIn({ field, values: value as unknown[] }, true);\n case \"like\":\n case \"ilike\":\n case \"startsWith\":\n case \"endsWith\":\n return this.processWhereLike({ field, pattern: value as string }, false);\n case \"notLike\":\n case \"notStartsWith\":\n case \"notEndsWith\":\n return this.processWhereLike({ field, pattern: value as string }, true);\n case \"exists\":\n // EXISTS expects value to be a raw sub-query string\n return this.addWhereClause(`EXISTS (${value})`, boolean);\n }\n\n const quotedField = this.parseColumnIdentifier(field, this.table, this.alias);\n\n if (value === null) {\n const nullOperator = operator === \"!=\" ? \"IS NOT NULL\" : \"IS NULL\";\n return this.addWhereClause(`${quotedField} ${nullOperator}`, boolean);\n }\n\n // Simple single-value operator — fall through to generic path\n const placeholder = this.addParam(value);\n this.addWhereClause(`${quotedField} ${this.mapOperator(operator)} ${placeholder}`, boolean);\n }\n\n /**\n * Process a raw WHERE operation.\n */\n private processWhereRaw(data: Record<string, unknown>, boolean: \"AND\" | \"OR\"): void {\n const expression = data.expression as string;\n const bindings = (data.bindings as unknown[]) ?? [];\n\n // Replace ? placeholders with $n\n let processed = expression;\n for (const binding of bindings) {\n processed = processed.replace(\"?\", this.addParam(binding));\n }\n\n this.addWhereClause(processed, boolean);\n }\n\n /**\n * Process WHERE IN / NOT IN.\n */\n private processWhereIn(data: Record<string, unknown>, negate: boolean): void {\n const field = data.field as string;\n const values = data.values as unknown[];\n\n const quotedField = this.parseColumnIdentifier(field, this.table, this.alias);\n const operator = negate ? \"!= ALL\" : \"= ANY\";\n const placeholder = this.addParam(values);\n\n this.addWhereClause(`${quotedField} ${operator}(${placeholder})`, \"AND\");\n }\n\n /**\n * Process WHERE NULL / NOT NULL.\n */\n private processWhereNull(data: Record<string, unknown>, negate: boolean): void {\n const field = data.field as string;\n const quotedField = this.parseColumnIdentifier(field, this.table, this.alias);\n const clause = negate ? `${quotedField} IS NOT NULL` : `${quotedField} IS NULL`;\n this.addWhereClause(clause, \"AND\");\n }\n\n /**\n * Process WHERE BETWEEN / NOT BETWEEN.\n */\n private processWhereBetween(data: Record<string, unknown>, negate: boolean): void {\n const field = data.field as string;\n const range = data.range as [unknown, unknown];\n\n const quotedField = this.parseColumnIdentifier(field, this.table, this.alias);\n const placeholder1 = this.addParam(range[0]);\n const placeholder2 = this.addParam(range[1]);\n const keyword = negate ? \"NOT BETWEEN\" : \"BETWEEN\";\n\n this.addWhereClause(`${quotedField} ${keyword} ${placeholder1} AND ${placeholder2}`, \"AND\");\n }\n\n /**\n * Process WHERE LIKE / NOT LIKE.\n */\n private processWhereLike(data: Record<string, unknown>, negate: boolean): void {\n const field = data.field as string;\n const pattern = data.pattern as string;\n\n const quotedField = this.parseColumnIdentifier(field, this.table, this.alias);\n const { operator } = this.dialect.likePattern(pattern, true);\n const placeholder = this.addParam(pattern);\n const keyword = negate ? `NOT ${operator}` : operator;\n\n this.addWhereClause(`${quotedField} ${keyword} ${placeholder}`, \"AND\");\n }\n\n /**\n * Process WHERE column comparison.\n */\n private processWhereColumn(data: Record<string, unknown>, boolean: \"AND\" | \"OR\"): void {\n const first = data.first as string;\n const operator = (data.operator as string) ?? \"=\";\n const second = data.second as string;\n\n // Both sides may need qualification if unambiguous table is unclear\n const quotedFirst = this.parseColumnIdentifier(first, this.table, this.alias);\n const quotedSecond = this.parseColumnIdentifier(second, this.table, this.alias);\n\n this.addWhereClause(`${quotedFirst} ${operator} ${quotedSecond}`, boolean);\n }\n\n /**\n * Process WHERE JSON contains.\n */\n private processWhereJsonContains(data: Record<string, unknown>, negate: boolean): void {\n const path = data.path as string;\n const value = data.value;\n\n const quotedPath = this.parseColumnIdentifier(path, this.table, this.alias);\n const jsonValue = JSON.stringify(value);\n const operator = negate ? \"NOT @>\" : \"@>\";\n\n this.addWhereClause(`${quotedPath} ${operator} '${jsonValue}'::jsonb`, \"AND\");\n }\n\n /**\n * Process full-text search WHERE.\n */\n private processWhereFullText(data: Record<string, unknown>): void {\n const fields = data.fields as string[];\n const query = data.query as string;\n\n // Build tsvector from fields\n const tsVectors = fields\n .map((f) => `to_tsvector('english', ${this.dialect.quoteIdentifier(f)})`)\n .join(\" || \");\n\n const placeholder = this.addParam(query);\n this.addWhereClause(`(${tsVectors}) @@ plainto_tsquery('english', ${placeholder})`, \"AND\");\n }\n\n /**\n * Process SELECT operation.\n */\n private processSelect(data: Record<string, unknown>): void {\n const fields = data.fields as string[] | Record<string, string>;\n\n if (Array.isArray(fields)) {\n this.selectColumns.push(...fields);\n } else {\n // Handle aliases: { field: 'alias' }\n for (const [field, alias] of Object.entries(fields)) {\n const quotedField = this.dialect.quoteIdentifier(field);\n const quotedAlias = this.dialect.quoteIdentifier(alias);\n this.selectRaw.push(`${quotedField} AS ${quotedAlias}`);\n }\n }\n }\n\n /**\n * Process raw SELECT expression.\n */\n private processSelectRaw(data: Record<string, unknown>): void {\n const expression = data.expression as string | Record<string, unknown>;\n const bindings = (data.bindings as unknown[]) ?? [];\n\n if (typeof expression === \"string\") {\n // Replace ? placeholders with $n positional params (same as processWhereRaw)\n let processed = expression;\n for (const binding of bindings) {\n processed = processed.replace(\"?\", this.addParam(binding));\n }\n this.selectRaw.push(processed);\n } else {\n // Handle object expressions (for compatibility)\n for (const [alias, expr] of Object.entries(expression)) {\n this.selectRaw.push(`${expr} AS ${this.dialect.quoteIdentifier(alias)}`);\n }\n }\n }\n\n /**\n * Process DESELECT operation.\n */\n private processDeselect(data: Record<string, unknown>): void {\n const fields = data.fields as string[];\n this.deselectColumns.push(...fields);\n }\n\n /**\n * Process SELECT for related columns (joinWith).\n *\n * - hasOne / belongsTo → LEFT JOIN + row_to_json (single object)\n * - hasMany → correlated subquery with json_agg (array, no row explosion)\n *\n * @example hasMany correlated subquery:\n * (SELECT json_agg(row_to_json(a.*))\n * FROM \"chat_message_actions\" a\n * WHERE a.\"chat_message_id\" = \"chat_messages\".\"id\") AS \"actions\"\n *\n * @example hasOne/belongsTo row_to_json:\n * row_to_json(\"organizationAiModel\".*) AS \"organizationAiModel\"\n */\n private processSelectRelatedColumns(data: Record<string, unknown>): void {\n const alias = data.alias as string;\n const select = data.select as string[] | undefined;\n const relationType = data.type as string | undefined;\n const constraintOps = data.constraintOps as PostgresParserOperation[] | undefined;\n const quotedAlias = this.dialect.quoteIdentifier(alias);\n const quotedTable = this.dialect.quoteIdentifier(this.table);\n\n const hasExplicitSelect = this.selectColumns.length > 0;\n if (!hasExplicitSelect && !this.selectRaw.includes(`${quotedTable}.*`)) {\n this.selectRaw.unshift(`${quotedTable}.*`);\n }\n\n if (relationType === \"hasMany\") {\n // Correlated subquery — no JOIN, no row explosion, returns a JSON array.\n const relatedTable = data.table as string;\n const foreignKey = data.foreignKey as string;\n const localKey = data.localKey as string;\n const quotedRelatedTable = this.dialect.quoteIdentifier(relatedTable);\n const quotedForeignKey = this.dialect.quoteIdentifier(foreignKey);\n const quotedLocalKey = this.dialect.quoteIdentifier(localKey);\n const quotedMainTable = this.dialect.quoteIdentifier(this.table);\n\n let innerSelect: string;\n if (select && select.length > 0) {\n // Pick specific columns: json_agg(json_build_object('id', a.\"id\", ...))\n const fields = select\n .map((col) => `'${col}', a.${this.dialect.quoteIdentifier(col)}`)\n .join(\", \");\n innerSelect = `json_agg(json_build_object(${fields}))`;\n } else {\n innerSelect = `json_agg(row_to_json(a.*))`;\n }\n\n // Build the base FK condition\n const fkCondition = `a.${quotedForeignKey} = ${quotedMainTable}.${quotedLocalKey}`;\n\n // Merge constraint ops (where / order / limit) from a sub-parser.\n // The sub-parser numbers its own placeholders starting at $1; we must\n // absorb its params into this parser and renumber the embedded SQL,\n // otherwise $N references in the merged clauses dangle.\n let extraWhere = \"\";\n let orderBy = \"\";\n let limitClause = \"\";\n\n if (constraintOps && constraintOps.length > 0) {\n const subParser = new PostgresQueryParser({\n table: relatedTable,\n alias: \"a\",\n operations: constraintOps,\n });\n subParser.parse();\n\n const renumber = this.absorbSubParserParams(subParser);\n\n if (subParser.whereClauses.length > 0) {\n extraWhere = ` AND ${renumber(subParser.whereClauses.join(\" \"))}`;\n }\n if (subParser.orderClauses.length > 0) {\n orderBy = ` ORDER BY ${renumber(subParser.orderClauses.join(\", \"))}`;\n }\n if (subParser.limitValue !== undefined) {\n limitClause = ` LIMIT ${subParser.limitValue}`;\n }\n }\n\n // Wrap with ORDER/LIMIT only when constraints are present (json_agg ignores ORDER)\n const innerQuery =\n orderBy || limitClause\n ? `SELECT row_to_json(sub.*) FROM (SELECT * FROM ${quotedRelatedTable} a WHERE ${fkCondition}${extraWhere}${orderBy}${limitClause}) sub`\n : `SELECT ${innerSelect.replace(\"json_agg(\", \"\").replace(/\\)$/, \"\")} FROM ${quotedRelatedTable} a WHERE ${fkCondition}${extraWhere}`;\n\n const aggregated =\n orderBy || limitClause\n ? `(SELECT json_agg(row_to_json(sub.*)) FROM (SELECT * FROM ${quotedRelatedTable} a WHERE ${fkCondition}${extraWhere}${orderBy}${limitClause}) sub) AS ${quotedAlias}`\n : `(SELECT ${innerSelect} FROM ${quotedRelatedTable} a WHERE ${fkCondition}${extraWhere}) AS ${quotedAlias}`;\n\n this.selectRaw.push(aggregated);\n } else {\n // hasOne / belongsTo — single object via LEFT JOIN + row_to_json.\n // If constraint provides an explicit select list, prefer it over data.select\n let effectiveSelect = select;\n if (constraintOps && constraintOps.length > 0) {\n const subParser = new PostgresQueryParser({\n table: (data.table as string) ?? alias,\n alias,\n operations: constraintOps,\n });\n subParser.parse();\n if (subParser.selectColumns.length > 0) {\n effectiveSelect = subParser.selectColumns;\n }\n }\n\n if (effectiveSelect && effectiveSelect.length > 0) {\n const selectedColumns = effectiveSelect\n .map((col) => `${quotedAlias}.${this.dialect.quoteIdentifier(col)}`)\n .join(\", \");\n this.selectRaw.push(\n `row_to_json((SELECT d FROM (SELECT ${selectedColumns}) d)) AS ${quotedAlias}`,\n );\n } else {\n this.selectRaw.push(`row_to_json(${quotedAlias}.*) AS ${quotedAlias}`);\n }\n }\n }\n\n /**\n * Process JOIN operation with smart field detection.\n *\n * Handles both regular columns and JSONB nested paths:\n * - \"id\" → \"table\".\"id\" (auto-prefixed)\n * - \"users.id\" → \"users\".\"id\" (explicit table)\n * - \"createdBy.id\" → \"table\".\"createdBy\"->>'id' (JSONB path)\n * - \"posts.createdBy.id\" → \"posts\".\"createdBy\"->>'id' (JSONB with table)\n */\n private processJoin(data: Record<string, unknown>, type: string): void {\n const options = data as unknown as\n | JoinOptions\n | { table: string; localField: string; foreignField: string };\n\n const joinTable = \"table\" in options ? options.table : \"\";\n const localField = \"localField\" in options ? options.localField : \"\";\n const foreignField = \"foreignField\" in options ? options.foreignField : \"\";\n const alias = \"alias\" in options ? options.alias : undefined;\n const constraintOps = (data.constraintOps as PostgresParserOperation[] | undefined) ?? [];\n\n const quotedTable = this.dialect.quoteIdentifier(joinTable);\n const tableRef = alias\n ? `${quotedTable} AS ${this.dialect.quoteIdentifier(alias)}`\n : quotedTable;\n const tableAlias = alias ?? joinTable;\n\n // Track the joined table for reference detection\n this.joinedTables.add(joinTable);\n if (alias) {\n this.joinedTables.add(alias);\n }\n\n // Parse local field (belongs to main table)\n const quotedLocal = this.parseColumnIdentifier(localField!, this.table, this.alias);\n\n // Parse foreign field (belongs to join table)\n const quotedForeign = this.parseColumnIdentifier(foreignField!, joinTable, tableAlias);\n\n // Build the basic ON condition. For hasOne/belongsTo joinWith with a\n // constraint callback, append the constraint's where-clauses to the ON\n // clause (preserves LEFT JOIN semantics — main rows stay even when no\n // related row passes the constraint). orderBy/limit on the constraint\n // are silently dropped — they have no meaning on a single-row LEFT JOIN.\n let onClause = `${quotedLocal} = ${quotedForeign}`;\n\n if (constraintOps.length > 0) {\n const whereOps = constraintOps.filter(\n (op) => op.type.startsWith(\"where\") || op.type.startsWith(\"orWhere\"),\n );\n\n if (whereOps.length > 0) {\n const subParser = new PostgresQueryParser({\n table: joinTable,\n alias: tableAlias,\n operations: whereOps,\n });\n subParser.parse();\n\n if (subParser.whereClauses.length > 0) {\n const renumber = this.absorbSubParserParams(subParser);\n onClause = `${onClause} AND ${renumber(subParser.whereClauses.join(\" \"))}`;\n }\n }\n }\n\n this.joinClauses.push(`${type} JOIN ${tableRef} ON ${onClause}`);\n }\n\n /**\n * Parse a column identifier with smart detection for table prefixes and JSONB paths.\n *\n * Supports an optional explicit cast suffix using PostgreSQL's `::type` syntax,\n * which is the only way to coerce a JSONB-extracted value (always returned as\n * `text`) into another type. The parser does NOT infer casts from key names —\n * coercion is always opt-in by the caller.\n *\n * @param field - The field string. Examples:\n * - \"id\" → `\"table\".\"id\"`\n * - \"users.id\" → `\"users\".\"id\"`\n * - \"createdBy.id\" → `\"table\".\"createdBy\"->>'id'`\n * - \"createdBy.id::int\" → `(\"table\".\"createdBy\"->>'id')::int`\n * - \"meta.score::numeric\" → `(\"table\".\"meta\"->>'score')::numeric`\n * - \"posts.createdBy.id::uuid\" → `(\"posts\".\"createdBy\"->>'id')::uuid`\n * @param defaultTable - Default table to use if no prefix\n * @param tableAlias - Table alias to use if provided\n * @returns Properly quoted SQL expression\n */\n private parseColumnIdentifier(field: string, defaultTable: string, tableAlias?: string): string {\n if (!field) return \"\";\n\n // Extract optional explicit cast suffix: \"createdBy.id::int\" → path \"createdBy.id\", cast \"int\"\n let cast: string | undefined;\n const castIndex = field.indexOf(\"::\");\n if (castIndex !== -1) {\n cast = field.slice(castIndex + 2).trim();\n field = field.slice(0, castIndex);\n }\n\n const effectiveTable = tableAlias ?? defaultTable;\n const parts = field.split(\".\");\n\n let expression: string;\n\n if (parts.length === 1) {\n // Single part: just a column name, prefix with default table\n expression = `${this.dialect.quoteIdentifier(effectiveTable)}.${this.dialect.quoteIdentifier(field)}`;\n } else if (parts.length === 2) {\n // Two parts: could be \"table.column\" or \"jsonbColumn.key\"\n const [first, second] = parts;\n\n if (this.isTableReference(first)) {\n // It's table.column - regular column reference\n expression = `${this.dialect.quoteIdentifier(first)}.${this.dialect.quoteIdentifier(second)}`;\n } else {\n // It's jsonbColumn.key - JSONB path\n expression = this.buildJsonbPath(effectiveTable, first, [second]);\n }\n } else {\n // Three or more parts: \"table.jsonbColumn.key...\" or \"jsonbColumn.key1.key2...\"\n const [first, second, ...rest] = parts;\n\n if (this.isTableReference(first)) {\n // First part is table: \"posts.createdBy.id\" → table is \"posts\", JSONB is \"createdBy.id\"\n expression = this.buildJsonbPath(first, second, rest);\n } else {\n // No table prefix: \"createdBy.address.city\" → use default table\n expression = this.buildJsonbPath(effectiveTable, first, [second, ...rest]);\n }\n }\n\n return cast ? `(${expression})::${cast}` : expression;\n }\n\n /**\n * Check if a string is a table reference (main table or join table).\n */\n private isTableReference(name: string): boolean {\n if (name === this.table || name === this.alias) {\n return true;\n }\n\n if (this.joinedTables.has(name)) {\n return true;\n }\n\n return false;\n }\n\n /**\n * Build a JSONB path expression.\n *\n * @param table - Table name\n * @param column - JSONB column name\n * @param path - Array of nested keys\n * @returns PostgreSQL JSONB path expression\n *\n * Returns the raw JSONB path expression — extracted values are always `text`\n * (`->>` returns text). Callers that need a different type must request an\n * explicit cast via the `::type` suffix in `parseColumnIdentifier`.\n *\n * @example\n * buildJsonbPath(\"posts\", \"createdBy\", [\"id\"])\n * // Returns: \"posts\".\"createdBy\"->>'id'\n *\n * buildJsonbPath(\"posts\", \"createdBy\", [\"address\", \"city\"])\n * // Returns: \"posts\".\"createdBy\"->'address'->>'city'\n */\n private buildJsonbPath(table: string, column: string, path: string[]): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumn = this.dialect.quoteIdentifier(column);\n\n if (path.length === 0) {\n return `${quotedTable}.${quotedColumn}`;\n }\n\n // Build JSONB path: use -> for intermediate keys, ->> for final key (returns text)\n let expression = `${quotedTable}.${quotedColumn}`;\n\n for (let i = 0; i < path.length; i++) {\n const isLast = i === path.length - 1;\n const operator = isLast ? \"->>\" : \"->\";\n expression += `${operator}'${path[i]}'`;\n }\n\n return expression;\n }\n\n /**\n * Process CROSS JOIN operation.\n */\n private processCrossJoin(data: Record<string, unknown>): void {\n const table = data.table as string;\n const quotedTable = this.dialect.quoteIdentifier(table);\n this.joinClauses.push(`CROSS JOIN ${quotedTable}`);\n }\n\n /**\n * Process raw JOIN expression.\n */\n private processJoinRaw(data: Record<string, unknown>): void {\n const expression = data.expression as string;\n const bindings = (data.bindings as unknown[]) ?? [];\n\n let processed = expression;\n for (const binding of bindings) {\n processed = processed.replace(\"?\", this.addParam(binding));\n }\n\n this.joinClauses.push(processed);\n }\n\n /**\n * Process ORDER BY operation.\n */\n private processOrderBy(data: Record<string, unknown>): void {\n const field = data.field as string;\n const direction = ((data.direction as string) ?? \"asc\").toUpperCase();\n\n const quotedField = this.parseColumnIdentifier(field, this.table, this.alias);\n this.orderClauses.push(`${quotedField} ${direction}`);\n }\n\n /**\n * Process raw ORDER BY expression.\n */\n private processOrderByRaw(data: Record<string, unknown>): void {\n const expression = data.expression as string;\n const bindings = (data.bindings as unknown[]) ?? [];\n\n // Replace ? placeholders with $n positional params (same as processWhereRaw)\n let processed = expression;\n for (const binding of bindings) {\n processed = processed.replace(\"?\", this.addParam(binding));\n }\n this.orderClauses.push(processed);\n }\n\n /**\n * Process GROUP BY operation.\n */\n private processGroupBy(data: Record<string, unknown>): void {\n const fields = data.fields as string | string[];\n const columns = Array.isArray(fields) ? fields : [fields];\n this.groupColumns.push(...columns);\n }\n\n /**\n * Process HAVING operation.\n */\n private processHaving(data: Record<string, unknown>): void {\n const field = data.field as string;\n const operator = (data.operator as string) ?? \"=\";\n const value = data.value;\n\n const quotedField = this.dialect.quoteIdentifier(field);\n const placeholder = this.addParam(value);\n\n this.havingClauses.push(`${quotedField} ${operator} ${placeholder}`);\n }\n\n /**\n * Process a raw HAVING expression, threading `?` placeholders into\n * positional params the same way `processWhereRaw` / `processSelectRaw` do.\n * Without this, bindings on a `havingRaw` op are silently dropped.\n */\n private processHavingRaw(data: Record<string, unknown>): void {\n let expression = data.expression as string;\n const bindings = (data.bindings as unknown[]) ?? [];\n\n for (const binding of bindings) {\n expression = expression.replace(\"?\", this.addParam(binding));\n }\n\n this.havingClauses.push(expression);\n }\n\n /**\n * Add a WHERE clause with boolean operator.\n */\n private addWhereClause(clause: string, boolean: \"AND\" | \"OR\"): void {\n if (this.whereClauses.length === 0) {\n this.whereClauses.push(clause);\n } else {\n this.whereClauses.push(`${boolean} ${clause}`);\n }\n }\n\n /**\n * Map simple Cascade operators to their SQL equivalents.\n *\n * Complex operators (between, in, like-variants, exists) are handled by\n * dedicated processors and should never reach this method.\n */\n private mapOperator(operator: WhereOperator): string {\n const mapping: Record<string, string> = {\n \"=\": \"=\",\n \"!=\": \"!=\",\n \"<>\": \"<>\",\n \">\": \">\",\n \">=\": \">=\",\n \"<\": \"<\",\n \"<=\": \"<=\",\n like: \"LIKE\",\n notlike: \"NOT LIKE\",\n ilike: \"ILIKE\",\n };\n\n return mapping[operator.toLowerCase()] ?? operator;\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,260 @@
|
|
|
1
|
+
import { SQLSerializer } from "../../migration/sql-serializer.mjs";
|
|
2
|
+
|
|
3
|
+
//#region ../../@warlock.js/cascade/src/drivers/postgres/postgres-sql-serializer.ts
|
|
4
|
+
/**
|
|
5
|
+
* PostgreSQL-specific SQL serializer.
|
|
6
|
+
*
|
|
7
|
+
* Converts pending migration operations into valid PostgreSQL DDL statements.
|
|
8
|
+
*/
|
|
9
|
+
var PostgresSQLSerializer = class extends SQLSerializer {
|
|
10
|
+
dialect;
|
|
11
|
+
constructor(dialect) {
|
|
12
|
+
super();
|
|
13
|
+
this.dialect = dialect;
|
|
14
|
+
}
|
|
15
|
+
serialize(operation, table) {
|
|
16
|
+
switch (operation.type) {
|
|
17
|
+
case "createTable": return this.createTable(table);
|
|
18
|
+
case "createTableIfNotExists": return this.createTableIfNotExists(table);
|
|
19
|
+
case "dropTable": return this.dropTable(table);
|
|
20
|
+
case "dropTableIfExists": return this.dropTableIfExists(table);
|
|
21
|
+
case "renameTable": return this.renameTable(table, operation.payload);
|
|
22
|
+
case "truncateTable": return this.truncateTable(table);
|
|
23
|
+
case "addColumn": return this.addColumn(table, operation.payload);
|
|
24
|
+
case "dropColumn": return this.dropColumn(table, operation.payload);
|
|
25
|
+
case "dropColumns": return this.dropColumns(table, operation.payload);
|
|
26
|
+
case "renameColumn": {
|
|
27
|
+
const payload = operation.payload;
|
|
28
|
+
return this.renameColumn(table, payload.from, payload.to);
|
|
29
|
+
}
|
|
30
|
+
case "modifyColumn": return this.modifyColumn(table, operation.payload);
|
|
31
|
+
case "createIndex": return this.createIndex(table, operation.payload);
|
|
32
|
+
case "dropIndex": return this.dropIndex(table, operation.payload);
|
|
33
|
+
case "createUniqueIndex": {
|
|
34
|
+
const payload = operation.payload;
|
|
35
|
+
return this.createIndex(table, {
|
|
36
|
+
columns: payload.columns,
|
|
37
|
+
name: payload.name,
|
|
38
|
+
unique: true
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
case "dropUniqueIndex": return this.dropIndex(table, operation.payload);
|
|
42
|
+
case "createFullTextIndex": {
|
|
43
|
+
const payload = operation.payload;
|
|
44
|
+
return this.createFullTextIndex(table, payload.columns, payload.options);
|
|
45
|
+
}
|
|
46
|
+
case "dropFullTextIndex": return this.dropIndex(table, operation.payload);
|
|
47
|
+
case "createGeoIndex": {
|
|
48
|
+
const payload = operation.payload;
|
|
49
|
+
return this.createGeoIndex(table, payload.column, payload.options);
|
|
50
|
+
}
|
|
51
|
+
case "dropGeoIndex": return this.dropIndex(table, `idx_${table}_geo_${operation.payload}`);
|
|
52
|
+
case "createVectorIndex": {
|
|
53
|
+
const payload = operation.payload;
|
|
54
|
+
return this.createVectorIndex(table, payload.column, payload.options);
|
|
55
|
+
}
|
|
56
|
+
case "dropVectorIndex": return this.dropIndex(table, `idx_${table}_vector_${operation.payload}`);
|
|
57
|
+
case "createTTLIndex": {
|
|
58
|
+
const payload = operation.payload;
|
|
59
|
+
return this.createTTLIndex(table, payload.column, payload.expireAfterSeconds);
|
|
60
|
+
}
|
|
61
|
+
case "dropTTLIndex": return this.dropIndex(table, `idx_${table}_ttl_${operation.payload}`);
|
|
62
|
+
case "addForeignKey": return this.addForeignKey(table, operation.payload);
|
|
63
|
+
case "dropForeignKey": return this.dropForeignKey(table, operation.payload);
|
|
64
|
+
case "addPrimaryKey": return this.addPrimaryKey(table, operation.payload);
|
|
65
|
+
case "dropPrimaryKey": return this.dropPrimaryKey(table);
|
|
66
|
+
case "addCheck": return null;
|
|
67
|
+
case "dropCheck": return null;
|
|
68
|
+
case "createTimestamps": return this.createTimestamps(table);
|
|
69
|
+
case "rawStatement": return operation.payload;
|
|
70
|
+
case "setSchemaValidation":
|
|
71
|
+
case "removeSchemaValidation": return null;
|
|
72
|
+
default: return null;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
createTable(table) {
|
|
76
|
+
return `CREATE TABLE ${this.dialect.quoteIdentifier(table)} ()`;
|
|
77
|
+
}
|
|
78
|
+
createTableIfNotExists(table) {
|
|
79
|
+
return `CREATE TABLE IF NOT EXISTS ${this.dialect.quoteIdentifier(table)} ()`;
|
|
80
|
+
}
|
|
81
|
+
dropTable(table) {
|
|
82
|
+
return `DROP TABLE ${this.dialect.quoteIdentifier(table)} CASCADE`;
|
|
83
|
+
}
|
|
84
|
+
dropTableIfExists(table) {
|
|
85
|
+
return `DROP TABLE IF EXISTS ${this.dialect.quoteIdentifier(table)} CASCADE`;
|
|
86
|
+
}
|
|
87
|
+
renameTable(from, to) {
|
|
88
|
+
return `ALTER TABLE ${this.dialect.quoteIdentifier(from)} RENAME TO ${this.dialect.quoteIdentifier(to)}`;
|
|
89
|
+
}
|
|
90
|
+
truncateTable(table) {
|
|
91
|
+
return `TRUNCATE TABLE ${this.dialect.quoteIdentifier(table)}`;
|
|
92
|
+
}
|
|
93
|
+
addColumn(table, column) {
|
|
94
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
95
|
+
const quotedColumn = this.dialect.quoteIdentifier(column.name);
|
|
96
|
+
let sqlType;
|
|
97
|
+
if (column.autoIncrement) if (column.type === "bigInteger") sqlType = "BIGSERIAL";
|
|
98
|
+
else sqlType = "SERIAL";
|
|
99
|
+
else sqlType = this.dialect.getSqlType(column.type, {
|
|
100
|
+
length: column.length,
|
|
101
|
+
precision: column.precision,
|
|
102
|
+
scale: column.scale,
|
|
103
|
+
dimensions: column.dimensions
|
|
104
|
+
});
|
|
105
|
+
let sql = `ALTER TABLE ${quotedTable} ADD COLUMN ${quotedColumn} ${sqlType}`;
|
|
106
|
+
if (column.generated) {
|
|
107
|
+
sql += ` GENERATED ALWAYS AS (${column.generated.expression})`;
|
|
108
|
+
if (column.generated.stored) sql += " STORED";
|
|
109
|
+
} else {
|
|
110
|
+
if (!column.autoIncrement && column.nullable === false) sql += " NOT NULL";
|
|
111
|
+
if (column.defaultValue !== void 0) if (typeof column.defaultValue === "object" && column.defaultValue !== null && column.defaultValue.__type === "CURRENT_TIMESTAMP") sql += " DEFAULT NOW()";
|
|
112
|
+
else if (column.isRawDefault === false) {
|
|
113
|
+
const escaped = String(column.defaultValue).replace(/'/g, "''");
|
|
114
|
+
sql += ` DEFAULT '${escaped}'`;
|
|
115
|
+
} else if (typeof column.defaultValue === "boolean") sql += ` DEFAULT ${column.defaultValue ? "TRUE" : "FALSE"}`;
|
|
116
|
+
else if (typeof column.defaultValue === "number") sql += ` DEFAULT ${column.defaultValue}`;
|
|
117
|
+
else sql += ` DEFAULT ${column.defaultValue}`;
|
|
118
|
+
if (column.primary) sql += " PRIMARY KEY";
|
|
119
|
+
if (column.unique) sql += " UNIQUE";
|
|
120
|
+
}
|
|
121
|
+
if (column.type === "vector") return ["CREATE EXTENSION IF NOT EXISTS vector", sql];
|
|
122
|
+
return sql;
|
|
123
|
+
}
|
|
124
|
+
dropColumn(table, column) {
|
|
125
|
+
return `ALTER TABLE ${this.dialect.quoteIdentifier(table)} DROP COLUMN ${this.dialect.quoteIdentifier(column)}`;
|
|
126
|
+
}
|
|
127
|
+
dropColumns(table, columns) {
|
|
128
|
+
return `ALTER TABLE ${this.dialect.quoteIdentifier(table)} ${columns.map((col) => `DROP COLUMN ${this.dialect.quoteIdentifier(col)}`).join(", ")}`;
|
|
129
|
+
}
|
|
130
|
+
renameColumn(table, from, to) {
|
|
131
|
+
return `ALTER TABLE ${this.dialect.quoteIdentifier(table)} RENAME COLUMN ${this.dialect.quoteIdentifier(from)} TO ${this.dialect.quoteIdentifier(to)}`;
|
|
132
|
+
}
|
|
133
|
+
modifyColumn(table, column) {
|
|
134
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
135
|
+
const quotedColumn = this.dialect.quoteIdentifier(column.name);
|
|
136
|
+
const sqlType = this.dialect.getSqlType(column.type, {
|
|
137
|
+
length: column.length,
|
|
138
|
+
precision: column.precision,
|
|
139
|
+
scale: column.scale,
|
|
140
|
+
dimensions: column.dimensions
|
|
141
|
+
});
|
|
142
|
+
const alters = [];
|
|
143
|
+
alters.push(`ALTER COLUMN ${quotedColumn} TYPE ${sqlType}`);
|
|
144
|
+
if (column.nullable === false) alters.push(`ALTER COLUMN ${quotedColumn} SET NOT NULL`);
|
|
145
|
+
else if (column.nullable === true) alters.push(`ALTER COLUMN ${quotedColumn} DROP NOT NULL`);
|
|
146
|
+
if (column.defaultValue !== void 0) {
|
|
147
|
+
let defaultVal;
|
|
148
|
+
if (typeof column.defaultValue === "object" && column.defaultValue !== null && column.defaultValue.__type === "CURRENT_TIMESTAMP") defaultVal = "NOW()";
|
|
149
|
+
else if (typeof column.defaultValue === "string") defaultVal = `'${column.defaultValue}'`;
|
|
150
|
+
else defaultVal = String(column.defaultValue);
|
|
151
|
+
alters.push(`ALTER COLUMN ${quotedColumn} SET DEFAULT ${defaultVal}`);
|
|
152
|
+
}
|
|
153
|
+
return `ALTER TABLE ${quotedTable} ${alters.join(", ")}`;
|
|
154
|
+
}
|
|
155
|
+
createTimestamps(table) {
|
|
156
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
157
|
+
return [`ALTER TABLE ${quotedTable} ADD COLUMN "created_at" TIMESTAMPTZ NOT NULL DEFAULT NOW()`, `ALTER TABLE ${quotedTable} ADD COLUMN "updated_at" TIMESTAMPTZ NOT NULL DEFAULT NOW()`];
|
|
158
|
+
}
|
|
159
|
+
createIndex(table, index) {
|
|
160
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
161
|
+
let indexName;
|
|
162
|
+
if (index.name) indexName = index.name;
|
|
163
|
+
else indexName = `idx_${table}_${Array.isArray(index.columns) ? index.columns.join("_") : index.columns}`;
|
|
164
|
+
const quotedIndexName = this.dialect.quoteIdentifier(indexName);
|
|
165
|
+
const uniqueKeyword = index.unique ? "UNIQUE " : "";
|
|
166
|
+
const concurrentlyKeyword = index.concurrently ? "CONCURRENTLY " : "";
|
|
167
|
+
let columnsPart;
|
|
168
|
+
if (index.expressions && index.expressions.length > 0) columnsPart = index.expressions.map((expr) => `(${expr})`).join(", ");
|
|
169
|
+
else columnsPart = index.columns.map((col, i) => {
|
|
170
|
+
const quotedCol = this.dialect.quoteIdentifier(col);
|
|
171
|
+
const direction = index.directions?.[i]?.toUpperCase() ?? "";
|
|
172
|
+
return direction ? `${quotedCol} ${direction}` : quotedCol;
|
|
173
|
+
}).join(", ");
|
|
174
|
+
let sql = `CREATE ${uniqueKeyword}INDEX ${concurrentlyKeyword}${quotedIndexName} ON ${quotedTable} (${columnsPart})`;
|
|
175
|
+
if (index.include && index.include.length > 0) {
|
|
176
|
+
const includeCols = index.include.map((col) => this.dialect.quoteIdentifier(col)).join(", ");
|
|
177
|
+
sql += ` INCLUDE (${includeCols})`;
|
|
178
|
+
}
|
|
179
|
+
if (index.where && Object.keys(index.where).length > 0) {
|
|
180
|
+
const conditions = Object.entries(index.where).map(([key, value]) => {
|
|
181
|
+
const quotedKey = this.dialect.quoteIdentifier(key);
|
|
182
|
+
return typeof value === "string" ? `${quotedKey} = '${value}'` : `${quotedKey} = ${value}`;
|
|
183
|
+
}).join(" AND ");
|
|
184
|
+
sql += ` WHERE ${conditions}`;
|
|
185
|
+
}
|
|
186
|
+
return sql;
|
|
187
|
+
}
|
|
188
|
+
dropIndex(table, indexNameOrColumns) {
|
|
189
|
+
let indexName;
|
|
190
|
+
if (typeof indexNameOrColumns === "string") indexName = indexNameOrColumns;
|
|
191
|
+
else indexName = `idx_${table}_${indexNameOrColumns.join("_")}`;
|
|
192
|
+
return `DROP INDEX IF EXISTS ${this.dialect.quoteIdentifier(indexName)}`;
|
|
193
|
+
}
|
|
194
|
+
createFullTextIndex(table, columns, options) {
|
|
195
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
196
|
+
const indexName = options?.name ?? `idx_${table}_fulltext_${columns.join("_")}`;
|
|
197
|
+
const quotedIndexName = this.dialect.quoteIdentifier(indexName);
|
|
198
|
+
const language = options?.language ?? "english";
|
|
199
|
+
return `CREATE INDEX ${quotedIndexName} ON ${quotedTable} USING GIN ((${columns.map((col) => {
|
|
200
|
+
const weight = options?.weights?.[col] ?? "A";
|
|
201
|
+
return `setweight(to_tsvector('${language}', COALESCE(${this.dialect.quoteIdentifier(col)}, '')), '${weight}')`;
|
|
202
|
+
}).join(" || ")}))`;
|
|
203
|
+
}
|
|
204
|
+
createGeoIndex(table, column, options) {
|
|
205
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
206
|
+
const quotedColumn = this.dialect.quoteIdentifier(column);
|
|
207
|
+
const indexName = options?.name ?? `idx_${table}_geo_${column}`;
|
|
208
|
+
return `CREATE INDEX ${this.dialect.quoteIdentifier(indexName)} ON ${quotedTable} USING GIST (${quotedColumn})`;
|
|
209
|
+
}
|
|
210
|
+
createVectorIndex(table, column, options) {
|
|
211
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
212
|
+
const quotedColumn = this.dialect.quoteIdentifier(column);
|
|
213
|
+
const indexName = options.name ?? `idx_${table}_vector_${column}`;
|
|
214
|
+
return `CREATE INDEX ${this.dialect.quoteIdentifier(indexName)} ON ${quotedTable} USING ivfflat (${quotedColumn} ${options.similarity === "euclidean" ? "vector_l2_ops" : options.similarity === "dotProduct" ? "vector_ip_ops" : "vector_cosine_ops"}) WITH (lists = ${options.lists ?? 100})`;
|
|
215
|
+
}
|
|
216
|
+
createTTLIndex(table, column, expireAfterSeconds) {
|
|
217
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
218
|
+
const quotedColumn = this.dialect.quoteIdentifier(column);
|
|
219
|
+
const indexName = `idx_${table}_ttl_${column}`;
|
|
220
|
+
return `CREATE INDEX ${this.dialect.quoteIdentifier(indexName)} ON ${quotedTable} (${quotedColumn}) WHERE ${quotedColumn} < NOW() - INTERVAL '${expireAfterSeconds} seconds'`;
|
|
221
|
+
}
|
|
222
|
+
addForeignKey(table, foreignKey) {
|
|
223
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
224
|
+
const quotedColumn = this.dialect.quoteIdentifier(foreignKey.column);
|
|
225
|
+
const quotedRefTable = this.dialect.quoteIdentifier(foreignKey.referencesTable);
|
|
226
|
+
const quotedRefColumn = this.dialect.quoteIdentifier(foreignKey.referencesColumn);
|
|
227
|
+
const constraintName = foreignKey.name ?? `fk_${table}_${foreignKey.column}_${foreignKey.referencesTable}`;
|
|
228
|
+
let sql = `ALTER TABLE ${quotedTable} ADD CONSTRAINT ${this.dialect.quoteIdentifier(constraintName)} FOREIGN KEY (${quotedColumn}) REFERENCES ${quotedRefTable} (${quotedRefColumn})`;
|
|
229
|
+
if (foreignKey.onDelete) sql += ` ON DELETE ${this.mapForeignKeyAction(foreignKey.onDelete)}`;
|
|
230
|
+
if (foreignKey.onUpdate) sql += ` ON UPDATE ${this.mapForeignKeyAction(foreignKey.onUpdate)}`;
|
|
231
|
+
return sql;
|
|
232
|
+
}
|
|
233
|
+
dropForeignKey(table, name) {
|
|
234
|
+
return `ALTER TABLE ${this.dialect.quoteIdentifier(table)} DROP CONSTRAINT ${this.dialect.quoteIdentifier(name)}`;
|
|
235
|
+
}
|
|
236
|
+
addPrimaryKey(table, columns) {
|
|
237
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
238
|
+
const quotedColumns = columns.map((c) => this.dialect.quoteIdentifier(c)).join(", ");
|
|
239
|
+
const constraintName = `pk_${table}`;
|
|
240
|
+
return `ALTER TABLE ${quotedTable} ADD CONSTRAINT ${this.dialect.quoteIdentifier(constraintName)} PRIMARY KEY (${quotedColumns})`;
|
|
241
|
+
}
|
|
242
|
+
dropPrimaryKey(table) {
|
|
243
|
+
const quotedTable = this.dialect.quoteIdentifier(table);
|
|
244
|
+
const constraintName = `pk_${table}`;
|
|
245
|
+
return `ALTER TABLE ${quotedTable} DROP CONSTRAINT ${this.dialect.quoteIdentifier(constraintName)}`;
|
|
246
|
+
}
|
|
247
|
+
mapForeignKeyAction(action) {
|
|
248
|
+
switch (action) {
|
|
249
|
+
case "cascade": return "CASCADE";
|
|
250
|
+
case "restrict": return "RESTRICT";
|
|
251
|
+
case "setNull": return "SET NULL";
|
|
252
|
+
case "noAction": return "NO ACTION";
|
|
253
|
+
default: return "NO ACTION";
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
};
|
|
257
|
+
|
|
258
|
+
//#endregion
|
|
259
|
+
export { PostgresSQLSerializer };
|
|
260
|
+
//# sourceMappingURL=postgres-sql-serializer.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-sql-serializer.mjs","names":[],"sources":["../../../../../../../@warlock.js/cascade/src/drivers/postgres/postgres-sql-serializer.ts"],"sourcesContent":["import type { SqlDialectContract } from \"../sql/sql-dialect.contract\";\nimport type { PendingOperation } from \"../../migration/migration\";\nimport { SQLSerializer } from \"../../migration/sql-serializer\";\nimport type {\n ColumnDefinition,\n ForeignKeyDefinition,\n FullTextIndexOptions,\n GeoIndexOptions,\n IndexDefinition,\n VectorIndexOptions,\n} from \"../../contracts/migration-driver.contract\";\n\n/**\n * PostgreSQL-specific SQL serializer.\n *\n * Converts pending migration operations into valid PostgreSQL DDL statements.\n */\nexport class PostgresSQLSerializer extends SQLSerializer {\n public constructor(private readonly dialect: SqlDialectContract) {\n super();\n }\n\n public serialize(operation: PendingOperation, table: string): string | string[] | null {\n switch (operation.type) {\n case \"createTable\":\n return this.createTable(table);\n case \"createTableIfNotExists\":\n return this.createTableIfNotExists(table);\n case \"dropTable\":\n return this.dropTable(table);\n case \"dropTableIfExists\":\n return this.dropTableIfExists(table);\n case \"renameTable\":\n return this.renameTable(table, operation.payload as string);\n case \"truncateTable\":\n return this.truncateTable(table);\n case \"addColumn\":\n return this.addColumn(table, operation.payload as ColumnDefinition);\n case \"dropColumn\":\n return this.dropColumn(table, operation.payload as string);\n case \"dropColumns\":\n // This is handled via map in serializeAll or loop, but Postgres supports multiple DROP COLUMN\n // For simplicity, we can serialize multiple statements if we want, or handle it here\n // Actually, dropColumns payload is string[]. We can join them.\n return this.dropColumns(table, operation.payload as string[]);\n case \"renameColumn\": {\n const payload = operation.payload as { from: string; to: string };\n return this.renameColumn(table, payload.from, payload.to);\n }\n case \"modifyColumn\":\n // Modify column might require multiple statements in Postgres (type, nullability, default).\n // SQLSerializer's serialize return is just a string, so we'll separate them by semicolon\n // Or wait, Postgres allows multiple ALTER COLUMN in one ALTER TABLE statement.\n return this.modifyColumn(table, operation.payload as ColumnDefinition);\n case \"createIndex\":\n return this.createIndex(table, operation.payload as IndexDefinition);\n case \"dropIndex\":\n return this.dropIndex(table, operation.payload as string | string[]);\n case \"createUniqueIndex\": {\n const payload = operation.payload as { columns: string[]; name?: string };\n return this.createIndex(table, { columns: payload.columns, name: payload.name, unique: true });\n }\n case \"dropUniqueIndex\":\n return this.dropIndex(table, operation.payload as string[]);\n case \"createFullTextIndex\": {\n const payload = operation.payload as { columns: string[]; options?: FullTextIndexOptions };\n return this.createFullTextIndex(table, payload.columns, payload.options);\n }\n case \"dropFullTextIndex\":\n return this.dropIndex(table, operation.payload as string);\n case \"createGeoIndex\": {\n const payload = operation.payload as { column: string; options?: GeoIndexOptions };\n return this.createGeoIndex(table, payload.column, payload.options);\n }\n case \"dropGeoIndex\":\n return this.dropIndex(table, `idx_${table}_geo_${operation.payload}`);\n case \"createVectorIndex\": {\n const payload = operation.payload as { column: string; options: VectorIndexOptions };\n return this.createVectorIndex(table, payload.column, payload.options);\n }\n case \"dropVectorIndex\":\n return this.dropIndex(table, `idx_${table}_vector_${operation.payload}`);\n case \"createTTLIndex\": {\n const payload = operation.payload as { column: string; expireAfterSeconds: number };\n return this.createTTLIndex(table, payload.column, payload.expireAfterSeconds);\n }\n case \"dropTTLIndex\":\n return this.dropIndex(table, `idx_${table}_ttl_${operation.payload}`);\n case \"addForeignKey\":\n return this.addForeignKey(table, operation.payload as ForeignKeyDefinition);\n case \"dropForeignKey\":\n return this.dropForeignKey(table, operation.payload as string);\n case \"addPrimaryKey\":\n return this.addPrimaryKey(table, operation.payload as string[]);\n case \"dropPrimaryKey\":\n return this.dropPrimaryKey(table);\n case \"addCheck\":\n // addCheck is not natively implemented in MigrationDriverContract but exists in OperationType\n return null;\n case \"dropCheck\":\n return null;\n case \"createTimestamps\":\n // createTimestamps needs to inject two columns. We return two statements.\n return this.createTimestamps(table);\n case \"rawStatement\": {\n const payload = operation.payload as string;\n // ensure string doesn't end with a semicolon if it's already one statement\n return payload;\n }\n case \"setSchemaValidation\":\n case \"removeSchemaValidation\":\n // Not implemented in PostgreSQL\n return null;\n default:\n return null;\n }\n }\n\n // ============================================================================\n // TABLE OPERATIONS\n // ============================================================================\n\n private createTable(table: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n return `CREATE TABLE ${quotedTable} ()`;\n }\n\n private createTableIfNotExists(table: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n return `CREATE TABLE IF NOT EXISTS ${quotedTable} ()`;\n }\n\n private dropTable(table: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n return `DROP TABLE ${quotedTable} CASCADE`;\n }\n\n private dropTableIfExists(table: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n return `DROP TABLE IF EXISTS ${quotedTable} CASCADE`;\n }\n\n private renameTable(from: string, to: string): string {\n const quotedFrom = this.dialect.quoteIdentifier(from);\n const quotedTo = this.dialect.quoteIdentifier(to);\n return `ALTER TABLE ${quotedFrom} RENAME TO ${quotedTo}`;\n }\n\n private truncateTable(table: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n return `TRUNCATE TABLE ${quotedTable}`;\n }\n\n // ============================================================================\n // COLUMN OPERATIONS\n // ============================================================================\n\n private addColumn(table: string, column: ColumnDefinition): string | string[] {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumn = this.dialect.quoteIdentifier(column.name);\n\n let sqlType: string;\n if (column.autoIncrement) {\n if (column.type === \"bigInteger\") {\n sqlType = \"BIGSERIAL\";\n } else {\n sqlType = \"SERIAL\";\n }\n } else {\n sqlType = this.dialect.getSqlType(column.type, {\n length: column.length,\n precision: column.precision,\n scale: column.scale,\n dimensions: column.dimensions,\n });\n }\n\n let sql = `ALTER TABLE ${quotedTable} ADD COLUMN ${quotedColumn} ${sqlType}`;\n\n if (column.generated) {\n sql += ` GENERATED ALWAYS AS (${column.generated.expression})`;\n if (column.generated.stored) {\n sql += \" STORED\";\n }\n } else {\n if (!column.autoIncrement && column.nullable === false) {\n sql += \" NOT NULL\";\n }\n\n if (column.defaultValue !== undefined) {\n if (\n typeof column.defaultValue === \"object\" &&\n column.defaultValue !== null &&\n (column.defaultValue as any).__type === \"CURRENT_TIMESTAMP\"\n ) {\n sql += \" DEFAULT NOW()\";\n } else if (column.isRawDefault === false) {\n const escaped = String(column.defaultValue).replace(/'/g, \"''\");\n sql += ` DEFAULT '${escaped}'`;\n } else if (typeof column.defaultValue === \"boolean\") {\n sql += ` DEFAULT ${column.defaultValue ? \"TRUE\" : \"FALSE\"}`;\n } else if (typeof column.defaultValue === \"number\") {\n sql += ` DEFAULT ${column.defaultValue}`;\n } else {\n sql += ` DEFAULT ${column.defaultValue}`; // raw default\n }\n }\n\n if (column.primary) {\n sql += \" PRIMARY KEY\";\n }\n\n if (column.unique) {\n sql += \" UNIQUE\";\n }\n }\n\n // pgvector: ensure the extension is active before the vector column is created.\n // SQLGrammar classifies CREATE EXTENSION as Phase 1, so this will always\n // run before any CREATE TABLE / ADD COLUMN statement regardless of batch order.\n if (column.type === \"vector\") {\n return [\"CREATE EXTENSION IF NOT EXISTS vector\", sql];\n }\n\n return sql;\n }\n\n private dropColumn(table: string, column: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumn = this.dialect.quoteIdentifier(column);\n return `ALTER TABLE ${quotedTable} DROP COLUMN ${quotedColumn}`;\n }\n\n private dropColumns(table: string, columns: string[]): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const drops = columns.map((col) => `DROP COLUMN ${this.dialect.quoteIdentifier(col)}`).join(\", \");\n return `ALTER TABLE ${quotedTable} ${drops}`;\n }\n\n private renameColumn(table: string, from: string, to: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedFrom = this.dialect.quoteIdentifier(from);\n const quotedTo = this.dialect.quoteIdentifier(to);\n return `ALTER TABLE ${quotedTable} RENAME COLUMN ${quotedFrom} TO ${quotedTo}`;\n }\n\n private modifyColumn(table: string, column: ColumnDefinition): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumn = this.dialect.quoteIdentifier(column.name);\n const sqlType = this.dialect.getSqlType(column.type, {\n length: column.length,\n precision: column.precision,\n scale: column.scale,\n dimensions: column.dimensions,\n });\n\n const alters: string[] = [];\n alters.push(`ALTER COLUMN ${quotedColumn} TYPE ${sqlType}`);\n\n if (column.nullable === false) {\n alters.push(`ALTER COLUMN ${quotedColumn} SET NOT NULL`);\n } else if (column.nullable === true) {\n alters.push(`ALTER COLUMN ${quotedColumn} DROP NOT NULL`);\n }\n\n if (column.defaultValue !== undefined) {\n let defaultVal: string;\n if (\n typeof column.defaultValue === \"object\" &&\n column.defaultValue !== null &&\n (column.defaultValue as any).__type === \"CURRENT_TIMESTAMP\"\n ) {\n defaultVal = \"NOW()\";\n } else if (typeof column.defaultValue === \"string\") {\n defaultVal = `'${column.defaultValue}'`;\n } else {\n defaultVal = String(column.defaultValue);\n }\n alters.push(`ALTER COLUMN ${quotedColumn} SET DEFAULT ${defaultVal}`);\n }\n\n return `ALTER TABLE ${quotedTable} ${alters.join(\", \")}`;\n }\n\n private createTimestamps(table: string): string[] {\n const quotedTable = this.dialect.quoteIdentifier(table);\n return [\n `ALTER TABLE ${quotedTable} ADD COLUMN \"created_at\" TIMESTAMPTZ NOT NULL DEFAULT NOW()`,\n `ALTER TABLE ${quotedTable} ADD COLUMN \"updated_at\" TIMESTAMPTZ NOT NULL DEFAULT NOW()`,\n ];\n }\n\n // ============================================================================\n // INDEX OPERATIONS\n // ============================================================================\n\n private createIndex(table: string, index: IndexDefinition): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n let indexName: string;\n if (index.name) {\n indexName = index.name;\n } else {\n const colStr = Array.isArray(index.columns) ? index.columns.join(\"_\") : index.columns;\n indexName = `idx_${table}_${colStr}`;\n }\n const quotedIndexName = this.dialect.quoteIdentifier(indexName);\n const uniqueKeyword = index.unique ? \"UNIQUE \" : \"\";\n const concurrentlyKeyword = index.concurrently ? \"CONCURRENTLY \" : \"\";\n\n let columnsPart: string;\n\n if (index.expressions && index.expressions.length > 0) {\n columnsPart = index.expressions.map((expr) => `(${expr})`).join(\", \");\n } else {\n const columns = index.columns.map((col, i) => {\n const quotedCol = this.dialect.quoteIdentifier(col);\n const direction = index.directions?.[i]?.toUpperCase() ?? \"\";\n return direction ? `${quotedCol} ${direction}` : quotedCol;\n });\n columnsPart = columns.join(\", \");\n }\n\n let sql = `CREATE ${uniqueKeyword}INDEX ${concurrentlyKeyword}${quotedIndexName} ON ${quotedTable} (${columnsPart})`;\n\n if (index.include && index.include.length > 0) {\n const includeCols = index.include.map((col) => this.dialect.quoteIdentifier(col)).join(\", \");\n sql += ` INCLUDE (${includeCols})`;\n }\n\n if (index.where && Object.keys(index.where).length > 0) {\n const conditions = Object.entries(index.where)\n .map(([key, value]) => {\n const quotedKey = this.dialect.quoteIdentifier(key);\n return typeof value === \"string\" ? `${quotedKey} = '${value}'` : `${quotedKey} = ${value}`;\n })\n .join(\" AND \");\n sql += ` WHERE ${conditions}`;\n }\n\n return sql;\n }\n\n private dropIndex(table: string, indexNameOrColumns: string | string[]): string {\n let indexName: string;\n if (typeof indexNameOrColumns === \"string\") {\n indexName = indexNameOrColumns;\n } else {\n indexName = `idx_${table}_${indexNameOrColumns.join(\"_\")}`;\n }\n const quotedIndexName = this.dialect.quoteIdentifier(indexName);\n return `DROP INDEX IF EXISTS ${quotedIndexName}`;\n }\n\n private createFullTextIndex(table: string, columns: string[], options?: FullTextIndexOptions): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const indexName = options?.name ?? `idx_${table}_fulltext_${columns.join(\"_\")}`;\n const quotedIndexName = this.dialect.quoteIdentifier(indexName);\n const language = options?.language ?? \"english\";\n\n const tsvectors = columns.map((col) => {\n const weight = options?.weights?.[col] ?? \"A\";\n return `setweight(to_tsvector('${language}', COALESCE(${this.dialect.quoteIdentifier(col)}, '')), '${weight}')`;\n });\n\n return `CREATE INDEX ${quotedIndexName} ON ${quotedTable} USING GIN ((${tsvectors.join(\" || \")}))`;\n }\n\n private createGeoIndex(table: string, column: string, options?: GeoIndexOptions): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumn = this.dialect.quoteIdentifier(column);\n const indexName = options?.name ?? `idx_${table}_geo_${column}`;\n const quotedIndexName = this.dialect.quoteIdentifier(indexName);\n\n return `CREATE INDEX ${quotedIndexName} ON ${quotedTable} USING GIST (${quotedColumn})`;\n }\n\n private createVectorIndex(table: string, column: string, options: VectorIndexOptions): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumn = this.dialect.quoteIdentifier(column);\n const indexName = options.name ?? `idx_${table}_vector_${column}`;\n const quotedIndexName = this.dialect.quoteIdentifier(indexName);\n\n const opClass =\n options.similarity === \"euclidean\"\n ? \"vector_l2_ops\"\n : options.similarity === \"dotProduct\"\n ? \"vector_ip_ops\"\n : \"vector_cosine_ops\";\n\n const lists = options.lists ?? 100;\n\n return `CREATE INDEX ${quotedIndexName} ON ${quotedTable} USING ivfflat (${quotedColumn} ${opClass}) WITH (lists = ${lists})`;\n }\n\n private createTTLIndex(table: string, column: string, expireAfterSeconds: number): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumn = this.dialect.quoteIdentifier(column);\n const indexName = `idx_${table}_ttl_${column}`;\n const quotedIndexName = this.dialect.quoteIdentifier(indexName);\n\n return `CREATE INDEX ${quotedIndexName} ON ${quotedTable} (${quotedColumn}) WHERE ${quotedColumn} < NOW() - INTERVAL '${expireAfterSeconds} seconds'`;\n }\n\n // ============================================================================\n // CONSTRAINTS\n // ============================================================================\n\n private addForeignKey(table: string, foreignKey: ForeignKeyDefinition): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumn = this.dialect.quoteIdentifier(foreignKey.column);\n const quotedRefTable = this.dialect.quoteIdentifier(foreignKey.referencesTable);\n const quotedRefColumn = this.dialect.quoteIdentifier(foreignKey.referencesColumn);\n\n const constraintName =\n foreignKey.name ?? `fk_${table}_${foreignKey.column}_${foreignKey.referencesTable}`;\n const quotedConstraint = this.dialect.quoteIdentifier(constraintName);\n\n let sql = `ALTER TABLE ${quotedTable} ADD CONSTRAINT ${quotedConstraint} FOREIGN KEY (${quotedColumn}) REFERENCES ${quotedRefTable} (${quotedRefColumn})`;\n\n if (foreignKey.onDelete) {\n sql += ` ON DELETE ${this.mapForeignKeyAction(foreignKey.onDelete)}`;\n }\n\n if (foreignKey.onUpdate) {\n sql += ` ON UPDATE ${this.mapForeignKeyAction(foreignKey.onUpdate)}`;\n }\n\n return sql;\n }\n\n private dropForeignKey(table: string, name: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedConstraint = this.dialect.quoteIdentifier(name);\n return `ALTER TABLE ${quotedTable} DROP CONSTRAINT ${quotedConstraint}`;\n }\n\n private addPrimaryKey(table: string, columns: string[]): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const quotedColumns = columns.map((c) => this.dialect.quoteIdentifier(c)).join(\", \");\n const constraintName = `pk_${table}`;\n const quotedConstraint = this.dialect.quoteIdentifier(constraintName);\n\n return `ALTER TABLE ${quotedTable} ADD CONSTRAINT ${quotedConstraint} PRIMARY KEY (${quotedColumns})`;\n }\n\n private dropPrimaryKey(table: string): string {\n const quotedTable = this.dialect.quoteIdentifier(table);\n const constraintName = `pk_${table}`;\n const quotedConstraint = this.dialect.quoteIdentifier(constraintName);\n\n return `ALTER TABLE ${quotedTable} DROP CONSTRAINT ${quotedConstraint}`;\n }\n\n private mapForeignKeyAction(\n action: \"cascade\" | \"restrict\" | \"setNull\" | \"noAction\",\n ): string {\n switch (action) {\n case \"cascade\": return \"CASCADE\";\n case \"restrict\": return \"RESTRICT\";\n case \"setNull\": return \"SET NULL\";\n case \"noAction\": return \"NO ACTION\";\n default: return \"NO ACTION\";\n }\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { SyncAdapterContract, SyncInstruction } from "../../contracts/sync-adapter.contract.mjs";
|
|
2
|
+
import { PostgresDriver } from "./postgres-driver.mjs";
|
|
3
|
+
|
|
4
|
+
//#region ../../@warlock.js/cascade/src/drivers/postgres/postgres-sync-adapter.d.ts
|
|
5
|
+
/**
|
|
6
|
+
* PostgreSQL Sync Adapter.
|
|
7
|
+
*
|
|
8
|
+
* Handles batch updates for embedded/denormalized data stored
|
|
9
|
+
* in JSONB columns. In a normalized SQL world, this is less common
|
|
10
|
+
* than in MongoDB, but still useful for JSONB documents.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```typescript
|
|
14
|
+
* const syncAdapter = driver.syncAdapter();
|
|
15
|
+
*
|
|
16
|
+
* // Update embedded user data in posts
|
|
17
|
+
* await syncAdapter.executeBatch([
|
|
18
|
+
* {
|
|
19
|
+
* targetTable: 'posts',
|
|
20
|
+
* filter: { 'author.id': 123 },
|
|
21
|
+
* update: { 'author.name': 'New Name' },
|
|
22
|
+
* // ... other fields
|
|
23
|
+
* }
|
|
24
|
+
* ]);
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
declare class PostgresSyncAdapter implements SyncAdapterContract {
|
|
28
|
+
private readonly driver;
|
|
29
|
+
/**
|
|
30
|
+
* Create a new sync adapter.
|
|
31
|
+
*
|
|
32
|
+
* @param driver - The PostgreSQL driver instance
|
|
33
|
+
*/
|
|
34
|
+
constructor(driver: PostgresDriver);
|
|
35
|
+
/**
|
|
36
|
+
* Execute a batch of sync instructions.
|
|
37
|
+
*
|
|
38
|
+
* @param instructions - Array of sync instructions
|
|
39
|
+
* @returns Total number of affected rows
|
|
40
|
+
*/
|
|
41
|
+
executeBatch(instructions: SyncInstruction[]): Promise<number>;
|
|
42
|
+
/**
|
|
43
|
+
* Execute a single sync instruction.
|
|
44
|
+
*
|
|
45
|
+
* @param instruction - Sync instruction
|
|
46
|
+
* @returns Number of affected rows
|
|
47
|
+
*/
|
|
48
|
+
executeOne(instruction: SyncInstruction): Promise<number>;
|
|
49
|
+
/**
|
|
50
|
+
* Execute an array update instruction with positional operators.
|
|
51
|
+
*
|
|
52
|
+
* @param instruction - Sync instruction with array update info
|
|
53
|
+
* @returns Number of affected rows
|
|
54
|
+
*/
|
|
55
|
+
executeArrayUpdate(instruction: SyncInstruction): Promise<number>;
|
|
56
|
+
/**
|
|
57
|
+
* Execute an update on JSONB fields.
|
|
58
|
+
*
|
|
59
|
+
* @param table - Table name
|
|
60
|
+
* @param filter - Row filter
|
|
61
|
+
* @param update - Fields to update
|
|
62
|
+
* @returns Number of affected rows
|
|
63
|
+
*/
|
|
64
|
+
private executeJsonbUpdate;
|
|
65
|
+
/**
|
|
66
|
+
* Execute an update on elements within a JSONB array.
|
|
67
|
+
*
|
|
68
|
+
* @param table - Table name
|
|
69
|
+
* @param filter - Row filter
|
|
70
|
+
* @param arrayField - JSONB array column
|
|
71
|
+
* @param arrayFilter - Filter to match array elements
|
|
72
|
+
* @param update - Fields to update on matched elements
|
|
73
|
+
* @returns Number of affected rows
|
|
74
|
+
*/
|
|
75
|
+
private executeArrayElementUpdate;
|
|
76
|
+
}
|
|
77
|
+
//#endregion
|
|
78
|
+
export { PostgresSyncAdapter };
|
|
79
|
+
//# sourceMappingURL=postgres-sync-adapter.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-sync-adapter.d.mts","names":[],"sources":["../../../../../../../@warlock.js/cascade/src/drivers/postgres/postgres-sync-adapter.ts"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;cAkCa,mBAAA,YAA+B,mBAAA;EAAA,iBAMN,MAAA;EAiEtB;;;AA2EyB;;cA5IH,MAAA,EAAQ,cAAA;;;;;;;EAQ/B,YAAA,CAAa,YAAA,EAAc,eAAA,KAAoB,OAAA;;;;;;;EAoB/C,UAAA,CAAW,WAAA,EAAa,eAAA,GAAkB,OAAA;;;;;;;EAW1C,kBAAA,CAAmB,WAAA,EAAa,eAAA,GAAkB,OAAA;;;;;;;;;UA0BjD,kBAAA;;;;;;;;;;;UA2EA,yBAAA;AAAA"}
|