@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.
Files changed (269) hide show
  1. package/cjs/contracts/database-driver.contract.d.ts +118 -0
  2. package/cjs/contracts/database-driver.contract.d.ts.map +1 -1
  3. package/cjs/contracts/migration-driver.contract.d.ts +14 -0
  4. package/cjs/contracts/migration-driver.contract.d.ts.map +1 -1
  5. package/cjs/contracts/query-builder.contract.d.ts +410 -1
  6. package/cjs/contracts/query-builder.contract.d.ts.map +1 -1
  7. package/cjs/data-source/data-source-registry.d.ts +4 -0
  8. package/cjs/data-source/data-source-registry.d.ts.map +1 -1
  9. package/cjs/data-source/data-source-registry.js +7 -0
  10. package/cjs/data-source/data-source-registry.js.map +1 -1
  11. package/cjs/drivers/mongodb/mongodb-blueprint.d.ts.map +1 -0
  12. package/cjs/drivers/mongodb/mongodb-blueprint.js.map +1 -0
  13. package/{esm/drivers/mongo → cjs/drivers/mongodb}/mongodb-driver.d.ts +49 -0
  14. package/cjs/drivers/mongodb/mongodb-driver.d.ts.map +1 -0
  15. package/cjs/drivers/{mongo → mongodb}/mongodb-driver.js +125 -8
  16. package/cjs/drivers/mongodb/mongodb-driver.js.map +1 -0
  17. package/cjs/drivers/{mongo/mongo-id-generator.d.ts → mongodb/mongodb-id-generator.d.ts} +1 -1
  18. package/cjs/drivers/mongodb/mongodb-id-generator.d.ts.map +1 -0
  19. package/cjs/drivers/{mongo/mongo-id-generator.js → mongodb/mongodb-id-generator.js} +1 -1
  20. package/cjs/drivers/mongodb/mongodb-id-generator.js.map +1 -0
  21. package/cjs/drivers/{mongo/mongo-migration-driver.d.ts → mongodb/mongodb-migration-driver.d.ts} +10 -1
  22. package/cjs/drivers/mongodb/mongodb-migration-driver.d.ts.map +1 -0
  23. package/cjs/drivers/{mongo/mongo-migration-driver.js → mongodb/mongodb-migration-driver.js} +18 -1
  24. package/cjs/drivers/mongodb/mongodb-migration-driver.js.map +1 -0
  25. package/cjs/drivers/{mongo/mongo-query-builder.d.ts → mongodb/mongodb-query-builder.d.ts} +172 -4
  26. package/cjs/drivers/mongodb/mongodb-query-builder.d.ts.map +1 -0
  27. package/cjs/drivers/{mongo/mongo-query-builder.js → mongodb/mongodb-query-builder.js} +220 -14
  28. package/cjs/drivers/mongodb/mongodb-query-builder.js.map +1 -0
  29. package/{esm/drivers/mongo/mongo-query-operations.d.ts → cjs/drivers/mongodb/mongodb-query-operations.d.ts} +16 -16
  30. package/cjs/drivers/mongodb/mongodb-query-operations.d.ts.map +1 -0
  31. package/cjs/drivers/{mongo/mongo-query-operations.js → mongodb/mongodb-query-operations.js} +22 -22
  32. package/cjs/drivers/mongodb/mongodb-query-operations.js.map +1 -0
  33. package/cjs/drivers/{mongo/mongo-query-parser.d.ts → mongodb/mongodb-query-parser.d.ts} +2 -2
  34. package/cjs/drivers/mongodb/mongodb-query-parser.d.ts.map +1 -0
  35. package/cjs/drivers/{mongo/mongo-query-parser.js → mongodb/mongodb-query-parser.js} +87 -87
  36. package/cjs/drivers/mongodb/mongodb-query-parser.js.map +1 -0
  37. package/cjs/drivers/{mongo/mongo-sync-adapter.d.ts → mongodb/mongodb-sync-adapter.d.ts} +2 -2
  38. package/cjs/drivers/mongodb/mongodb-sync-adapter.d.ts.map +1 -0
  39. package/cjs/drivers/{mongo/mongo-sync-adapter.js → mongodb/mongodb-sync-adapter.js} +2 -2
  40. package/cjs/drivers/mongodb/mongodb-sync-adapter.js.map +1 -0
  41. package/{esm/drivers/mongo → cjs/drivers/mongodb}/types.d.ts +2 -2
  42. package/cjs/drivers/mongodb/types.d.ts.map +1 -0
  43. package/cjs/drivers/postgres/index.d.ts +16 -0
  44. package/cjs/drivers/postgres/index.d.ts.map +1 -0
  45. package/cjs/drivers/postgres/postgres-blueprint.d.ts +64 -0
  46. package/cjs/drivers/postgres/postgres-blueprint.d.ts.map +1 -0
  47. package/cjs/drivers/postgres/postgres-blueprint.js +121 -0
  48. package/cjs/drivers/postgres/postgres-blueprint.js.map +1 -0
  49. package/cjs/drivers/postgres/postgres-dialect.d.ts +135 -0
  50. package/cjs/drivers/postgres/postgres-dialect.d.ts.map +1 -0
  51. package/cjs/drivers/postgres/postgres-dialect.js +245 -0
  52. package/cjs/drivers/postgres/postgres-dialect.js.map +1 -0
  53. package/cjs/drivers/postgres/postgres-driver.d.ts +360 -0
  54. package/cjs/drivers/postgres/postgres-driver.d.ts.map +1 -0
  55. package/cjs/drivers/postgres/postgres-driver.js +763 -0
  56. package/cjs/drivers/postgres/postgres-driver.js.map +1 -0
  57. package/cjs/drivers/postgres/postgres-migration-driver.d.ts +297 -0
  58. package/cjs/drivers/postgres/postgres-migration-driver.d.ts.map +1 -0
  59. package/cjs/drivers/postgres/postgres-migration-driver.js +578 -0
  60. package/cjs/drivers/postgres/postgres-migration-driver.js.map +1 -0
  61. package/cjs/drivers/postgres/postgres-query-builder.d.ts +824 -0
  62. package/cjs/drivers/postgres/postgres-query-builder.d.ts.map +1 -0
  63. package/cjs/drivers/postgres/postgres-query-builder.js +1800 -0
  64. package/cjs/drivers/postgres/postgres-query-builder.js.map +1 -0
  65. package/cjs/drivers/postgres/postgres-query-parser.d.ts +308 -0
  66. package/cjs/drivers/postgres/postgres-query-parser.d.ts.map +1 -0
  67. package/cjs/drivers/postgres/postgres-query-parser.js +706 -0
  68. package/cjs/drivers/postgres/postgres-query-parser.js.map +1 -0
  69. package/cjs/drivers/postgres/postgres-sync-adapter.d.ts +83 -0
  70. package/cjs/drivers/postgres/postgres-sync-adapter.d.ts.map +1 -0
  71. package/cjs/drivers/postgres/postgres-sync-adapter.js +197 -0
  72. package/cjs/drivers/postgres/postgres-sync-adapter.js.map +1 -0
  73. package/cjs/drivers/postgres/types.d.ts +142 -0
  74. package/cjs/drivers/postgres/types.d.ts.map +1 -0
  75. package/cjs/drivers/sql/index.d.ts +10 -0
  76. package/cjs/drivers/sql/index.d.ts.map +1 -0
  77. package/cjs/drivers/sql/sql-dialect.contract.d.ts +203 -0
  78. package/cjs/drivers/sql/sql-dialect.contract.d.ts.map +1 -0
  79. package/cjs/drivers/sql/sql-types.d.ts +202 -0
  80. package/cjs/drivers/sql/sql-types.d.ts.map +1 -0
  81. package/cjs/index.d.ts +9 -6
  82. package/cjs/index.d.ts.map +1 -1
  83. package/cjs/index.js +1 -1
  84. package/cjs/migration/migration-runner.d.ts.map +1 -1
  85. package/cjs/migration/migration-runner.js +3 -0
  86. package/cjs/migration/migration-runner.js.map +1 -1
  87. package/cjs/model/model.d.ts +236 -1
  88. package/cjs/model/model.d.ts.map +1 -1
  89. package/cjs/model/model.js +203 -4
  90. package/cjs/model/model.js.map +1 -1
  91. package/cjs/relations/helpers.d.ts +156 -0
  92. package/cjs/relations/helpers.d.ts.map +1 -0
  93. package/cjs/relations/helpers.js +197 -0
  94. package/cjs/relations/helpers.js.map +1 -0
  95. package/cjs/relations/index.d.ts +33 -0
  96. package/cjs/relations/index.d.ts.map +1 -0
  97. package/cjs/relations/pivot-operations.d.ts +160 -0
  98. package/cjs/relations/pivot-operations.d.ts.map +1 -0
  99. package/cjs/relations/pivot-operations.js +293 -0
  100. package/cjs/relations/pivot-operations.js.map +1 -0
  101. package/cjs/relations/relation-loader.d.ts +194 -0
  102. package/cjs/relations/relation-loader.d.ts.map +1 -0
  103. package/cjs/relations/relation-loader.js +466 -0
  104. package/cjs/relations/relation-loader.js.map +1 -0
  105. package/cjs/relations/types.d.ts +280 -0
  106. package/cjs/relations/types.d.ts.map +1 -0
  107. package/cjs/sync/model-sync-operation.js +1 -1
  108. package/cjs/sync/model-sync-operation.js.map +1 -1
  109. package/cjs/utils/connect-to-database.d.ts.map +1 -1
  110. package/cjs/utils/connect-to-database.js +15 -3
  111. package/cjs/utils/connect-to-database.js.map +1 -1
  112. package/cjs/utils/define-model.d.ts +51 -29
  113. package/cjs/utils/define-model.d.ts.map +1 -1
  114. package/cjs/validation/rules/database-model-rule.js +1 -1
  115. package/cjs/validation/rules/database-model-rule.js.map +1 -1
  116. package/esm/contracts/database-driver.contract.d.ts +118 -0
  117. package/esm/contracts/database-driver.contract.d.ts.map +1 -1
  118. package/esm/contracts/migration-driver.contract.d.ts +14 -0
  119. package/esm/contracts/migration-driver.contract.d.ts.map +1 -1
  120. package/esm/contracts/query-builder.contract.d.ts +410 -1
  121. package/esm/contracts/query-builder.contract.d.ts.map +1 -1
  122. package/esm/data-source/data-source-registry.d.ts +4 -0
  123. package/esm/data-source/data-source-registry.d.ts.map +1 -1
  124. package/esm/data-source/data-source-registry.js +7 -0
  125. package/esm/data-source/data-source-registry.js.map +1 -1
  126. package/esm/drivers/mongodb/mongodb-blueprint.d.ts.map +1 -0
  127. package/esm/drivers/mongodb/mongodb-blueprint.js.map +1 -0
  128. package/{cjs/drivers/mongo → esm/drivers/mongodb}/mongodb-driver.d.ts +49 -0
  129. package/esm/drivers/mongodb/mongodb-driver.d.ts.map +1 -0
  130. package/esm/drivers/{mongo → mongodb}/mongodb-driver.js +121 -4
  131. package/esm/drivers/mongodb/mongodb-driver.js.map +1 -0
  132. package/esm/drivers/{mongo/mongo-id-generator.d.ts → mongodb/mongodb-id-generator.d.ts} +1 -1
  133. package/esm/drivers/mongodb/mongodb-id-generator.d.ts.map +1 -0
  134. package/esm/drivers/{mongo/mongo-id-generator.js → mongodb/mongodb-id-generator.js} +1 -1
  135. package/esm/drivers/mongodb/mongodb-id-generator.js.map +1 -0
  136. package/esm/drivers/{mongo/mongo-migration-driver.d.ts → mongodb/mongodb-migration-driver.d.ts} +10 -1
  137. package/esm/drivers/mongodb/mongodb-migration-driver.d.ts.map +1 -0
  138. package/esm/drivers/{mongo/mongo-migration-driver.js → mongodb/mongodb-migration-driver.js} +18 -1
  139. package/esm/drivers/mongodb/mongodb-migration-driver.js.map +1 -0
  140. package/esm/drivers/{mongo/mongo-query-builder.d.ts → mongodb/mongodb-query-builder.d.ts} +172 -4
  141. package/esm/drivers/mongodb/mongodb-query-builder.d.ts.map +1 -0
  142. package/esm/drivers/{mongo/mongo-query-builder.js → mongodb/mongodb-query-builder.js} +218 -12
  143. package/esm/drivers/mongodb/mongodb-query-builder.js.map +1 -0
  144. package/{cjs/drivers/mongo/mongo-query-operations.d.ts → esm/drivers/mongodb/mongodb-query-operations.d.ts} +16 -16
  145. package/esm/drivers/mongodb/mongodb-query-operations.d.ts.map +1 -0
  146. package/esm/drivers/{mongo/mongo-query-operations.js → mongodb/mongodb-query-operations.js} +22 -22
  147. package/esm/drivers/mongodb/mongodb-query-operations.js.map +1 -0
  148. package/esm/drivers/{mongo/mongo-query-parser.d.ts → mongodb/mongodb-query-parser.d.ts} +2 -2
  149. package/esm/drivers/mongodb/mongodb-query-parser.d.ts.map +1 -0
  150. package/esm/drivers/{mongo/mongo-query-parser.js → mongodb/mongodb-query-parser.js} +87 -87
  151. package/esm/drivers/mongodb/mongodb-query-parser.js.map +1 -0
  152. package/esm/drivers/{mongo/mongo-sync-adapter.d.ts → mongodb/mongodb-sync-adapter.d.ts} +2 -2
  153. package/esm/drivers/mongodb/mongodb-sync-adapter.d.ts.map +1 -0
  154. package/esm/drivers/{mongo/mongo-sync-adapter.js → mongodb/mongodb-sync-adapter.js} +2 -2
  155. package/esm/drivers/mongodb/mongodb-sync-adapter.js.map +1 -0
  156. package/{cjs/drivers/mongo → esm/drivers/mongodb}/types.d.ts +2 -2
  157. package/esm/drivers/mongodb/types.d.ts.map +1 -0
  158. package/esm/drivers/postgres/index.d.ts +16 -0
  159. package/esm/drivers/postgres/index.d.ts.map +1 -0
  160. package/esm/drivers/postgres/postgres-blueprint.d.ts +64 -0
  161. package/esm/drivers/postgres/postgres-blueprint.d.ts.map +1 -0
  162. package/esm/drivers/postgres/postgres-blueprint.js +121 -0
  163. package/esm/drivers/postgres/postgres-blueprint.js.map +1 -0
  164. package/esm/drivers/postgres/postgres-dialect.d.ts +135 -0
  165. package/esm/drivers/postgres/postgres-dialect.d.ts.map +1 -0
  166. package/esm/drivers/postgres/postgres-dialect.js +245 -0
  167. package/esm/drivers/postgres/postgres-dialect.js.map +1 -0
  168. package/esm/drivers/postgres/postgres-driver.d.ts +360 -0
  169. package/esm/drivers/postgres/postgres-driver.d.ts.map +1 -0
  170. package/esm/drivers/postgres/postgres-driver.js +763 -0
  171. package/esm/drivers/postgres/postgres-driver.js.map +1 -0
  172. package/esm/drivers/postgres/postgres-migration-driver.d.ts +297 -0
  173. package/esm/drivers/postgres/postgres-migration-driver.d.ts.map +1 -0
  174. package/esm/drivers/postgres/postgres-migration-driver.js +578 -0
  175. package/esm/drivers/postgres/postgres-migration-driver.js.map +1 -0
  176. package/esm/drivers/postgres/postgres-query-builder.d.ts +824 -0
  177. package/esm/drivers/postgres/postgres-query-builder.d.ts.map +1 -0
  178. package/esm/drivers/postgres/postgres-query-builder.js +1800 -0
  179. package/esm/drivers/postgres/postgres-query-builder.js.map +1 -0
  180. package/esm/drivers/postgres/postgres-query-parser.d.ts +308 -0
  181. package/esm/drivers/postgres/postgres-query-parser.d.ts.map +1 -0
  182. package/esm/drivers/postgres/postgres-query-parser.js +706 -0
  183. package/esm/drivers/postgres/postgres-query-parser.js.map +1 -0
  184. package/esm/drivers/postgres/postgres-sync-adapter.d.ts +83 -0
  185. package/esm/drivers/postgres/postgres-sync-adapter.d.ts.map +1 -0
  186. package/esm/drivers/postgres/postgres-sync-adapter.js +197 -0
  187. package/esm/drivers/postgres/postgres-sync-adapter.js.map +1 -0
  188. package/esm/drivers/postgres/types.d.ts +142 -0
  189. package/esm/drivers/postgres/types.d.ts.map +1 -0
  190. package/esm/drivers/sql/index.d.ts +10 -0
  191. package/esm/drivers/sql/index.d.ts.map +1 -0
  192. package/esm/drivers/sql/sql-dialect.contract.d.ts +203 -0
  193. package/esm/drivers/sql/sql-dialect.contract.d.ts.map +1 -0
  194. package/esm/drivers/sql/sql-types.d.ts +202 -0
  195. package/esm/drivers/sql/sql-types.d.ts.map +1 -0
  196. package/esm/index.d.ts +9 -6
  197. package/esm/index.d.ts.map +1 -1
  198. package/esm/index.js +1 -1
  199. package/esm/migration/migration-runner.d.ts.map +1 -1
  200. package/esm/migration/migration-runner.js +3 -0
  201. package/esm/migration/migration-runner.js.map +1 -1
  202. package/esm/model/model.d.ts +236 -1
  203. package/esm/model/model.d.ts.map +1 -1
  204. package/esm/model/model.js +203 -4
  205. package/esm/model/model.js.map +1 -1
  206. package/esm/relations/helpers.d.ts +156 -0
  207. package/esm/relations/helpers.d.ts.map +1 -0
  208. package/esm/relations/helpers.js +197 -0
  209. package/esm/relations/helpers.js.map +1 -0
  210. package/esm/relations/index.d.ts +33 -0
  211. package/esm/relations/index.d.ts.map +1 -0
  212. package/esm/relations/pivot-operations.d.ts +160 -0
  213. package/esm/relations/pivot-operations.d.ts.map +1 -0
  214. package/esm/relations/pivot-operations.js +293 -0
  215. package/esm/relations/pivot-operations.js.map +1 -0
  216. package/esm/relations/relation-loader.d.ts +194 -0
  217. package/esm/relations/relation-loader.d.ts.map +1 -0
  218. package/esm/relations/relation-loader.js +466 -0
  219. package/esm/relations/relation-loader.js.map +1 -0
  220. package/esm/relations/types.d.ts +280 -0
  221. package/esm/relations/types.d.ts.map +1 -0
  222. package/esm/sync/model-sync-operation.js +1 -1
  223. package/esm/sync/model-sync-operation.js.map +1 -1
  224. package/esm/utils/connect-to-database.d.ts.map +1 -1
  225. package/esm/utils/connect-to-database.js +15 -3
  226. package/esm/utils/connect-to-database.js.map +1 -1
  227. package/esm/utils/define-model.d.ts +51 -29
  228. package/esm/utils/define-model.d.ts.map +1 -1
  229. package/esm/validation/rules/database-model-rule.js +1 -1
  230. package/esm/validation/rules/database-model-rule.js.map +1 -1
  231. package/package.json +4 -4
  232. package/cjs/drivers/mongo/mongo-id-generator.d.ts.map +0 -1
  233. package/cjs/drivers/mongo/mongo-id-generator.js.map +0 -1
  234. package/cjs/drivers/mongo/mongo-migration-driver.d.ts.map +0 -1
  235. package/cjs/drivers/mongo/mongo-migration-driver.js.map +0 -1
  236. package/cjs/drivers/mongo/mongo-query-builder.d.ts.map +0 -1
  237. package/cjs/drivers/mongo/mongo-query-builder.js.map +0 -1
  238. package/cjs/drivers/mongo/mongo-query-operations.d.ts.map +0 -1
  239. package/cjs/drivers/mongo/mongo-query-operations.js.map +0 -1
  240. package/cjs/drivers/mongo/mongo-query-parser.d.ts.map +0 -1
  241. package/cjs/drivers/mongo/mongo-query-parser.js.map +0 -1
  242. package/cjs/drivers/mongo/mongo-sync-adapter.d.ts.map +0 -1
  243. package/cjs/drivers/mongo/mongo-sync-adapter.js.map +0 -1
  244. package/cjs/drivers/mongo/mongodb-blueprint.d.ts.map +0 -1
  245. package/cjs/drivers/mongo/mongodb-blueprint.js.map +0 -1
  246. package/cjs/drivers/mongo/mongodb-driver.d.ts.map +0 -1
  247. package/cjs/drivers/mongo/mongodb-driver.js.map +0 -1
  248. package/cjs/drivers/mongo/types.d.ts.map +0 -1
  249. package/esm/drivers/mongo/mongo-id-generator.d.ts.map +0 -1
  250. package/esm/drivers/mongo/mongo-id-generator.js.map +0 -1
  251. package/esm/drivers/mongo/mongo-migration-driver.d.ts.map +0 -1
  252. package/esm/drivers/mongo/mongo-migration-driver.js.map +0 -1
  253. package/esm/drivers/mongo/mongo-query-builder.d.ts.map +0 -1
  254. package/esm/drivers/mongo/mongo-query-builder.js.map +0 -1
  255. package/esm/drivers/mongo/mongo-query-operations.d.ts.map +0 -1
  256. package/esm/drivers/mongo/mongo-query-operations.js.map +0 -1
  257. package/esm/drivers/mongo/mongo-query-parser.d.ts.map +0 -1
  258. package/esm/drivers/mongo/mongo-query-parser.js.map +0 -1
  259. package/esm/drivers/mongo/mongo-sync-adapter.d.ts.map +0 -1
  260. package/esm/drivers/mongo/mongo-sync-adapter.js.map +0 -1
  261. package/esm/drivers/mongo/mongodb-blueprint.d.ts.map +0 -1
  262. package/esm/drivers/mongo/mongodb-blueprint.js.map +0 -1
  263. package/esm/drivers/mongo/mongodb-driver.d.ts.map +0 -1
  264. package/esm/drivers/mongo/mongodb-driver.js.map +0 -1
  265. package/esm/drivers/mongo/types.d.ts.map +0 -1
  266. /package/cjs/drivers/{mongo → mongodb}/mongodb-blueprint.d.ts +0 -0
  267. /package/cjs/drivers/{mongo → mongodb}/mongodb-blueprint.js +0 -0
  268. /package/esm/drivers/{mongo → mongodb}/mongodb-blueprint.d.ts +0 -0
  269. /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
+ 'use strict';/**
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
+ }exports.PostgresBlueprint=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
+ 'use strict';/**
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
+ }exports.PostgresDialect=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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"}