@warlock.js/cascade 4.0.92 → 4.0.93
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/cjs/contracts/database-driver.contract.d.ts +118 -0
- package/cjs/contracts/database-driver.contract.d.ts.map +1 -1
- package/cjs/contracts/migration-driver.contract.d.ts +14 -0
- package/cjs/contracts/migration-driver.contract.d.ts.map +1 -1
- package/cjs/contracts/query-builder.contract.d.ts +410 -1
- package/cjs/contracts/query-builder.contract.d.ts.map +1 -1
- package/cjs/data-source/data-source-registry.d.ts +4 -0
- package/cjs/data-source/data-source-registry.d.ts.map +1 -1
- package/cjs/data-source/data-source-registry.js +7 -0
- package/cjs/data-source/data-source-registry.js.map +1 -1
- package/cjs/drivers/mongodb/mongodb-blueprint.d.ts.map +1 -0
- package/cjs/drivers/mongodb/mongodb-blueprint.js.map +1 -0
- package/{esm/drivers/mongo → cjs/drivers/mongodb}/mongodb-driver.d.ts +49 -0
- package/cjs/drivers/mongodb/mongodb-driver.d.ts.map +1 -0
- package/cjs/drivers/{mongo → mongodb}/mongodb-driver.js +125 -8
- package/cjs/drivers/mongodb/mongodb-driver.js.map +1 -0
- package/cjs/drivers/{mongo/mongo-id-generator.d.ts → mongodb/mongodb-id-generator.d.ts} +1 -1
- package/cjs/drivers/mongodb/mongodb-id-generator.d.ts.map +1 -0
- package/cjs/drivers/{mongo/mongo-id-generator.js → mongodb/mongodb-id-generator.js} +1 -1
- package/cjs/drivers/mongodb/mongodb-id-generator.js.map +1 -0
- package/cjs/drivers/{mongo/mongo-migration-driver.d.ts → mongodb/mongodb-migration-driver.d.ts} +10 -1
- package/cjs/drivers/mongodb/mongodb-migration-driver.d.ts.map +1 -0
- package/cjs/drivers/{mongo/mongo-migration-driver.js → mongodb/mongodb-migration-driver.js} +18 -1
- package/cjs/drivers/mongodb/mongodb-migration-driver.js.map +1 -0
- package/cjs/drivers/{mongo/mongo-query-builder.d.ts → mongodb/mongodb-query-builder.d.ts} +172 -4
- package/cjs/drivers/mongodb/mongodb-query-builder.d.ts.map +1 -0
- package/cjs/drivers/{mongo/mongo-query-builder.js → mongodb/mongodb-query-builder.js} +220 -14
- package/cjs/drivers/mongodb/mongodb-query-builder.js.map +1 -0
- package/{esm/drivers/mongo/mongo-query-operations.d.ts → cjs/drivers/mongodb/mongodb-query-operations.d.ts} +16 -16
- package/cjs/drivers/mongodb/mongodb-query-operations.d.ts.map +1 -0
- package/cjs/drivers/{mongo/mongo-query-operations.js → mongodb/mongodb-query-operations.js} +22 -22
- package/cjs/drivers/mongodb/mongodb-query-operations.js.map +1 -0
- package/cjs/drivers/{mongo/mongo-query-parser.d.ts → mongodb/mongodb-query-parser.d.ts} +2 -2
- package/cjs/drivers/mongodb/mongodb-query-parser.d.ts.map +1 -0
- package/cjs/drivers/{mongo/mongo-query-parser.js → mongodb/mongodb-query-parser.js} +87 -87
- package/cjs/drivers/mongodb/mongodb-query-parser.js.map +1 -0
- package/cjs/drivers/{mongo/mongo-sync-adapter.d.ts → mongodb/mongodb-sync-adapter.d.ts} +2 -2
- package/cjs/drivers/mongodb/mongodb-sync-adapter.d.ts.map +1 -0
- package/cjs/drivers/{mongo/mongo-sync-adapter.js → mongodb/mongodb-sync-adapter.js} +2 -2
- package/cjs/drivers/mongodb/mongodb-sync-adapter.js.map +1 -0
- package/{esm/drivers/mongo → cjs/drivers/mongodb}/types.d.ts +2 -2
- package/cjs/drivers/mongodb/types.d.ts.map +1 -0
- package/cjs/drivers/postgres/index.d.ts +16 -0
- package/cjs/drivers/postgres/index.d.ts.map +1 -0
- package/cjs/drivers/postgres/postgres-blueprint.d.ts +64 -0
- package/cjs/drivers/postgres/postgres-blueprint.d.ts.map +1 -0
- package/cjs/drivers/postgres/postgres-blueprint.js +121 -0
- package/cjs/drivers/postgres/postgres-blueprint.js.map +1 -0
- package/cjs/drivers/postgres/postgres-dialect.d.ts +135 -0
- package/cjs/drivers/postgres/postgres-dialect.d.ts.map +1 -0
- package/cjs/drivers/postgres/postgres-dialect.js +245 -0
- package/cjs/drivers/postgres/postgres-dialect.js.map +1 -0
- package/cjs/drivers/postgres/postgres-driver.d.ts +360 -0
- package/cjs/drivers/postgres/postgres-driver.d.ts.map +1 -0
- package/cjs/drivers/postgres/postgres-driver.js +763 -0
- package/cjs/drivers/postgres/postgres-driver.js.map +1 -0
- package/cjs/drivers/postgres/postgres-migration-driver.d.ts +297 -0
- package/cjs/drivers/postgres/postgres-migration-driver.d.ts.map +1 -0
- package/cjs/drivers/postgres/postgres-migration-driver.js +578 -0
- package/cjs/drivers/postgres/postgres-migration-driver.js.map +1 -0
- package/cjs/drivers/postgres/postgres-query-builder.d.ts +824 -0
- package/cjs/drivers/postgres/postgres-query-builder.d.ts.map +1 -0
- package/cjs/drivers/postgres/postgres-query-builder.js +1800 -0
- package/cjs/drivers/postgres/postgres-query-builder.js.map +1 -0
- package/cjs/drivers/postgres/postgres-query-parser.d.ts +308 -0
- package/cjs/drivers/postgres/postgres-query-parser.d.ts.map +1 -0
- package/cjs/drivers/postgres/postgres-query-parser.js +706 -0
- package/cjs/drivers/postgres/postgres-query-parser.js.map +1 -0
- package/cjs/drivers/postgres/postgres-sync-adapter.d.ts +83 -0
- package/cjs/drivers/postgres/postgres-sync-adapter.d.ts.map +1 -0
- package/cjs/drivers/postgres/postgres-sync-adapter.js +197 -0
- package/cjs/drivers/postgres/postgres-sync-adapter.js.map +1 -0
- package/cjs/drivers/postgres/types.d.ts +142 -0
- package/cjs/drivers/postgres/types.d.ts.map +1 -0
- package/cjs/drivers/sql/index.d.ts +10 -0
- package/cjs/drivers/sql/index.d.ts.map +1 -0
- package/cjs/drivers/sql/sql-dialect.contract.d.ts +203 -0
- package/cjs/drivers/sql/sql-dialect.contract.d.ts.map +1 -0
- package/cjs/drivers/sql/sql-types.d.ts +202 -0
- package/cjs/drivers/sql/sql-types.d.ts.map +1 -0
- package/cjs/index.d.ts +9 -6
- package/cjs/index.d.ts.map +1 -1
- package/cjs/index.js +1 -1
- package/cjs/migration/migration-runner.d.ts.map +1 -1
- package/cjs/migration/migration-runner.js +3 -0
- package/cjs/migration/migration-runner.js.map +1 -1
- package/cjs/model/model.d.ts +236 -1
- package/cjs/model/model.d.ts.map +1 -1
- package/cjs/model/model.js +203 -4
- package/cjs/model/model.js.map +1 -1
- package/cjs/relations/helpers.d.ts +156 -0
- package/cjs/relations/helpers.d.ts.map +1 -0
- package/cjs/relations/helpers.js +197 -0
- package/cjs/relations/helpers.js.map +1 -0
- package/cjs/relations/index.d.ts +33 -0
- package/cjs/relations/index.d.ts.map +1 -0
- package/cjs/relations/pivot-operations.d.ts +160 -0
- package/cjs/relations/pivot-operations.d.ts.map +1 -0
- package/cjs/relations/pivot-operations.js +293 -0
- package/cjs/relations/pivot-operations.js.map +1 -0
- package/cjs/relations/relation-loader.d.ts +194 -0
- package/cjs/relations/relation-loader.d.ts.map +1 -0
- package/cjs/relations/relation-loader.js +466 -0
- package/cjs/relations/relation-loader.js.map +1 -0
- package/cjs/relations/types.d.ts +280 -0
- package/cjs/relations/types.d.ts.map +1 -0
- package/cjs/sync/model-sync-operation.js +1 -1
- package/cjs/sync/model-sync-operation.js.map +1 -1
- package/cjs/utils/connect-to-database.d.ts.map +1 -1
- package/cjs/utils/connect-to-database.js +15 -3
- package/cjs/utils/connect-to-database.js.map +1 -1
- package/cjs/utils/define-model.d.ts +51 -29
- package/cjs/utils/define-model.d.ts.map +1 -1
- package/cjs/validation/rules/database-model-rule.js +1 -1
- package/cjs/validation/rules/database-model-rule.js.map +1 -1
- package/esm/contracts/database-driver.contract.d.ts +118 -0
- package/esm/contracts/database-driver.contract.d.ts.map +1 -1
- package/esm/contracts/migration-driver.contract.d.ts +14 -0
- package/esm/contracts/migration-driver.contract.d.ts.map +1 -1
- package/esm/contracts/query-builder.contract.d.ts +410 -1
- package/esm/contracts/query-builder.contract.d.ts.map +1 -1
- package/esm/data-source/data-source-registry.d.ts +4 -0
- package/esm/data-source/data-source-registry.d.ts.map +1 -1
- package/esm/data-source/data-source-registry.js +7 -0
- package/esm/data-source/data-source-registry.js.map +1 -1
- package/esm/drivers/mongodb/mongodb-blueprint.d.ts.map +1 -0
- package/esm/drivers/mongodb/mongodb-blueprint.js.map +1 -0
- package/{cjs/drivers/mongo → esm/drivers/mongodb}/mongodb-driver.d.ts +49 -0
- package/esm/drivers/mongodb/mongodb-driver.d.ts.map +1 -0
- package/esm/drivers/{mongo → mongodb}/mongodb-driver.js +121 -4
- package/esm/drivers/mongodb/mongodb-driver.js.map +1 -0
- package/esm/drivers/{mongo/mongo-id-generator.d.ts → mongodb/mongodb-id-generator.d.ts} +1 -1
- package/esm/drivers/mongodb/mongodb-id-generator.d.ts.map +1 -0
- package/esm/drivers/{mongo/mongo-id-generator.js → mongodb/mongodb-id-generator.js} +1 -1
- package/esm/drivers/mongodb/mongodb-id-generator.js.map +1 -0
- package/esm/drivers/{mongo/mongo-migration-driver.d.ts → mongodb/mongodb-migration-driver.d.ts} +10 -1
- package/esm/drivers/mongodb/mongodb-migration-driver.d.ts.map +1 -0
- package/esm/drivers/{mongo/mongo-migration-driver.js → mongodb/mongodb-migration-driver.js} +18 -1
- package/esm/drivers/mongodb/mongodb-migration-driver.js.map +1 -0
- package/esm/drivers/{mongo/mongo-query-builder.d.ts → mongodb/mongodb-query-builder.d.ts} +172 -4
- package/esm/drivers/mongodb/mongodb-query-builder.d.ts.map +1 -0
- package/esm/drivers/{mongo/mongo-query-builder.js → mongodb/mongodb-query-builder.js} +218 -12
- package/esm/drivers/mongodb/mongodb-query-builder.js.map +1 -0
- package/{cjs/drivers/mongo/mongo-query-operations.d.ts → esm/drivers/mongodb/mongodb-query-operations.d.ts} +16 -16
- package/esm/drivers/mongodb/mongodb-query-operations.d.ts.map +1 -0
- package/esm/drivers/{mongo/mongo-query-operations.js → mongodb/mongodb-query-operations.js} +22 -22
- package/esm/drivers/mongodb/mongodb-query-operations.js.map +1 -0
- package/esm/drivers/{mongo/mongo-query-parser.d.ts → mongodb/mongodb-query-parser.d.ts} +2 -2
- package/esm/drivers/mongodb/mongodb-query-parser.d.ts.map +1 -0
- package/esm/drivers/{mongo/mongo-query-parser.js → mongodb/mongodb-query-parser.js} +87 -87
- package/esm/drivers/mongodb/mongodb-query-parser.js.map +1 -0
- package/esm/drivers/{mongo/mongo-sync-adapter.d.ts → mongodb/mongodb-sync-adapter.d.ts} +2 -2
- package/esm/drivers/mongodb/mongodb-sync-adapter.d.ts.map +1 -0
- package/esm/drivers/{mongo/mongo-sync-adapter.js → mongodb/mongodb-sync-adapter.js} +2 -2
- package/esm/drivers/mongodb/mongodb-sync-adapter.js.map +1 -0
- package/{cjs/drivers/mongo → esm/drivers/mongodb}/types.d.ts +2 -2
- package/esm/drivers/mongodb/types.d.ts.map +1 -0
- package/esm/drivers/postgres/index.d.ts +16 -0
- package/esm/drivers/postgres/index.d.ts.map +1 -0
- package/esm/drivers/postgres/postgres-blueprint.d.ts +64 -0
- package/esm/drivers/postgres/postgres-blueprint.d.ts.map +1 -0
- package/esm/drivers/postgres/postgres-blueprint.js +121 -0
- package/esm/drivers/postgres/postgres-blueprint.js.map +1 -0
- package/esm/drivers/postgres/postgres-dialect.d.ts +135 -0
- package/esm/drivers/postgres/postgres-dialect.d.ts.map +1 -0
- package/esm/drivers/postgres/postgres-dialect.js +245 -0
- package/esm/drivers/postgres/postgres-dialect.js.map +1 -0
- package/esm/drivers/postgres/postgres-driver.d.ts +360 -0
- package/esm/drivers/postgres/postgres-driver.d.ts.map +1 -0
- package/esm/drivers/postgres/postgres-driver.js +763 -0
- package/esm/drivers/postgres/postgres-driver.js.map +1 -0
- package/esm/drivers/postgres/postgres-migration-driver.d.ts +297 -0
- package/esm/drivers/postgres/postgres-migration-driver.d.ts.map +1 -0
- package/esm/drivers/postgres/postgres-migration-driver.js +578 -0
- package/esm/drivers/postgres/postgres-migration-driver.js.map +1 -0
- package/esm/drivers/postgres/postgres-query-builder.d.ts +824 -0
- package/esm/drivers/postgres/postgres-query-builder.d.ts.map +1 -0
- package/esm/drivers/postgres/postgres-query-builder.js +1800 -0
- package/esm/drivers/postgres/postgres-query-builder.js.map +1 -0
- package/esm/drivers/postgres/postgres-query-parser.d.ts +308 -0
- package/esm/drivers/postgres/postgres-query-parser.d.ts.map +1 -0
- package/esm/drivers/postgres/postgres-query-parser.js +706 -0
- package/esm/drivers/postgres/postgres-query-parser.js.map +1 -0
- package/esm/drivers/postgres/postgres-sync-adapter.d.ts +83 -0
- package/esm/drivers/postgres/postgres-sync-adapter.d.ts.map +1 -0
- package/esm/drivers/postgres/postgres-sync-adapter.js +197 -0
- package/esm/drivers/postgres/postgres-sync-adapter.js.map +1 -0
- package/esm/drivers/postgres/types.d.ts +142 -0
- package/esm/drivers/postgres/types.d.ts.map +1 -0
- package/esm/drivers/sql/index.d.ts +10 -0
- package/esm/drivers/sql/index.d.ts.map +1 -0
- package/esm/drivers/sql/sql-dialect.contract.d.ts +203 -0
- package/esm/drivers/sql/sql-dialect.contract.d.ts.map +1 -0
- package/esm/drivers/sql/sql-types.d.ts +202 -0
- package/esm/drivers/sql/sql-types.d.ts.map +1 -0
- package/esm/index.d.ts +9 -6
- package/esm/index.d.ts.map +1 -1
- package/esm/index.js +1 -1
- package/esm/migration/migration-runner.d.ts.map +1 -1
- package/esm/migration/migration-runner.js +3 -0
- package/esm/migration/migration-runner.js.map +1 -1
- package/esm/model/model.d.ts +236 -1
- package/esm/model/model.d.ts.map +1 -1
- package/esm/model/model.js +203 -4
- package/esm/model/model.js.map +1 -1
- package/esm/relations/helpers.d.ts +156 -0
- package/esm/relations/helpers.d.ts.map +1 -0
- package/esm/relations/helpers.js +197 -0
- package/esm/relations/helpers.js.map +1 -0
- package/esm/relations/index.d.ts +33 -0
- package/esm/relations/index.d.ts.map +1 -0
- package/esm/relations/pivot-operations.d.ts +160 -0
- package/esm/relations/pivot-operations.d.ts.map +1 -0
- package/esm/relations/pivot-operations.js +293 -0
- package/esm/relations/pivot-operations.js.map +1 -0
- package/esm/relations/relation-loader.d.ts +194 -0
- package/esm/relations/relation-loader.d.ts.map +1 -0
- package/esm/relations/relation-loader.js +466 -0
- package/esm/relations/relation-loader.js.map +1 -0
- package/esm/relations/types.d.ts +280 -0
- package/esm/relations/types.d.ts.map +1 -0
- package/esm/sync/model-sync-operation.js +1 -1
- package/esm/sync/model-sync-operation.js.map +1 -1
- package/esm/utils/connect-to-database.d.ts.map +1 -1
- package/esm/utils/connect-to-database.js +15 -3
- package/esm/utils/connect-to-database.js.map +1 -1
- package/esm/utils/define-model.d.ts +51 -29
- package/esm/utils/define-model.d.ts.map +1 -1
- package/esm/validation/rules/database-model-rule.js +1 -1
- package/esm/validation/rules/database-model-rule.js.map +1 -1
- package/package.json +4 -4
- package/cjs/drivers/mongo/mongo-id-generator.d.ts.map +0 -1
- package/cjs/drivers/mongo/mongo-id-generator.js.map +0 -1
- package/cjs/drivers/mongo/mongo-migration-driver.d.ts.map +0 -1
- package/cjs/drivers/mongo/mongo-migration-driver.js.map +0 -1
- package/cjs/drivers/mongo/mongo-query-builder.d.ts.map +0 -1
- package/cjs/drivers/mongo/mongo-query-builder.js.map +0 -1
- package/cjs/drivers/mongo/mongo-query-operations.d.ts.map +0 -1
- package/cjs/drivers/mongo/mongo-query-operations.js.map +0 -1
- package/cjs/drivers/mongo/mongo-query-parser.d.ts.map +0 -1
- package/cjs/drivers/mongo/mongo-query-parser.js.map +0 -1
- package/cjs/drivers/mongo/mongo-sync-adapter.d.ts.map +0 -1
- package/cjs/drivers/mongo/mongo-sync-adapter.js.map +0 -1
- package/cjs/drivers/mongo/mongodb-blueprint.d.ts.map +0 -1
- package/cjs/drivers/mongo/mongodb-blueprint.js.map +0 -1
- package/cjs/drivers/mongo/mongodb-driver.d.ts.map +0 -1
- package/cjs/drivers/mongo/mongodb-driver.js.map +0 -1
- package/cjs/drivers/mongo/types.d.ts.map +0 -1
- package/esm/drivers/mongo/mongo-id-generator.d.ts.map +0 -1
- package/esm/drivers/mongo/mongo-id-generator.js.map +0 -1
- package/esm/drivers/mongo/mongo-migration-driver.d.ts.map +0 -1
- package/esm/drivers/mongo/mongo-migration-driver.js.map +0 -1
- package/esm/drivers/mongo/mongo-query-builder.d.ts.map +0 -1
- package/esm/drivers/mongo/mongo-query-builder.js.map +0 -1
- package/esm/drivers/mongo/mongo-query-operations.d.ts.map +0 -1
- package/esm/drivers/mongo/mongo-query-operations.js.map +0 -1
- package/esm/drivers/mongo/mongo-query-parser.d.ts.map +0 -1
- package/esm/drivers/mongo/mongo-query-parser.js.map +0 -1
- package/esm/drivers/mongo/mongo-sync-adapter.d.ts.map +0 -1
- package/esm/drivers/mongo/mongo-sync-adapter.js.map +0 -1
- package/esm/drivers/mongo/mongodb-blueprint.d.ts.map +0 -1
- package/esm/drivers/mongo/mongodb-blueprint.js.map +0 -1
- package/esm/drivers/mongo/mongodb-driver.d.ts.map +0 -1
- package/esm/drivers/mongo/mongodb-driver.js.map +0 -1
- package/esm/drivers/mongo/types.d.ts.map +0 -1
- /package/cjs/drivers/{mongo → mongodb}/mongodb-blueprint.d.ts +0 -0
- /package/cjs/drivers/{mongo → mongodb}/mongodb-blueprint.js +0 -0
- /package/esm/drivers/{mongo → mongodb}/mongodb-blueprint.d.ts +0 -0
- /package/esm/drivers/{mongo → mongodb}/mongodb-blueprint.js +0 -0
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL Blueprint
|
|
3
|
+
*
|
|
4
|
+
* Implements the DriverBlueprintContract for querying PostgreSQL
|
|
5
|
+
* information schema metadata.
|
|
6
|
+
*
|
|
7
|
+
* @module cascade/drivers/postgres
|
|
8
|
+
*/
|
|
9
|
+
import type { DriverBlueprintContract, TableIndexInformation } from "../../contracts/driver-blueprint.contract";
|
|
10
|
+
import type { PostgresDriver } from "./postgres-driver";
|
|
11
|
+
/**
|
|
12
|
+
* PostgreSQL Blueprint.
|
|
13
|
+
*
|
|
14
|
+
* Provides methods for introspecting the database schema
|
|
15
|
+
* via PostgreSQL's information_schema and pg_catalog.
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* ```typescript
|
|
19
|
+
* const blueprint = driver.blueprint;
|
|
20
|
+
*
|
|
21
|
+
* // Get all tables
|
|
22
|
+
* const tables = await blueprint.listTables();
|
|
23
|
+
*
|
|
24
|
+
* // Get columns for a table
|
|
25
|
+
* const columns = await blueprint.listColumns('users');
|
|
26
|
+
* ```
|
|
27
|
+
*/
|
|
28
|
+
export declare class PostgresBlueprint implements DriverBlueprintContract {
|
|
29
|
+
private readonly driver;
|
|
30
|
+
/**
|
|
31
|
+
* Create a new blueprint.
|
|
32
|
+
*
|
|
33
|
+
* @param driver - The PostgreSQL driver instance
|
|
34
|
+
*/
|
|
35
|
+
constructor(driver: PostgresDriver);
|
|
36
|
+
/**
|
|
37
|
+
* Get all table names in the database.
|
|
38
|
+
*
|
|
39
|
+
* @returns Array of table names
|
|
40
|
+
*/
|
|
41
|
+
listTables(): Promise<string[]>;
|
|
42
|
+
/**
|
|
43
|
+
* Get all indexes for a table.
|
|
44
|
+
*
|
|
45
|
+
* @param table - Table name
|
|
46
|
+
* @returns Array of index information
|
|
47
|
+
*/
|
|
48
|
+
listIndexes(table: string): Promise<TableIndexInformation[]>;
|
|
49
|
+
/**
|
|
50
|
+
* Get all column names for a table.
|
|
51
|
+
*
|
|
52
|
+
* @param table - Table name
|
|
53
|
+
* @returns Array of column names
|
|
54
|
+
*/
|
|
55
|
+
listColumns(table: string): Promise<string[]>;
|
|
56
|
+
/**
|
|
57
|
+
* Check if a table exists.
|
|
58
|
+
*
|
|
59
|
+
* @param table - Table name
|
|
60
|
+
* @returns Whether the table exists
|
|
61
|
+
*/
|
|
62
|
+
tableExists(table: string): Promise<boolean>;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=postgres-blueprint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-blueprint.d.ts","sourceRoot":"","sources":["../../../src/drivers/postgres/postgres-blueprint.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EACV,uBAAuB,EACvB,qBAAqB,EACtB,MAAM,2CAA2C,CAAC;AACnD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD;;;;;;;;;;;;;;;;GAgBG;AACH,qBAAa,iBAAkB,YAAW,uBAAuB;IAM5C,OAAO,CAAC,QAAQ,CAAC,MAAM;IAL1C;;;;OAIG;gBACiC,MAAM,EAAE,cAAc;IAE1D;;;;OAIG;IACU,UAAU,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAY5C;;;;;OAKG;IACU,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC;IA8CzE;;;;;OAKG;IACU,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAa1D;;;;;OAKG;IACU,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;CAY1D"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL Blueprint
|
|
3
|
+
*
|
|
4
|
+
* Implements the DriverBlueprintContract for querying PostgreSQL
|
|
5
|
+
* information schema metadata.
|
|
6
|
+
*
|
|
7
|
+
* @module cascade/drivers/postgres
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* PostgreSQL Blueprint.
|
|
11
|
+
*
|
|
12
|
+
* Provides methods for introspecting the database schema
|
|
13
|
+
* via PostgreSQL's information_schema and pg_catalog.
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```typescript
|
|
17
|
+
* const blueprint = driver.blueprint;
|
|
18
|
+
*
|
|
19
|
+
* // Get all tables
|
|
20
|
+
* const tables = await blueprint.listTables();
|
|
21
|
+
*
|
|
22
|
+
* // Get columns for a table
|
|
23
|
+
* const columns = await blueprint.listColumns('users');
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
class PostgresBlueprint {
|
|
27
|
+
driver;
|
|
28
|
+
/**
|
|
29
|
+
* Create a new blueprint.
|
|
30
|
+
*
|
|
31
|
+
* @param driver - The PostgreSQL driver instance
|
|
32
|
+
*/
|
|
33
|
+
constructor(driver) {
|
|
34
|
+
this.driver = driver;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Get all table names in the database.
|
|
38
|
+
*
|
|
39
|
+
* @returns Array of table names
|
|
40
|
+
*/
|
|
41
|
+
async listTables() {
|
|
42
|
+
const result = await this.driver.query(`SELECT table_name
|
|
43
|
+
FROM information_schema.tables
|
|
44
|
+
WHERE table_schema = 'public'
|
|
45
|
+
AND table_type = 'BASE TABLE'
|
|
46
|
+
ORDER BY table_name`);
|
|
47
|
+
return result.rows.map((row) => row.table_name);
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Get all indexes for a table.
|
|
51
|
+
*
|
|
52
|
+
* @param table - Table name
|
|
53
|
+
* @returns Array of index information
|
|
54
|
+
*/
|
|
55
|
+
async listIndexes(table) {
|
|
56
|
+
const result = await this.driver.query(`SELECT indexname, indexdef
|
|
57
|
+
FROM pg_indexes
|
|
58
|
+
WHERE schemaname = 'public'
|
|
59
|
+
AND tablename = $1`, [table]);
|
|
60
|
+
return result.rows.map((row) => {
|
|
61
|
+
const isUnique = row.indexdef.includes("UNIQUE");
|
|
62
|
+
const isPrimary = row.indexname.endsWith("_pkey");
|
|
63
|
+
// Extract columns from indexdef
|
|
64
|
+
const columnsMatch = row.indexdef.match(/\(([^)]+)\)/);
|
|
65
|
+
const columns = columnsMatch
|
|
66
|
+
? columnsMatch[1].split(",").map((c) => c.trim().replace(/"/g, ""))
|
|
67
|
+
: [];
|
|
68
|
+
// Determine index type
|
|
69
|
+
let type = "btree"; // default
|
|
70
|
+
if (row.indexdef.includes("USING GIN"))
|
|
71
|
+
type = "gin";
|
|
72
|
+
else if (row.indexdef.includes("USING GIST"))
|
|
73
|
+
type = "gist";
|
|
74
|
+
else if (row.indexdef.includes("USING HASH"))
|
|
75
|
+
type = "hash";
|
|
76
|
+
else if (row.indexdef.includes("USING ivfflat"))
|
|
77
|
+
type = "ivfflat";
|
|
78
|
+
// Check for partial index
|
|
79
|
+
const isPartial = row.indexdef.includes("WHERE");
|
|
80
|
+
return {
|
|
81
|
+
name: row.indexname,
|
|
82
|
+
columns,
|
|
83
|
+
type,
|
|
84
|
+
unique: isUnique || isPrimary,
|
|
85
|
+
partial: isPartial,
|
|
86
|
+
options: {
|
|
87
|
+
primary: isPrimary,
|
|
88
|
+
definition: row.indexdef,
|
|
89
|
+
},
|
|
90
|
+
};
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Get all column names for a table.
|
|
95
|
+
*
|
|
96
|
+
* @param table - Table name
|
|
97
|
+
* @returns Array of column names
|
|
98
|
+
*/
|
|
99
|
+
async listColumns(table) {
|
|
100
|
+
const result = await this.driver.query(`SELECT column_name
|
|
101
|
+
FROM information_schema.columns
|
|
102
|
+
WHERE table_schema = 'public'
|
|
103
|
+
AND table_name = $1
|
|
104
|
+
ORDER BY ordinal_position`, [table]);
|
|
105
|
+
return result.rows.map((row) => row.column_name);
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Check if a table exists.
|
|
109
|
+
*
|
|
110
|
+
* @param table - Table name
|
|
111
|
+
* @returns Whether the table exists
|
|
112
|
+
*/
|
|
113
|
+
async tableExists(table) {
|
|
114
|
+
const result = await this.driver.query(`SELECT EXISTS (
|
|
115
|
+
SELECT FROM information_schema.tables
|
|
116
|
+
WHERE table_schema = 'public'
|
|
117
|
+
AND table_name = $1
|
|
118
|
+
)`, [table]);
|
|
119
|
+
return result.rows[0]?.exists ?? false;
|
|
120
|
+
}
|
|
121
|
+
}export{PostgresBlueprint};//# sourceMappingURL=postgres-blueprint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-blueprint.js","sources":["../../../src/drivers/postgres/postgres-blueprint.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL Dialect Implementation
|
|
3
|
+
*
|
|
4
|
+
* Implements the SqlDialectContract for PostgreSQL-specific SQL syntax.
|
|
5
|
+
* Handles parameter placeholders ($1, $2), identifier quoting, and
|
|
6
|
+
* PostgreSQL-specific features like JSONB operators.
|
|
7
|
+
*
|
|
8
|
+
* @module cascade/drivers/postgres
|
|
9
|
+
*/
|
|
10
|
+
import type { SqlDialectContract } from "../sql/sql-dialect.contract";
|
|
11
|
+
/**
|
|
12
|
+
* PostgreSQL-specific SQL dialect implementation.
|
|
13
|
+
*
|
|
14
|
+
* Provides PostgreSQL syntax for:
|
|
15
|
+
* - Parameter placeholders ($1, $2, $3...)
|
|
16
|
+
* - Identifier quoting with double quotes
|
|
17
|
+
* - JSONB operators (->, ->>, @>)
|
|
18
|
+
* - ILIKE for case-insensitive matching
|
|
19
|
+
* - RETURNING clause support
|
|
20
|
+
*
|
|
21
|
+
* @example
|
|
22
|
+
* ```typescript
|
|
23
|
+
* const dialect = new PostgresDialect();
|
|
24
|
+
*
|
|
25
|
+
* dialect.placeholder(1); // "$1"
|
|
26
|
+
* dialect.quoteIdentifier('user'); // '"user"'
|
|
27
|
+
* dialect.jsonExtract('data', 'name'); // "data"->>'name'
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
export declare class PostgresDialect implements SqlDialectContract {
|
|
31
|
+
/**
|
|
32
|
+
* Dialect name identifier.
|
|
33
|
+
*/
|
|
34
|
+
readonly name: "postgres";
|
|
35
|
+
/**
|
|
36
|
+
* PostgreSQL supports the RETURNING clause for INSERT/UPDATE/DELETE.
|
|
37
|
+
*/
|
|
38
|
+
readonly supportsReturning = true;
|
|
39
|
+
/**
|
|
40
|
+
* PostgreSQL uses ON CONFLICT for upsert operations.
|
|
41
|
+
*/
|
|
42
|
+
readonly upsertKeyword: "ON CONFLICT";
|
|
43
|
+
/**
|
|
44
|
+
* Generate a PostgreSQL parameter placeholder.
|
|
45
|
+
*
|
|
46
|
+
* PostgreSQL uses numbered placeholders: $1, $2, $3, etc.
|
|
47
|
+
*
|
|
48
|
+
* @param index - The 1-based parameter index
|
|
49
|
+
* @returns The placeholder string (e.g., "$1")
|
|
50
|
+
*/
|
|
51
|
+
placeholder(index: number): string;
|
|
52
|
+
/**
|
|
53
|
+
* Quote an identifier using PostgreSQL's double-quote syntax.
|
|
54
|
+
*
|
|
55
|
+
* Handles escaping of embedded double quotes by doubling them.
|
|
56
|
+
* This is necessary for reserved words and special characters.
|
|
57
|
+
*
|
|
58
|
+
* @param identifier - The identifier (table/column name) to quote
|
|
59
|
+
* @returns The quoted identifier (e.g., '"user"')
|
|
60
|
+
*/
|
|
61
|
+
quoteIdentifier(identifier: string): string;
|
|
62
|
+
/**
|
|
63
|
+
* Convert a boolean to PostgreSQL literal.
|
|
64
|
+
*
|
|
65
|
+
* @param value - The boolean value
|
|
66
|
+
* @returns "TRUE" or "FALSE"
|
|
67
|
+
*/
|
|
68
|
+
booleanLiteral(value: boolean): string;
|
|
69
|
+
/**
|
|
70
|
+
* Build LIMIT/OFFSET clause for PostgreSQL.
|
|
71
|
+
*
|
|
72
|
+
* @param limit - Maximum rows to return
|
|
73
|
+
* @param offset - Rows to skip
|
|
74
|
+
* @returns The SQL clause (e.g., "LIMIT 10 OFFSET 20")
|
|
75
|
+
*/
|
|
76
|
+
limitOffset(limit?: number, offset?: number): string;
|
|
77
|
+
/**
|
|
78
|
+
* Build a JSON path extraction expression for PostgreSQL.
|
|
79
|
+
*
|
|
80
|
+
* Uses the ->> operator for text extraction from JSONB columns.
|
|
81
|
+
* Supports nested paths using chained operators.
|
|
82
|
+
*
|
|
83
|
+
* @param column - The JSONB column name
|
|
84
|
+
* @param path - The path to extract (dot notation: "user.name")
|
|
85
|
+
* @returns The SQL expression (e.g., "data"->>'user'->>'name')
|
|
86
|
+
*/
|
|
87
|
+
jsonExtract(column: string, path: string): string;
|
|
88
|
+
/**
|
|
89
|
+
* Build a JSON contains expression for PostgreSQL.
|
|
90
|
+
*
|
|
91
|
+
* Uses the @> containment operator for JSONB columns.
|
|
92
|
+
*
|
|
93
|
+
* @param column - The JSONB column name
|
|
94
|
+
* @param value - The value to check for
|
|
95
|
+
* @param path - Optional path within the JSON
|
|
96
|
+
* @returns The SQL expression
|
|
97
|
+
*/
|
|
98
|
+
jsonContains(column: string, value: unknown, path?: string): string;
|
|
99
|
+
/**
|
|
100
|
+
* Build a LIKE pattern expression for PostgreSQL.
|
|
101
|
+
*
|
|
102
|
+
* Uses ILIKE for case-insensitive matching, LIKE for case-sensitive.
|
|
103
|
+
*
|
|
104
|
+
* @param pattern - The pattern to match
|
|
105
|
+
* @param caseInsensitive - Whether to use case-insensitive matching
|
|
106
|
+
* @returns Object with operator and pattern
|
|
107
|
+
*/
|
|
108
|
+
likePattern(pattern: string, caseInsensitive?: boolean): {
|
|
109
|
+
operator: string;
|
|
110
|
+
pattern: string;
|
|
111
|
+
};
|
|
112
|
+
/**
|
|
113
|
+
* Build an array contains expression for PostgreSQL.
|
|
114
|
+
*
|
|
115
|
+
* Uses ANY() for checking if a value is in an array column.
|
|
116
|
+
*
|
|
117
|
+
* @param column - The array column name
|
|
118
|
+
* @param paramIndex - The parameter index
|
|
119
|
+
* @returns The SQL expression
|
|
120
|
+
*/
|
|
121
|
+
arrayContains(column: string, paramIndex: number): string;
|
|
122
|
+
/**
|
|
123
|
+
* Get the PostgreSQL SQL type for an abstract type.
|
|
124
|
+
*
|
|
125
|
+
* @param type - The abstract type name
|
|
126
|
+
* @param options - Type-specific options
|
|
127
|
+
* @returns The PostgreSQL type string
|
|
128
|
+
*/
|
|
129
|
+
getSqlType(type: string, options?: {
|
|
130
|
+
length?: number;
|
|
131
|
+
precision?: number;
|
|
132
|
+
scale?: number;
|
|
133
|
+
}): string;
|
|
134
|
+
}
|
|
135
|
+
//# sourceMappingURL=postgres-dialect.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-dialect.d.ts","sourceRoot":"","sources":["../../../src/drivers/postgres/postgres-dialect.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAEtE;;;;;;;;;;;;;;;;;;GAkBG;AACH,qBAAa,eAAgB,YAAW,kBAAkB;IACxD;;OAEG;IACH,SAAgB,IAAI,aAAuB;IAE3C;;OAEG;IACH,SAAgB,iBAAiB,QAAQ;IAEzC;;OAEG;IACH,SAAgB,aAAa,gBAA0B;IAEvD;;;;;;;OAOG;IACI,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAIzC;;;;;;;;OAQG;IACI,eAAe,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM;IAMlD;;;;;OAKG;IACI,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM;IAI7C;;;;;;OAMG;IACI,WAAW,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM;IAc3D;;;;;;;;;OASG;IACI,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM;IAkBxD;;;;;;;;;OASG;IACI,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,MAAM;IAc1E;;;;;;;;OAQG;IACI,WAAW,CAChB,OAAO,EAAE,MAAM,EACf,eAAe,UAAO,GACrB;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE;IAUxC;;;;;;;;OAQG;IACI,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM;IAIhE;;;;;;OAMG;IACI,UAAU,CACf,IAAI,EAAE,MAAM,EACZ,OAAO,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAChE,MAAM;CAuEV"}
|
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PostgreSQL Dialect Implementation
|
|
3
|
+
*
|
|
4
|
+
* Implements the SqlDialectContract for PostgreSQL-specific SQL syntax.
|
|
5
|
+
* Handles parameter placeholders ($1, $2), identifier quoting, and
|
|
6
|
+
* PostgreSQL-specific features like JSONB operators.
|
|
7
|
+
*
|
|
8
|
+
* @module cascade/drivers/postgres
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* PostgreSQL-specific SQL dialect implementation.
|
|
12
|
+
*
|
|
13
|
+
* Provides PostgreSQL syntax for:
|
|
14
|
+
* - Parameter placeholders ($1, $2, $3...)
|
|
15
|
+
* - Identifier quoting with double quotes
|
|
16
|
+
* - JSONB operators (->, ->>, @>)
|
|
17
|
+
* - ILIKE for case-insensitive matching
|
|
18
|
+
* - RETURNING clause support
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* ```typescript
|
|
22
|
+
* const dialect = new PostgresDialect();
|
|
23
|
+
*
|
|
24
|
+
* dialect.placeholder(1); // "$1"
|
|
25
|
+
* dialect.quoteIdentifier('user'); // '"user"'
|
|
26
|
+
* dialect.jsonExtract('data', 'name'); // "data"->>'name'
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
class PostgresDialect {
|
|
30
|
+
/**
|
|
31
|
+
* Dialect name identifier.
|
|
32
|
+
*/
|
|
33
|
+
name = "postgres";
|
|
34
|
+
/**
|
|
35
|
+
* PostgreSQL supports the RETURNING clause for INSERT/UPDATE/DELETE.
|
|
36
|
+
*/
|
|
37
|
+
supportsReturning = true;
|
|
38
|
+
/**
|
|
39
|
+
* PostgreSQL uses ON CONFLICT for upsert operations.
|
|
40
|
+
*/
|
|
41
|
+
upsertKeyword = "ON CONFLICT";
|
|
42
|
+
/**
|
|
43
|
+
* Generate a PostgreSQL parameter placeholder.
|
|
44
|
+
*
|
|
45
|
+
* PostgreSQL uses numbered placeholders: $1, $2, $3, etc.
|
|
46
|
+
*
|
|
47
|
+
* @param index - The 1-based parameter index
|
|
48
|
+
* @returns The placeholder string (e.g., "$1")
|
|
49
|
+
*/
|
|
50
|
+
placeholder(index) {
|
|
51
|
+
return `$${index}`;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Quote an identifier using PostgreSQL's double-quote syntax.
|
|
55
|
+
*
|
|
56
|
+
* Handles escaping of embedded double quotes by doubling them.
|
|
57
|
+
* This is necessary for reserved words and special characters.
|
|
58
|
+
*
|
|
59
|
+
* @param identifier - The identifier (table/column name) to quote
|
|
60
|
+
* @returns The quoted identifier (e.g., '"user"')
|
|
61
|
+
*/
|
|
62
|
+
quoteIdentifier(identifier) {
|
|
63
|
+
// Split on dots for qualified names (schema.table.column)
|
|
64
|
+
const parts = identifier.split(".");
|
|
65
|
+
return parts.map((part) => `"${part.replace(/"/g, '""')}"`).join(".");
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Convert a boolean to PostgreSQL literal.
|
|
69
|
+
*
|
|
70
|
+
* @param value - The boolean value
|
|
71
|
+
* @returns "TRUE" or "FALSE"
|
|
72
|
+
*/
|
|
73
|
+
booleanLiteral(value) {
|
|
74
|
+
return value ? "TRUE" : "FALSE";
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Build LIMIT/OFFSET clause for PostgreSQL.
|
|
78
|
+
*
|
|
79
|
+
* @param limit - Maximum rows to return
|
|
80
|
+
* @param offset - Rows to skip
|
|
81
|
+
* @returns The SQL clause (e.g., "LIMIT 10 OFFSET 20")
|
|
82
|
+
*/
|
|
83
|
+
limitOffset(limit, offset) {
|
|
84
|
+
const parts = [];
|
|
85
|
+
if (limit !== undefined) {
|
|
86
|
+
parts.push(`LIMIT ${limit}`);
|
|
87
|
+
}
|
|
88
|
+
if (offset !== undefined) {
|
|
89
|
+
parts.push(`OFFSET ${offset}`);
|
|
90
|
+
}
|
|
91
|
+
return parts.join(" ");
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Build a JSON path extraction expression for PostgreSQL.
|
|
95
|
+
*
|
|
96
|
+
* Uses the ->> operator for text extraction from JSONB columns.
|
|
97
|
+
* Supports nested paths using chained operators.
|
|
98
|
+
*
|
|
99
|
+
* @param column - The JSONB column name
|
|
100
|
+
* @param path - The path to extract (dot notation: "user.name")
|
|
101
|
+
* @returns The SQL expression (e.g., "data"->>'user'->>'name')
|
|
102
|
+
*/
|
|
103
|
+
jsonExtract(column, path) {
|
|
104
|
+
const quotedColumn = this.quoteIdentifier(column);
|
|
105
|
+
const pathParts = path.split(".");
|
|
106
|
+
if (pathParts.length === 1) {
|
|
107
|
+
return `${quotedColumn}->>'${pathParts[0]}'`;
|
|
108
|
+
}
|
|
109
|
+
// For nested paths: data->'user'->>'name' (last one gets text extraction)
|
|
110
|
+
const jsonPath = pathParts
|
|
111
|
+
.slice(0, -1)
|
|
112
|
+
.map((p) => `'${p}'`)
|
|
113
|
+
.join("->");
|
|
114
|
+
const lastKey = pathParts[pathParts.length - 1];
|
|
115
|
+
return `${quotedColumn}->${jsonPath}->>'${lastKey}'`;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Build a JSON contains expression for PostgreSQL.
|
|
119
|
+
*
|
|
120
|
+
* Uses the @> containment operator for JSONB columns.
|
|
121
|
+
*
|
|
122
|
+
* @param column - The JSONB column name
|
|
123
|
+
* @param value - The value to check for
|
|
124
|
+
* @param path - Optional path within the JSON
|
|
125
|
+
* @returns The SQL expression
|
|
126
|
+
*/
|
|
127
|
+
jsonContains(column, value, path) {
|
|
128
|
+
const quotedColumn = this.quoteIdentifier(column);
|
|
129
|
+
if (path) {
|
|
130
|
+
// Check if a specific path contains the value
|
|
131
|
+
const jsonValue = JSON.stringify({ [path]: value });
|
|
132
|
+
return `${quotedColumn} @> '${jsonValue}'::jsonb`;
|
|
133
|
+
}
|
|
134
|
+
// Check if the column contains the value (for arrays or objects)
|
|
135
|
+
const jsonValue = JSON.stringify(value);
|
|
136
|
+
return `${quotedColumn} @> '${jsonValue}'::jsonb`;
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Build a LIKE pattern expression for PostgreSQL.
|
|
140
|
+
*
|
|
141
|
+
* Uses ILIKE for case-insensitive matching, LIKE for case-sensitive.
|
|
142
|
+
*
|
|
143
|
+
* @param pattern - The pattern to match
|
|
144
|
+
* @param caseInsensitive - Whether to use case-insensitive matching
|
|
145
|
+
* @returns Object with operator and pattern
|
|
146
|
+
*/
|
|
147
|
+
likePattern(pattern, caseInsensitive = true) {
|
|
148
|
+
// Escape special characters in the pattern (%, _, \)
|
|
149
|
+
const escapedPattern = pattern.replace(/\\/g, "\\\\").replace(/%/g, "\\%").replace(/_/g, "\\_");
|
|
150
|
+
return {
|
|
151
|
+
operator: caseInsensitive ? "ILIKE" : "LIKE",
|
|
152
|
+
pattern: escapedPattern,
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Build an array contains expression for PostgreSQL.
|
|
157
|
+
*
|
|
158
|
+
* Uses ANY() for checking if a value is in an array column.
|
|
159
|
+
*
|
|
160
|
+
* @param column - The array column name
|
|
161
|
+
* @param paramIndex - The parameter index
|
|
162
|
+
* @returns The SQL expression
|
|
163
|
+
*/
|
|
164
|
+
arrayContains(column, paramIndex) {
|
|
165
|
+
return `${this.placeholder(paramIndex)} = ANY(${this.quoteIdentifier(column)})`;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Get the PostgreSQL SQL type for an abstract type.
|
|
169
|
+
*
|
|
170
|
+
* @param type - The abstract type name
|
|
171
|
+
* @param options - Type-specific options
|
|
172
|
+
* @returns The PostgreSQL type string
|
|
173
|
+
*/
|
|
174
|
+
getSqlType(type, options) {
|
|
175
|
+
switch (type) {
|
|
176
|
+
case "string":
|
|
177
|
+
return options?.length ? `VARCHAR(${options.length})` : "TEXT";
|
|
178
|
+
case "char":
|
|
179
|
+
return `CHAR(${options?.length ?? 1})`;
|
|
180
|
+
case "text":
|
|
181
|
+
return "TEXT";
|
|
182
|
+
case "mediumText":
|
|
183
|
+
case "longText":
|
|
184
|
+
return "TEXT"; // PostgreSQL doesn't distinguish text sizes
|
|
185
|
+
case "integer":
|
|
186
|
+
return "INTEGER";
|
|
187
|
+
case "smallInteger":
|
|
188
|
+
return "SMALLINT";
|
|
189
|
+
case "tinyInteger":
|
|
190
|
+
return "SMALLINT"; // PostgreSQL doesn't have TINYINT
|
|
191
|
+
case "bigInteger":
|
|
192
|
+
return "BIGINT";
|
|
193
|
+
case "float":
|
|
194
|
+
return "REAL";
|
|
195
|
+
case "double":
|
|
196
|
+
return "DOUBLE PRECISION";
|
|
197
|
+
case "decimal":
|
|
198
|
+
if (options?.precision !== undefined) {
|
|
199
|
+
const scale = options.scale ?? 0;
|
|
200
|
+
return `DECIMAL(${options.precision}, ${scale})`;
|
|
201
|
+
}
|
|
202
|
+
return "DECIMAL";
|
|
203
|
+
case "boolean":
|
|
204
|
+
return "BOOLEAN";
|
|
205
|
+
case "date":
|
|
206
|
+
return "DATE";
|
|
207
|
+
case "dateTime":
|
|
208
|
+
return "TIMESTAMP";
|
|
209
|
+
case "timestamp":
|
|
210
|
+
return "TIMESTAMPTZ"; // With timezone
|
|
211
|
+
case "time":
|
|
212
|
+
return "TIME";
|
|
213
|
+
case "year":
|
|
214
|
+
return "SMALLINT"; // PostgreSQL doesn't have YEAR type
|
|
215
|
+
case "json":
|
|
216
|
+
return "JSONB"; // Prefer JSONB for indexing and operators
|
|
217
|
+
case "binary":
|
|
218
|
+
return "BYTEA";
|
|
219
|
+
case "uuid":
|
|
220
|
+
return "UUID";
|
|
221
|
+
case "ulid":
|
|
222
|
+
return "CHAR(26)"; // ULIDs are 26 characters
|
|
223
|
+
case "ipAddress":
|
|
224
|
+
return "INET";
|
|
225
|
+
case "macAddress":
|
|
226
|
+
return "MACADDR";
|
|
227
|
+
case "point":
|
|
228
|
+
return "POINT";
|
|
229
|
+
case "polygon":
|
|
230
|
+
return "POLYGON";
|
|
231
|
+
case "lineString":
|
|
232
|
+
return "PATH";
|
|
233
|
+
case "geometry":
|
|
234
|
+
return "GEOMETRY"; // Requires PostGIS
|
|
235
|
+
case "vector":
|
|
236
|
+
return options?.length ? `VECTOR(${options.length})` : "VECTOR"; // Requires pgvector
|
|
237
|
+
case "enum":
|
|
238
|
+
return "TEXT"; // PostgreSQL enums need CREATE TYPE first
|
|
239
|
+
case "set":
|
|
240
|
+
return "TEXT[]"; // Use array for set-like behavior
|
|
241
|
+
default:
|
|
242
|
+
return type.toUpperCase();
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}export{PostgresDialect};//# sourceMappingURL=postgres-dialect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-dialect.js","sources":["../../../src/drivers/postgres/postgres-dialect.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
|