relq 1.0.66 → 1.0.67

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 (395) hide show
  1. package/dist/cjs/cli/adapters/base.cjs +2 -0
  2. package/dist/cjs/cli/adapters/cockroachdb/features.cjs +118 -0
  3. package/dist/cjs/cli/adapters/cockroachdb/index.cjs +84 -0
  4. package/dist/cjs/cli/adapters/cockroachdb/validator.cjs +149 -0
  5. package/dist/cjs/cli/adapters/dsql/features.cjs +133 -0
  6. package/dist/cjs/cli/adapters/dsql/index.cjs +135 -0
  7. package/dist/cjs/cli/adapters/dsql/validator.cjs +212 -0
  8. package/dist/cjs/cli/adapters/mysql/features.cjs +207 -0
  9. package/dist/cjs/cli/adapters/mysql/index.cjs +249 -0
  10. package/dist/cjs/cli/adapters/mysql/introspect.cjs +257 -0
  11. package/dist/cjs/cli/adapters/mysql/mariadb.cjs +32 -0
  12. package/dist/cjs/cli/adapters/mysql/planetscale.cjs +121 -0
  13. package/dist/cjs/cli/adapters/mysql/sql-generator.cjs +210 -0
  14. package/dist/cjs/cli/adapters/nile/features.cjs +90 -0
  15. package/dist/cjs/cli/adapters/nile/index.cjs +149 -0
  16. package/dist/cjs/cli/adapters/nile/tenant-context.cjs +85 -0
  17. package/dist/cjs/cli/adapters/nile/validator.cjs +212 -0
  18. package/dist/cjs/cli/adapters/postgres/features.cjs +194 -0
  19. package/dist/cjs/cli/adapters/postgres/index.cjs +158 -0
  20. package/dist/cjs/cli/adapters/postgres/introspect.cjs +570 -0
  21. package/dist/cjs/cli/adapters/postgres/sql-generator.cjs +247 -0
  22. package/dist/cjs/cli/adapters/postgres/type-map.cjs +214 -0
  23. package/dist/cjs/cli/adapters/postgres/validator.cjs +350 -0
  24. package/dist/cjs/cli/adapters/registry.cjs +198 -0
  25. package/dist/cjs/cli/adapters/sqlite/features.cjs +153 -0
  26. package/dist/cjs/cli/adapters/sqlite/index.cjs +257 -0
  27. package/dist/cjs/cli/adapters/sqlite/introspect.cjs +172 -0
  28. package/dist/cjs/cli/adapters/sqlite/sql-generator.cjs +257 -0
  29. package/dist/cjs/cli/adapters/sqlite/turso.cjs +112 -0
  30. package/dist/cjs/cli/adapters/xata/features.cjs +146 -0
  31. package/dist/cjs/cli/adapters/xata/index.cjs +398 -0
  32. package/dist/cjs/cli/adapters/xata/introspect.cjs +219 -0
  33. package/dist/cjs/cli/commands/add.cjs +2 -2
  34. package/dist/cjs/cli/commands/diff.cjs +2 -2
  35. package/dist/cjs/cli/commands/export.cjs +3 -3
  36. package/dist/cjs/cli/commands/generate.cjs +2 -2
  37. package/dist/cjs/cli/commands/import.cjs +201 -37
  38. package/dist/cjs/cli/commands/init.cjs +291 -95
  39. package/dist/cjs/cli/commands/introspect.cjs +7 -2
  40. package/dist/cjs/cli/commands/migrate.cjs +51 -23
  41. package/dist/cjs/cli/commands/pull.cjs +34 -171
  42. package/dist/cjs/cli/commands/push.cjs +57 -50
  43. package/dist/cjs/cli/commands/rollback.cjs +28 -17
  44. package/dist/cjs/cli/commands/sync.cjs +25 -17
  45. package/dist/cjs/cli/index.cjs +28 -101
  46. package/dist/cjs/cli/utils/ast-codegen.cjs +13 -17
  47. package/dist/cjs/cli/utils/cockroachdb/introspect.cjs +545 -0
  48. package/dist/cjs/cli/utils/crdb-validator.cjs +464 -0
  49. package/dist/cjs/cli/utils/database-client.cjs +289 -0
  50. package/dist/cjs/cli/utils/dialect-introspect.cjs +128 -0
  51. package/dist/cjs/cli/utils/dialect-router.cjs +192 -0
  52. package/dist/cjs/cli/utils/dialect-validator.cjs +486 -0
  53. package/dist/cjs/cli/utils/dsql/introspect.cjs +393 -0
  54. package/dist/cjs/cli/utils/dsql-rules.cjs +166 -0
  55. package/dist/cjs/cli/utils/dsql-validator.cjs +155 -0
  56. package/dist/cjs/cli/utils/mysql-validator.cjs +526 -0
  57. package/dist/cjs/cli/utils/nile/introspect.cjs +568 -0
  58. package/dist/cjs/cli/utils/nile-validator.cjs +442 -0
  59. package/dist/cjs/cli/utils/{fast-introspect.cjs → postgres/introspect.cjs} +80 -118
  60. package/dist/cjs/cli/utils/schema-to-ast.cjs +3 -3
  61. package/dist/cjs/cli/utils/sqlite-validator.cjs +561 -0
  62. package/dist/cjs/cli/utils/type-generator.cjs +13 -5
  63. package/dist/cjs/cockroachdb-builder.cjs +259 -0
  64. package/dist/cjs/config/connection.cjs +2 -0
  65. package/dist/cjs/config/define.cjs +60 -0
  66. package/dist/cjs/config/env.cjs +301 -0
  67. package/dist/cjs/config/index.cjs +34 -3
  68. package/dist/cjs/config/legacy.cjs +177 -0
  69. package/dist/cjs/config/types.cjs +97 -0
  70. package/dist/cjs/config/url-parser.cjs +260 -0
  71. package/dist/cjs/dsql-builder.cjs +240 -0
  72. package/dist/cjs/introspect/index.cjs +4 -4
  73. package/dist/cjs/nile-builder.cjs +90 -0
  74. package/dist/cjs/{schema-builder.cjs → pg-builder.cjs} +1 -1
  75. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/constraint-validator.cjs +44 -0
  76. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/errors.cjs +810 -0
  77. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/function-validator.cjs +103 -0
  78. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/index-builder.cjs +67 -0
  79. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/index.cjs +62 -0
  80. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/locality.cjs +80 -0
  81. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/trigger-validator.cjs +50 -0
  82. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/ttl.cjs +69 -0
  83. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/type-mappings.cjs +136 -0
  84. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/type-validator.cjs +98 -0
  85. package/dist/cjs/schema-definition/pg-schema/cockroachdb-schema/zone-config.cjs +77 -0
  86. package/dist/cjs/schema-definition/pg-schema/column-types/column-builder.cjs +216 -0
  87. package/dist/cjs/schema-definition/pg-schema/column-types/core-types.cjs +5 -0
  88. package/dist/cjs/schema-definition/pg-schema/column-types/custom-types.cjs +92 -0
  89. package/dist/cjs/schema-definition/pg-schema/column-types/domain-types.cjs +227 -0
  90. package/dist/cjs/schema-definition/pg-schema/column-types/expression-builder.cjs +426 -0
  91. package/dist/cjs/schema-definition/pg-schema/column-types/fluent-gen-expr.cjs +2 -0
  92. package/dist/cjs/schema-definition/pg-schema/column-types/index.cjs +28 -0
  93. package/dist/cjs/schema-definition/pg-schema/column-types/numeric-types.cjs +55 -0
  94. package/dist/cjs/schema-definition/pg-schema/column-types/range-types.cjs +28 -0
  95. package/dist/cjs/schema-definition/pg-schema/column-types/special-types.cjs +43 -0
  96. package/dist/cjs/schema-definition/pg-schema/column-types/string-temporal-types.cjs +138 -0
  97. package/dist/cjs/schema-definition/pg-schema/column-types/system-extension-types.cjs +30 -0
  98. package/dist/cjs/schema-definition/pg-schema/column-types/vector-postgis-types.cjs +58 -0
  99. package/dist/cjs/schema-definition/pg-schema/dialect-support/dialect-features.cjs +288 -0
  100. package/dist/cjs/schema-definition/pg-schema/dialect-support/dialect-types.cjs +2 -0
  101. package/dist/cjs/schema-definition/pg-schema/dialect-support/dialect-utilities.cjs +135 -0
  102. package/dist/cjs/schema-definition/pg-schema/dialect-support/index.cjs +19 -0
  103. package/dist/cjs/schema-definition/pg-schema/dsql-schema/constraint-validator.cjs +44 -0
  104. package/dist/cjs/schema-definition/pg-schema/dsql-schema/errors.cjs +894 -0
  105. package/dist/cjs/schema-definition/pg-schema/dsql-schema/function-validator.cjs +64 -0
  106. package/dist/cjs/schema-definition/pg-schema/dsql-schema/index-validator.cjs +70 -0
  107. package/dist/cjs/schema-definition/pg-schema/dsql-schema/index.cjs +86 -0
  108. package/dist/cjs/schema-definition/pg-schema/dsql-schema/limits.cjs +61 -0
  109. package/dist/cjs/schema-definition/pg-schema/dsql-schema/misc-validator.cjs +82 -0
  110. package/dist/cjs/schema-definition/pg-schema/dsql-schema/sequence-validator.cjs +41 -0
  111. package/dist/cjs/schema-definition/pg-schema/dsql-schema/sql-generator.cjs +213 -0
  112. package/dist/cjs/schema-definition/pg-schema/dsql-schema/table-validator.cjs +59 -0
  113. package/dist/cjs/schema-definition/pg-schema/dsql-schema/trigger-validator.cjs +23 -0
  114. package/dist/cjs/schema-definition/pg-schema/dsql-schema/type-mappings.cjs +159 -0
  115. package/dist/cjs/schema-definition/pg-schema/dsql-schema/type-validator.cjs +105 -0
  116. package/dist/cjs/schema-definition/pg-schema/dsql-schema/view-validator.cjs +41 -0
  117. package/dist/cjs/schema-definition/{index.cjs → pg-schema/index.cjs} +28 -6
  118. package/dist/cjs/schema-definition/pg-schema/introspection/code-generator.cjs +186 -0
  119. package/dist/cjs/schema-definition/pg-schema/introspection/index.cjs +19 -0
  120. package/dist/cjs/schema-definition/pg-schema/introspection/introspection-types.cjs +77 -0
  121. package/dist/cjs/schema-definition/{introspection.cjs → pg-schema/introspection/sql-parser.cjs} +15 -259
  122. package/dist/cjs/schema-definition/pg-schema/nile-schema/constraint-validator.cjs +61 -0
  123. package/dist/cjs/schema-definition/pg-schema/nile-schema/errors.cjs +485 -0
  124. package/dist/cjs/schema-definition/pg-schema/nile-schema/fk-validator.cjs +75 -0
  125. package/dist/cjs/schema-definition/pg-schema/nile-schema/function-validator.cjs +84 -0
  126. package/dist/cjs/schema-definition/pg-schema/nile-schema/index.cjs +83 -0
  127. package/dist/cjs/schema-definition/pg-schema/nile-schema/limits.cjs +69 -0
  128. package/dist/cjs/schema-definition/pg-schema/nile-schema/misc-validator.cjs +189 -0
  129. package/dist/cjs/schema-definition/pg-schema/nile-schema/pk-validator.cjs +35 -0
  130. package/dist/cjs/schema-definition/pg-schema/nile-schema/sequence-validator.cjs +75 -0
  131. package/dist/cjs/schema-definition/pg-schema/nile-schema/sql-generator.cjs +193 -0
  132. package/dist/cjs/schema-definition/pg-schema/nile-schema/table-classifier.cjs +114 -0
  133. package/dist/cjs/schema-definition/pg-schema/nile-schema/type-mappings.cjs +193 -0
  134. package/dist/cjs/schema-definition/pg-schema/nile-schema/type-validator.cjs +101 -0
  135. package/dist/cjs/schema-definition/pg-schema/pg-relations/index.cjs +19 -0
  136. package/dist/cjs/schema-definition/pg-schema/pg-relations/relation-api.cjs +86 -0
  137. package/dist/{esm/schema-definition/pg-relations.js → cjs/schema-definition/pg-schema/pg-relations/relation-builder.cjs} +4 -76
  138. package/dist/cjs/schema-definition/pg-schema/pg-relations/relation-types.cjs +2 -0
  139. package/dist/cjs/schema-definition/{pg-sequence.cjs → pg-schema/pg-sequence.cjs} +3 -3
  140. package/dist/cjs/schema-definition/{pg-view.cjs → pg-schema/pg-view.cjs} +2 -2
  141. package/dist/cjs/schema-definition/{relations.cjs → pg-schema/relations.cjs} +13 -0
  142. package/dist/cjs/schema-definition/{schema-builder.cjs → pg-schema/schema-builder.cjs} +1 -1
  143. package/dist/cjs/schema-definition/pg-schema/sql-expressions/index.cjs +20 -0
  144. package/dist/cjs/schema-definition/pg-schema/sql-expressions/sql-conditions.cjs +94 -0
  145. package/dist/cjs/schema-definition/pg-schema/sql-expressions/sql-expr-core.cjs +50 -0
  146. package/dist/cjs/schema-definition/pg-schema/sql-expressions/sql-functions-base.cjs +2 -0
  147. package/dist/cjs/schema-definition/pg-schema/sql-expressions/sql-functions.cjs +109 -0
  148. package/dist/cjs/schema-definition/pg-schema/table-definition/constraints-builder.cjs +178 -0
  149. package/dist/cjs/schema-definition/pg-schema/table-definition/generated-columns.cjs +45 -0
  150. package/dist/cjs/schema-definition/pg-schema/table-definition/index-builder.cjs +282 -0
  151. package/dist/cjs/schema-definition/pg-schema/table-definition/index-types.cjs +2 -0
  152. package/dist/cjs/schema-definition/pg-schema/table-definition/index.cjs +21 -0
  153. package/dist/cjs/schema-definition/pg-schema/table-definition/sql-generation.cjs +276 -0
  154. package/dist/cjs/schema-definition/pg-schema/table-definition/table-core.cjs +118 -0
  155. package/dist/cjs/schema-definition/pg-schema/table-definition/table-types.cjs +2 -0
  156. package/dist/cjs/schema-definition/pg-schema/validate-schema/index.cjs +19 -0
  157. package/dist/cjs/schema-definition/pg-schema/validate-schema/validation-helpers.cjs +75 -0
  158. package/dist/cjs/schema-definition/pg-schema/validate-schema/validation-types.cjs +2 -0
  159. package/dist/cjs/schema-definition/pg-schema/validate-schema/validators.cjs +280 -0
  160. package/dist/cjs/schema-definition/sqlite-schema/column-types/blob-types.cjs +11 -0
  161. package/dist/cjs/schema-definition/sqlite-schema/column-types/column-builder.cjs +76 -0
  162. package/dist/cjs/schema-definition/sqlite-schema/column-types/core-types.cjs +2 -0
  163. package/dist/cjs/schema-definition/sqlite-schema/column-types/index.cjs +27 -0
  164. package/dist/cjs/schema-definition/sqlite-schema/column-types/integer-types.cjs +16 -0
  165. package/dist/cjs/schema-definition/sqlite-schema/column-types/numeric-type.cjs +26 -0
  166. package/dist/cjs/schema-definition/sqlite-schema/column-types/real-types.cjs +39 -0
  167. package/dist/cjs/schema-definition/sqlite-schema/column-types/temporal-types.cjs +33 -0
  168. package/dist/cjs/schema-definition/sqlite-schema/column-types/text-types.cjs +45 -0
  169. package/dist/cjs/schema-definition/sqlite-schema/defaults.cjs +34 -0
  170. package/dist/cjs/schema-definition/sqlite-schema/index.cjs +26 -0
  171. package/dist/cjs/schema-definition/sqlite-schema/table-definition/ast-generation.cjs +180 -0
  172. package/dist/cjs/schema-definition/sqlite-schema/table-definition/index.cjs +26 -0
  173. package/dist/cjs/schema-definition/sqlite-schema/table-definition/sql-generation.cjs +176 -0
  174. package/dist/cjs/schema-definition/sqlite-schema/table-definition/table-core.cjs +55 -0
  175. package/dist/cjs/schema-definition/sqlite-schema/table-definition/table-types.cjs +2 -0
  176. package/dist/cjs/schema-definition/sqlite-schema/turso/index.cjs +18 -0
  177. package/dist/cjs/schema-definition/sqlite-schema/turso/vector-index.cjs +40 -0
  178. package/dist/cjs/schema-definition/sqlite-schema/turso/vector-types.cjs +35 -0
  179. package/dist/cjs/sqlite-builder.cjs +17 -0
  180. package/dist/cjs/turso-builder.cjs +18 -0
  181. package/dist/cockroachdb-builder.cjs +1 -0
  182. package/dist/cockroachdb-builder.d.ts +7602 -0
  183. package/dist/cockroachdb-builder.js +1 -0
  184. package/dist/config.d.ts +1925 -449
  185. package/dist/dsql-builder.cjs +1 -0
  186. package/dist/dsql-builder.d.ts +6633 -0
  187. package/dist/dsql-builder.js +1 -0
  188. package/dist/esm/cli/adapters/base.js +1 -0
  189. package/dist/esm/cli/adapters/cockroachdb/features.js +115 -0
  190. package/dist/esm/cli/adapters/cockroachdb/index.js +47 -0
  191. package/dist/esm/cli/adapters/cockroachdb/validator.js +142 -0
  192. package/dist/esm/cli/adapters/dsql/features.js +130 -0
  193. package/dist/esm/cli/adapters/dsql/index.js +96 -0
  194. package/dist/esm/cli/adapters/dsql/validator.js +204 -0
  195. package/dist/esm/cli/adapters/mysql/features.js +204 -0
  196. package/dist/esm/cli/adapters/mysql/index.js +244 -0
  197. package/dist/esm/cli/adapters/mysql/introspect.js +254 -0
  198. package/dist/esm/cli/adapters/mysql/mariadb.js +28 -0
  199. package/dist/esm/cli/adapters/mysql/planetscale.js +117 -0
  200. package/dist/esm/cli/adapters/mysql/sql-generator.js +202 -0
  201. package/dist/esm/cli/adapters/nile/features.js +87 -0
  202. package/dist/esm/cli/adapters/nile/index.js +111 -0
  203. package/dist/esm/cli/adapters/nile/tenant-context.js +76 -0
  204. package/dist/esm/cli/adapters/nile/validator.js +205 -0
  205. package/dist/esm/cli/adapters/postgres/features.js +188 -0
  206. package/dist/esm/cli/adapters/postgres/index.js +120 -0
  207. package/dist/esm/cli/adapters/postgres/introspect.js +531 -0
  208. package/dist/esm/cli/adapters/postgres/sql-generator.js +239 -0
  209. package/dist/esm/cli/adapters/postgres/type-map.js +202 -0
  210. package/dist/esm/cli/adapters/postgres/validator.js +344 -0
  211. package/dist/esm/cli/adapters/registry.js +150 -0
  212. package/dist/esm/cli/adapters/sqlite/features.js +150 -0
  213. package/dist/esm/cli/adapters/sqlite/index.js +219 -0
  214. package/dist/esm/cli/adapters/sqlite/introspect.js +167 -0
  215. package/dist/esm/cli/adapters/sqlite/sql-generator.js +249 -0
  216. package/dist/esm/cli/adapters/sqlite/turso.js +108 -0
  217. package/dist/esm/cli/adapters/xata/features.js +143 -0
  218. package/dist/esm/cli/adapters/xata/index.js +393 -0
  219. package/dist/esm/cli/adapters/xata/introspect.js +216 -0
  220. package/dist/esm/cli/commands/add.js +2 -2
  221. package/dist/esm/cli/commands/diff.js +2 -2
  222. package/dist/esm/cli/commands/export.js +3 -3
  223. package/dist/esm/cli/commands/generate.js +2 -2
  224. package/dist/esm/cli/commands/import.js +202 -38
  225. package/dist/esm/cli/commands/init.js +291 -95
  226. package/dist/esm/cli/commands/introspect.js +7 -2
  227. package/dist/esm/cli/commands/migrate.js +52 -24
  228. package/dist/esm/cli/commands/pull.js +36 -173
  229. package/dist/esm/cli/commands/push.js +57 -50
  230. package/dist/esm/cli/commands/rollback.js +28 -17
  231. package/dist/esm/cli/commands/sync.js +25 -17
  232. package/dist/esm/cli/index.js +28 -101
  233. package/dist/esm/cli/utils/ast-codegen.js +13 -17
  234. package/dist/esm/cli/utils/cockroachdb/introspect.js +509 -0
  235. package/dist/esm/cli/utils/crdb-validator.js +457 -0
  236. package/dist/esm/cli/utils/database-client.js +252 -0
  237. package/dist/esm/cli/utils/dialect-introspect.js +87 -0
  238. package/dist/esm/cli/utils/dialect-router.js +167 -0
  239. package/dist/esm/cli/utils/dialect-validator.js +447 -0
  240. package/dist/esm/cli/utils/dsql/introspect.js +357 -0
  241. package/dist/esm/cli/utils/dsql-rules.js +127 -0
  242. package/dist/esm/cli/utils/dsql-validator.js +155 -0
  243. package/dist/esm/cli/utils/mysql-validator.js +518 -0
  244. package/dist/esm/cli/utils/nile/introspect.js +532 -0
  245. package/dist/esm/cli/utils/nile-validator.js +432 -0
  246. package/dist/esm/cli/utils/{fast-introspect.js → postgres/introspect.js} +79 -117
  247. package/dist/esm/cli/utils/schema-to-ast.js +3 -3
  248. package/dist/esm/cli/utils/sqlite-validator.js +552 -0
  249. package/dist/esm/cli/utils/type-generator.js +13 -5
  250. package/dist/esm/cockroachdb-builder.js +79 -0
  251. package/dist/esm/config/connection.js +1 -0
  252. package/dist/esm/config/define.js +55 -0
  253. package/dist/esm/config/env.js +295 -0
  254. package/dist/esm/config/index.js +6 -1
  255. package/dist/esm/config/legacy.js +171 -0
  256. package/dist/esm/config/types.js +88 -0
  257. package/dist/esm/config/url-parser.js +255 -0
  258. package/dist/esm/dsql-builder.js +86 -0
  259. package/dist/esm/introspect/index.js +4 -4
  260. package/dist/esm/nile-builder.js +3 -0
  261. package/dist/esm/pg-builder.js +2 -0
  262. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/constraint-validator.js +38 -0
  263. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/errors.js +802 -0
  264. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/function-validator.js +97 -0
  265. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/index-builder.js +59 -0
  266. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/index.js +10 -0
  267. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/locality.js +74 -0
  268. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/trigger-validator.js +45 -0
  269. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/ttl.js +63 -0
  270. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/type-mappings.js +129 -0
  271. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/type-validator.js +90 -0
  272. package/dist/esm/schema-definition/pg-schema/cockroachdb-schema/zone-config.js +71 -0
  273. package/dist/esm/schema-definition/pg-schema/column-types/column-builder.js +211 -0
  274. package/dist/esm/schema-definition/pg-schema/column-types/core-types.js +2 -0
  275. package/dist/esm/schema-definition/pg-schema/column-types/custom-types.js +76 -0
  276. package/dist/esm/schema-definition/pg-schema/column-types/domain-types.js +223 -0
  277. package/dist/esm/schema-definition/pg-schema/column-types/expression-builder.js +419 -0
  278. package/dist/esm/schema-definition/pg-schema/column-types/fluent-gen-expr.js +1 -0
  279. package/dist/esm/schema-definition/pg-schema/column-types/index.js +12 -0
  280. package/dist/esm/schema-definition/pg-schema/column-types/numeric-types.js +41 -0
  281. package/dist/esm/schema-definition/pg-schema/column-types/range-types.js +13 -0
  282. package/dist/esm/schema-definition/pg-schema/column-types/special-types.js +21 -0
  283. package/dist/esm/schema-definition/pg-schema/column-types/string-temporal-types.js +124 -0
  284. package/dist/esm/schema-definition/pg-schema/column-types/system-extension-types.js +14 -0
  285. package/dist/esm/schema-definition/pg-schema/column-types/vector-postgis-types.js +47 -0
  286. package/dist/esm/schema-definition/pg-schema/dialect-support/dialect-features.js +285 -0
  287. package/dist/esm/schema-definition/pg-schema/dialect-support/dialect-types.js +1 -0
  288. package/dist/esm/schema-definition/pg-schema/dialect-support/dialect-utilities.js +124 -0
  289. package/dist/esm/schema-definition/pg-schema/dialect-support/index.js +3 -0
  290. package/dist/esm/schema-definition/pg-schema/dsql-schema/constraint-validator.js +39 -0
  291. package/dist/esm/schema-definition/pg-schema/dsql-schema/errors.js +886 -0
  292. package/dist/esm/schema-definition/pg-schema/dsql-schema/function-validator.js +58 -0
  293. package/dist/esm/schema-definition/pg-schema/dsql-schema/index-validator.js +65 -0
  294. package/dist/esm/schema-definition/pg-schema/dsql-schema/index.js +13 -0
  295. package/dist/esm/schema-definition/pg-schema/dsql-schema/limits.js +58 -0
  296. package/dist/esm/schema-definition/pg-schema/dsql-schema/misc-validator.js +76 -0
  297. package/dist/esm/schema-definition/pg-schema/dsql-schema/sequence-validator.js +35 -0
  298. package/dist/esm/schema-definition/pg-schema/dsql-schema/sql-generator.js +207 -0
  299. package/dist/esm/schema-definition/pg-schema/dsql-schema/table-validator.js +53 -0
  300. package/dist/esm/schema-definition/pg-schema/dsql-schema/trigger-validator.js +19 -0
  301. package/dist/esm/schema-definition/pg-schema/dsql-schema/type-mappings.js +153 -0
  302. package/dist/esm/schema-definition/pg-schema/dsql-schema/type-validator.js +98 -0
  303. package/dist/esm/schema-definition/pg-schema/dsql-schema/view-validator.js +36 -0
  304. package/dist/esm/schema-definition/{index.js → pg-schema/index.js} +7 -5
  305. package/dist/esm/schema-definition/pg-schema/introspection/code-generator.js +178 -0
  306. package/dist/esm/schema-definition/pg-schema/introspection/index.js +3 -0
  307. package/dist/esm/schema-definition/pg-schema/introspection/introspection-types.js +72 -0
  308. package/dist/esm/schema-definition/{introspection.js → pg-schema/introspection/sql-parser.js} +6 -252
  309. package/dist/esm/schema-definition/pg-schema/nile-schema/constraint-validator.js +56 -0
  310. package/dist/esm/schema-definition/pg-schema/nile-schema/errors.js +477 -0
  311. package/dist/esm/schema-definition/pg-schema/nile-schema/fk-validator.js +71 -0
  312. package/dist/esm/schema-definition/pg-schema/nile-schema/function-validator.js +79 -0
  313. package/dist/esm/schema-definition/pg-schema/nile-schema/index.js +12 -0
  314. package/dist/esm/schema-definition/pg-schema/nile-schema/limits.js +66 -0
  315. package/dist/esm/schema-definition/pg-schema/nile-schema/misc-validator.js +181 -0
  316. package/dist/esm/schema-definition/pg-schema/nile-schema/pk-validator.js +31 -0
  317. package/dist/esm/schema-definition/pg-schema/nile-schema/sequence-validator.js +70 -0
  318. package/dist/esm/schema-definition/pg-schema/nile-schema/sql-generator.js +187 -0
  319. package/dist/esm/schema-definition/pg-schema/nile-schema/table-classifier.js +106 -0
  320. package/dist/esm/schema-definition/pg-schema/nile-schema/type-mappings.js +187 -0
  321. package/dist/esm/schema-definition/pg-schema/nile-schema/type-validator.js +94 -0
  322. package/dist/esm/schema-definition/pg-schema/pg-relations/index.js +3 -0
  323. package/dist/esm/schema-definition/pg-schema/pg-relations/relation-api.js +77 -0
  324. package/dist/{cjs/schema-definition/pg-relations.cjs → esm/schema-definition/pg-schema/pg-relations/relation-builder.js} +2 -87
  325. package/dist/esm/schema-definition/pg-schema/pg-relations/relation-types.js +1 -0
  326. package/dist/esm/schema-definition/{pg-sequence.js → pg-schema/pg-sequence.js} +3 -3
  327. package/dist/esm/schema-definition/{pg-view.js → pg-schema/pg-view.js} +2 -2
  328. package/dist/esm/schema-definition/{relations.js → pg-schema/relations.js} +13 -0
  329. package/dist/esm/schema-definition/{schema-builder.js → pg-schema/schema-builder.js} +1 -1
  330. package/dist/esm/schema-definition/pg-schema/sql-expressions/index.js +4 -0
  331. package/dist/esm/schema-definition/pg-schema/sql-expressions/sql-conditions.js +88 -0
  332. package/dist/esm/schema-definition/pg-schema/sql-expressions/sql-expr-core.js +43 -0
  333. package/dist/esm/schema-definition/pg-schema/sql-expressions/sql-functions-base.js +1 -0
  334. package/dist/esm/schema-definition/pg-schema/sql-expressions/sql-functions.js +105 -0
  335. package/dist/esm/schema-definition/pg-schema/table-definition/constraints-builder.js +171 -0
  336. package/dist/esm/schema-definition/pg-schema/table-definition/generated-columns.js +38 -0
  337. package/dist/esm/schema-definition/pg-schema/table-definition/index-builder.js +273 -0
  338. package/dist/esm/schema-definition/pg-schema/table-definition/index-types.js +1 -0
  339. package/dist/esm/schema-definition/pg-schema/table-definition/index.js +5 -0
  340. package/dist/esm/schema-definition/pg-schema/table-definition/sql-generation.js +265 -0
  341. package/dist/esm/schema-definition/pg-schema/table-definition/table-core.js +115 -0
  342. package/dist/esm/schema-definition/pg-schema/table-definition/table-types.js +1 -0
  343. package/dist/esm/schema-definition/pg-schema/validate-schema/index.js +3 -0
  344. package/dist/esm/schema-definition/pg-schema/validate-schema/validation-helpers.js +69 -0
  345. package/dist/esm/schema-definition/pg-schema/validate-schema/validation-types.js +1 -0
  346. package/dist/esm/schema-definition/pg-schema/validate-schema/validators.js +277 -0
  347. package/dist/esm/schema-definition/sqlite-schema/column-types/blob-types.js +7 -0
  348. package/dist/esm/schema-definition/sqlite-schema/column-types/column-builder.js +72 -0
  349. package/dist/esm/schema-definition/sqlite-schema/column-types/core-types.js +1 -0
  350. package/dist/esm/schema-definition/sqlite-schema/column-types/index.js +8 -0
  351. package/dist/esm/schema-definition/sqlite-schema/column-types/integer-types.js +11 -0
  352. package/dist/esm/schema-definition/sqlite-schema/column-types/numeric-type.js +18 -0
  353. package/dist/esm/schema-definition/sqlite-schema/column-types/real-types.js +34 -0
  354. package/dist/esm/schema-definition/sqlite-schema/column-types/temporal-types.js +26 -0
  355. package/dist/esm/schema-definition/sqlite-schema/column-types/text-types.js +40 -0
  356. package/dist/esm/schema-definition/sqlite-schema/defaults.js +31 -0
  357. package/dist/esm/schema-definition/sqlite-schema/index.js +4 -0
  358. package/dist/esm/schema-definition/sqlite-schema/table-definition/ast-generation.js +177 -0
  359. package/dist/esm/schema-definition/sqlite-schema/table-definition/index.js +4 -0
  360. package/dist/esm/schema-definition/sqlite-schema/table-definition/sql-generation.js +171 -0
  361. package/dist/esm/schema-definition/sqlite-schema/table-definition/table-core.js +52 -0
  362. package/dist/esm/schema-definition/sqlite-schema/table-definition/table-types.js +1 -0
  363. package/dist/esm/schema-definition/sqlite-schema/turso/index.js +2 -0
  364. package/dist/esm/schema-definition/sqlite-schema/turso/vector-index.js +32 -0
  365. package/dist/esm/schema-definition/sqlite-schema/turso/vector-types.js +27 -0
  366. package/dist/esm/sqlite-builder.js +1 -0
  367. package/dist/esm/turso-builder.js +2 -0
  368. package/dist/index.d.ts +157 -74
  369. package/dist/nile-builder.cjs +1 -0
  370. package/dist/nile-builder.d.ts +10251 -0
  371. package/dist/nile-builder.js +1 -0
  372. package/dist/pg-builder.cjs +1 -0
  373. package/dist/pg-builder.d.ts +7625 -0
  374. package/dist/pg-builder.js +1 -0
  375. package/package.json +20 -5
  376. package/dist/cjs/schema-definition/column-types.cjs +0 -1258
  377. package/dist/cjs/schema-definition/sql-expressions.cjs +0 -205
  378. package/dist/cjs/schema-definition/table-definition.cjs +0 -811
  379. package/dist/esm/schema-builder.js +0 -2
  380. package/dist/esm/schema-definition/column-types.js +0 -1164
  381. package/dist/esm/schema-definition/sql-expressions.js +0 -196
  382. package/dist/esm/schema-definition/table-definition.js +0 -805
  383. package/dist/schema-builder.cjs +0 -1
  384. package/dist/schema-builder.d.ts +0 -3953
  385. package/dist/schema-builder.js +0 -1
  386. /package/dist/cjs/schema-definition/{defaults.cjs → pg-schema/defaults.cjs} +0 -0
  387. /package/dist/cjs/schema-definition/{partitions.cjs → pg-schema/partitions.cjs} +0 -0
  388. /package/dist/cjs/schema-definition/{pg-enum.cjs → pg-schema/pg-enum.cjs} +0 -0
  389. /package/dist/cjs/schema-definition/{pg-function.cjs → pg-schema/pg-function.cjs} +0 -0
  390. /package/dist/cjs/schema-definition/{pg-trigger.cjs → pg-schema/pg-trigger.cjs} +0 -0
  391. /package/dist/esm/schema-definition/{defaults.js → pg-schema/defaults.js} +0 -0
  392. /package/dist/esm/schema-definition/{partitions.js → pg-schema/partitions.js} +0 -0
  393. /package/dist/esm/schema-definition/{pg-enum.js → pg-schema/pg-enum.js} +0 -0
  394. /package/dist/esm/schema-definition/{pg-function.js → pg-schema/pg-function.js} +0 -0
  395. /package/dist/esm/schema-definition/{pg-trigger.js → pg-schema/pg-trigger.js} +0 -0
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,118 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PLPGSQL_LIMITATIONS = exports.UNSUPPORTED_SQL_FEATURES = exports.UNSUPPORTED_DATA_TYPES = exports.COCKROACHDB_FEATURES = void 0;
4
+ exports.COCKROACHDB_FEATURES = {
5
+ supportsJson: true,
6
+ supportsJsonb: true,
7
+ supportsArrays: true,
8
+ supportsEnums: true,
9
+ supportsUuid: true,
10
+ supportsSerial: true,
11
+ supportsIdentity: true,
12
+ supportsBigint: true,
13
+ supportsDecimal: true,
14
+ supportsGeometry: false,
15
+ supportsTimestampTz: true,
16
+ supportsInterval: true,
17
+ supportsRangeTypes: false,
18
+ supportsCompositeTypes: false,
19
+ supportsNetworkTypes: true,
20
+ supportsFullTextSearch: false,
21
+ supportsDeferrableConstraints: true,
22
+ supportsExcludeConstraints: false,
23
+ supportsGeneratedColumns: true,
24
+ supportsPartialIndexes: true,
25
+ supportsCoveringIndexes: true,
26
+ supportsBtreeIndex: true,
27
+ supportsHashIndex: true,
28
+ supportsGistIndex: false,
29
+ supportsGinIndex: true,
30
+ supportsBrinIndex: false,
31
+ supportsSpGistIndex: false,
32
+ supportsSchemas: true,
33
+ supportsTablePartitioning: true,
34
+ supportsTableInheritance: false,
35
+ supportsMaterializedViews: true,
36
+ supportsForeignTables: false,
37
+ supportsTriggers: true,
38
+ supportsStoredProcedures: true,
39
+ supportsSequences: true,
40
+ supportsDomains: false,
41
+ supportsTransactions: true,
42
+ supportsSavepoints: true,
43
+ supportsIsolationLevels: true,
44
+ supportsReadOnlyTransactions: true,
45
+ supportsWindowFunctions: true,
46
+ supportsCTE: true,
47
+ supportsRecursiveCTE: true,
48
+ supportsLateralJoin: true,
49
+ supportsReturning: true,
50
+ supportsOnConflict: true,
51
+ supportsDistinctOn: true,
52
+ supportsGroupingSets: true,
53
+ supportsFilter: true,
54
+ supportsListenNotify: false,
55
+ supportsLogicalReplication: false,
56
+ supportsComments: true,
57
+ supportsExtensions: false,
58
+ supportsCopyCommand: true,
59
+ };
60
+ exports.UNSUPPORTED_DATA_TYPES = [
61
+ { pattern: /\bMONEY\b/i, name: 'MONEY', alternative: 'NUMERIC(precision, scale)', category: 'monetary' },
62
+ { pattern: /\bXML\b/i, name: 'XML', alternative: 'TEXT', category: 'text' },
63
+ { pattern: /\bPOINT\b/i, name: 'POINT', alternative: 'GEOMETRY via spatial extension or two NUMERIC columns', category: 'geometric' },
64
+ { pattern: /\bLINE\b/i, name: 'LINE', alternative: 'TEXT or GEOMETRY via spatial', category: 'geometric' },
65
+ { pattern: /\bLSEG\b/i, name: 'LSEG', alternative: 'TEXT or GEOMETRY via spatial', category: 'geometric' },
66
+ { pattern: /\bBOX\b/i, name: 'BOX', alternative: 'TEXT or GEOMETRY via spatial', category: 'geometric' },
67
+ { pattern: /\bPATH\b/i, name: 'PATH', alternative: 'TEXT or GEOMETRY via spatial', category: 'geometric' },
68
+ { pattern: /\bPOLYGON\b/i, name: 'POLYGON', alternative: 'GEOMETRY via spatial extension', category: 'geometric' },
69
+ { pattern: /\bCIRCLE\b/i, name: 'CIRCLE', alternative: 'TEXT or GEOMETRY via spatial', category: 'geometric' },
70
+ { pattern: /\bINT4RANGE\b/i, name: 'INT4RANGE', alternative: 'Two INTEGER columns', category: 'range' },
71
+ { pattern: /\bINT8RANGE\b/i, name: 'INT8RANGE', alternative: 'Two BIGINT columns', category: 'range' },
72
+ { pattern: /\bNUMRANGE\b/i, name: 'NUMRANGE', alternative: 'Two NUMERIC columns', category: 'range' },
73
+ { pattern: /\bTSRANGE\b/i, name: 'TSRANGE', alternative: 'Two TIMESTAMP columns', category: 'range' },
74
+ { pattern: /\bTSTZRANGE\b/i, name: 'TSTZRANGE', alternative: 'Two TIMESTAMPTZ columns', category: 'range' },
75
+ { pattern: /\bDATERANGE\b/i, name: 'DATERANGE', alternative: 'Two DATE columns', category: 'range' },
76
+ { pattern: /\b\w+MULTIRANGE\b/i, name: 'Multirange', alternative: 'Multiple rows or JSONB', category: 'range' },
77
+ { pattern: /\bTSVECTOR\b/i, name: 'TSVECTOR', alternative: 'TEXT + inverted indexes', category: 'fulltext' },
78
+ { pattern: /\bTSQUERY\b/i, name: 'TSQUERY', alternative: 'Application-layer search', category: 'fulltext' },
79
+ { pattern: /\bOID\b/i, name: 'OID', alternative: 'INTEGER or BIGINT', category: 'system' },
80
+ { pattern: /\bREGCLASS\b/i, name: 'REGCLASS', alternative: 'TEXT', category: 'system' },
81
+ { pattern: /\bREGPROC\b/i, name: 'REGPROC', alternative: 'TEXT', category: 'system' },
82
+ { pattern: /\bREGTYPE\b/i, name: 'REGTYPE', alternative: 'TEXT', category: 'system' },
83
+ { pattern: /\bCIDR\b/i, name: 'CIDR', alternative: 'TEXT or INET', category: 'network' },
84
+ { pattern: /\bMACADDR\b/i, name: 'MACADDR', alternative: 'TEXT or VARCHAR(17)', category: 'network' },
85
+ { pattern: /\bMACADDR8\b/i, name: 'MACADDR8', alternative: 'TEXT or VARCHAR(23)', category: 'network' },
86
+ { pattern: /\bpg_lsn\b/i, name: 'pg_lsn', alternative: 'N/A (PostgreSQL internal)', category: 'system' },
87
+ { pattern: /\bpg_snapshot\b/i, name: 'pg_snapshot', alternative: 'N/A (PostgreSQL internal)', category: 'system' },
88
+ ];
89
+ exports.UNSUPPORTED_SQL_FEATURES = [
90
+ { pattern: /\bLISTEN\b/i, name: 'LISTEN', alternative: 'CockroachDB changefeeds', severity: 'error' },
91
+ { pattern: /\bNOTIFY\b/i, name: 'NOTIFY', alternative: 'CockroachDB changefeeds', severity: 'error' },
92
+ { pattern: /\bUNLISTEN\b/i, name: 'UNLISTEN', alternative: 'CockroachDB changefeeds', severity: 'error' },
93
+ { pattern: /\bCREATE\s+DOMAIN\b/i, name: 'CREATE DOMAIN', alternative: 'CHECK constraints on columns', severity: 'error' },
94
+ { pattern: /\bCREATE\s+TYPE\s+\w+\s+AS\s*\(/i, name: 'Composite Type', alternative: 'JSONB or separate table', severity: 'error' },
95
+ { pattern: /\bCREATE\s+EXTENSION\b/i, name: 'CREATE EXTENSION', alternative: 'Built-in features or application-layer', severity: 'error' },
96
+ { pattern: /\bVACUUM\b/i, name: 'VACUUM', alternative: 'CockroachDB handles this automatically', severity: 'warning' },
97
+ { pattern: /\bREINDEX\b/i, name: 'REINDEX', alternative: 'CockroachDB handles this automatically', severity: 'warning' },
98
+ { pattern: /\bCLUSTER\b/i, name: 'CLUSTER', alternative: 'CockroachDB handles this automatically', severity: 'warning' },
99
+ { pattern: /\bpg_advisory_lock\b/i, name: 'Advisory Locks', alternative: 'Application-layer distributed lock', severity: 'error' },
100
+ { pattern: /\bpg_try_advisory_lock\b/i, name: 'Advisory Locks', alternative: 'Application-layer distributed lock', severity: 'error' },
101
+ { pattern: /\bto_tsvector\b/i, name: 'to_tsvector', alternative: 'Inverted indexes', severity: 'error' },
102
+ { pattern: /\bto_tsquery\b/i, name: 'to_tsquery', alternative: 'Inverted indexes', severity: 'error' },
103
+ { pattern: /\bplainto_tsquery\b/i, name: 'plainto_tsquery', alternative: 'Inverted indexes', severity: 'error' },
104
+ { pattern: /\bphraseto_tsquery\b/i, name: 'phraseto_tsquery', alternative: 'Inverted indexes', severity: 'error' },
105
+ { pattern: /\bwebsearch_to_tsquery\b/i, name: 'websearch_to_tsquery', alternative: 'Inverted indexes', severity: 'error' },
106
+ { pattern: /\bts_rank\b/i, name: 'ts_rank', alternative: 'Application-layer ranking', severity: 'error' },
107
+ { pattern: /\bts_rank_cd\b/i, name: 'ts_rank_cd', alternative: 'Application-layer ranking', severity: 'error' },
108
+ ];
109
+ exports.PLPGSQL_LIMITATIONS = [
110
+ { pattern: /%TYPE\b/i, name: '%TYPE', alternative: 'Explicit type declaration' },
111
+ { pattern: /%ROWTYPE\b/i, name: '%ROWTYPE', alternative: 'RECORD type' },
112
+ { pattern: /\$\d+\b/, name: 'Ordinal parameter refs ($1, $2)', alternative: 'Named parameters' },
113
+ { pattern: /\bFOR\s+\w+\s+IN\b/i, name: 'FOR loops', alternative: 'WHILE loop or cursor' },
114
+ { pattern: /\bFOREACH\b/i, name: 'FOREACH', alternative: 'WHILE loop with array subscript' },
115
+ { pattern: /\bPERFORM\b/i, name: 'PERFORM', alternative: 'SELECT ... INTO _dummy' },
116
+ { pattern: /\bEXECUTE\b/i, name: 'EXECUTE', alternative: 'Prepared statements' },
117
+ { pattern: /\bGET\s+DIAGNOSTICS\b/i, name: 'GET DIAGNOSTICS', alternative: 'Explicit row count check' },
118
+ ];
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.CockroachDBAdapter = void 0;
37
+ const index_1 = require("../postgres/index.cjs");
38
+ const features_1 = require("./features.cjs");
39
+ const validator_1 = require("./validator.cjs");
40
+ class CockroachDBAdapter extends index_1.PostgresAdapter {
41
+ dialect = 'cockroachdb';
42
+ displayName = 'CockroachDB';
43
+ features = features_1.COCKROACHDB_FEATURES;
44
+ validate(schema) {
45
+ return (0, validator_1.validateSchemaForCockroachDB)(schema);
46
+ }
47
+ validateSql(sql) {
48
+ return (0, validator_1.validateSqlForCockroachDB)(sql);
49
+ }
50
+ getAlternativeType(type) {
51
+ return (0, validator_1.getAlternativeType)(type);
52
+ }
53
+ isTypeSupported(type) {
54
+ return (0, validator_1.isTypeSupported)(type);
55
+ }
56
+ async getDatabaseVersion(connection) {
57
+ const { Pool } = await Promise.resolve().then(() => __importStar(require("../../../addon/pg/index.cjs")));
58
+ const { buildPoolConfig } = await Promise.resolve().then(() => __importStar(require("../../../config/config.cjs")));
59
+ const config = connection;
60
+ const poolConfig = await buildPoolConfig({
61
+ url: config.url,
62
+ host: config.host,
63
+ port: config.port,
64
+ database: config.database,
65
+ user: config.user,
66
+ password: config.password,
67
+ ssl: config.ssl,
68
+ });
69
+ const pool = new Pool({ ...poolConfig, max: 1 });
70
+ try {
71
+ const result = await pool.query('SELECT version()');
72
+ const version = result.rows[0]?.version || '';
73
+ const match = version.match(/CockroachDB\s+\w+\s+(v[\d.]+)/i);
74
+ return match ? match[1] : version;
75
+ }
76
+ finally {
77
+ await pool.end();
78
+ }
79
+ }
80
+ generateCreateTable(table, options) {
81
+ return super.generateCreateTable(table, options);
82
+ }
83
+ }
84
+ exports.CockroachDBAdapter = CockroachDBAdapter;
@@ -0,0 +1,149 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validateSqlForCockroachDB = validateSqlForCockroachDB;
4
+ exports.validateSchemaForCockroachDB = validateSchemaForCockroachDB;
5
+ exports.validateTableForCockroachDB = validateTableForCockroachDB;
6
+ exports.getAlternativeType = getAlternativeType;
7
+ exports.isTypeSupported = isTypeSupported;
8
+ const features_1 = require("./features.cjs");
9
+ function validateSqlForCockroachDB(sql) {
10
+ const issues = [];
11
+ for (const typeCheck of features_1.UNSUPPORTED_DATA_TYPES) {
12
+ if (typeCheck.pattern.test(sql)) {
13
+ issues.push({
14
+ severity: 'error',
15
+ category: 'DATA_TYPE',
16
+ feature: typeCheck.name,
17
+ message: `Data type '${typeCheck.name}' is not supported in CockroachDB`,
18
+ alternative: typeCheck.alternative,
19
+ });
20
+ }
21
+ }
22
+ for (const feature of features_1.UNSUPPORTED_SQL_FEATURES) {
23
+ if (feature.pattern.test(sql)) {
24
+ issues.push({
25
+ severity: feature.severity,
26
+ category: 'FEATURE',
27
+ feature: feature.name,
28
+ message: `'${feature.name}' is not supported in CockroachDB`,
29
+ alternative: feature.alternative,
30
+ });
31
+ }
32
+ }
33
+ if (/\bCREATE\s+(OR\s+REPLACE\s+)?FUNCTION\b/i.test(sql)) {
34
+ for (const limitation of features_1.PLPGSQL_LIMITATIONS) {
35
+ if (limitation.pattern.test(sql)) {
36
+ issues.push({
37
+ severity: 'error',
38
+ category: 'SYNTAX',
39
+ feature: limitation.name,
40
+ message: `PL/pgSQL feature '${limitation.name}' is not supported in CockroachDB`,
41
+ alternative: limitation.alternative,
42
+ });
43
+ }
44
+ }
45
+ }
46
+ const errors = issues.filter(i => i.severity === 'error').length;
47
+ const warnings = issues.filter(i => i.severity === 'warning').length;
48
+ const info = issues.filter(i => i.severity === 'info').length;
49
+ return {
50
+ valid: errors === 0,
51
+ issues,
52
+ summary: { errors, warnings, info },
53
+ };
54
+ }
55
+ function validateSchemaForCockroachDB(schema) {
56
+ const issues = [];
57
+ for (const table of schema.tables) {
58
+ const tableResult = validateTableForCockroachDB(table);
59
+ issues.push(...tableResult.issues);
60
+ }
61
+ const errors = issues.filter(i => i.severity === 'error').length;
62
+ const warnings = issues.filter(i => i.severity === 'warning').length;
63
+ const info = issues.filter(i => i.severity === 'info').length;
64
+ return {
65
+ valid: errors === 0,
66
+ issues,
67
+ summary: { errors, warnings, info },
68
+ };
69
+ }
70
+ function validateTableForCockroachDB(table) {
71
+ const issues = [];
72
+ for (const column of table.columns) {
73
+ const typeCheck = checkColumnType(column.type);
74
+ if (typeCheck) {
75
+ issues.push({
76
+ severity: 'error',
77
+ category: 'DATA_TYPE',
78
+ feature: typeCheck.name,
79
+ location: `${table.schema}.${table.name}.${column.name}`,
80
+ message: `Column uses unsupported type '${typeCheck.name}'`,
81
+ alternative: typeCheck.alternative,
82
+ });
83
+ }
84
+ }
85
+ const hasSerialPK = table.columns.some(c => c.isPrimaryKey && (c.type === 'serial' || c.type === 'bigserial' || c.isAutoIncrement));
86
+ if (hasSerialPK) {
87
+ issues.push({
88
+ severity: 'warning',
89
+ category: 'PERFORMANCE',
90
+ feature: 'SERIAL Primary Key',
91
+ location: `${table.schema}.${table.name}`,
92
+ message: 'SERIAL primary key may not distribute well in CockroachDB',
93
+ alternative: 'Consider UUID with gen_random_uuid() for better distribution',
94
+ });
95
+ }
96
+ const errors = issues.filter(i => i.severity === 'error').length;
97
+ const warnings = issues.filter(i => i.severity === 'warning').length;
98
+ const info = issues.filter(i => i.severity === 'info').length;
99
+ return {
100
+ valid: errors === 0,
101
+ issues,
102
+ summary: { errors, warnings, info },
103
+ };
104
+ }
105
+ function checkColumnType(type) {
106
+ const upperType = type.toUpperCase();
107
+ for (const typeCheck of features_1.UNSUPPORTED_DATA_TYPES) {
108
+ if (typeCheck.pattern.test(upperType)) {
109
+ return {
110
+ name: typeCheck.name,
111
+ alternative: typeCheck.alternative,
112
+ };
113
+ }
114
+ }
115
+ return null;
116
+ }
117
+ function getAlternativeType(type) {
118
+ const upperType = type.toUpperCase();
119
+ const typeMap = {
120
+ 'MONEY': 'NUMERIC(19,4)',
121
+ 'XML': 'TEXT',
122
+ 'POINT': 'GEOMETRY',
123
+ 'LINE': 'TEXT',
124
+ 'LSEG': 'TEXT',
125
+ 'BOX': 'TEXT',
126
+ 'PATH': 'TEXT',
127
+ 'POLYGON': 'GEOMETRY',
128
+ 'CIRCLE': 'TEXT',
129
+ 'INT4RANGE': 'JSONB',
130
+ 'INT8RANGE': 'JSONB',
131
+ 'NUMRANGE': 'JSONB',
132
+ 'TSRANGE': 'JSONB',
133
+ 'TSTZRANGE': 'JSONB',
134
+ 'DATERANGE': 'JSONB',
135
+ 'TSVECTOR': 'TEXT',
136
+ 'TSQUERY': 'TEXT',
137
+ 'CIDR': 'INET',
138
+ 'MACADDR': 'VARCHAR(17)',
139
+ 'MACADDR8': 'VARCHAR(23)',
140
+ 'OID': 'BIGINT',
141
+ 'REGCLASS': 'TEXT',
142
+ 'REGPROC': 'TEXT',
143
+ 'REGTYPE': 'TEXT',
144
+ };
145
+ return typeMap[upperType] || type;
146
+ }
147
+ function isTypeSupported(type) {
148
+ return checkColumnType(type) === null;
149
+ }
@@ -0,0 +1,133 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DSQL_ALTERNATIVES = exports.UNSUPPORTED_SQL_OPERATIONS = exports.UNSUPPORTED_COLUMN_TYPES = exports.DSQL_TRANSACTION_LIMITS = exports.DSQL_FEATURES = void 0;
4
+ exports.DSQL_FEATURES = {
5
+ supportsJson: false,
6
+ supportsJsonb: false,
7
+ supportsArrays: false,
8
+ supportsEnums: true,
9
+ supportsUuid: true,
10
+ supportsSerial: false,
11
+ supportsIdentity: false,
12
+ supportsBigint: true,
13
+ supportsDecimal: true,
14
+ supportsGeometry: false,
15
+ supportsTimestampTz: true,
16
+ supportsInterval: true,
17
+ supportsRangeTypes: false,
18
+ supportsCompositeTypes: false,
19
+ supportsNetworkTypes: false,
20
+ supportsFullTextSearch: false,
21
+ supportsDeferrableConstraints: false,
22
+ supportsExcludeConstraints: false,
23
+ supportsGeneratedColumns: true,
24
+ supportsPartialIndexes: true,
25
+ supportsCoveringIndexes: true,
26
+ supportsBtreeIndex: true,
27
+ supportsHashIndex: true,
28
+ supportsGistIndex: false,
29
+ supportsGinIndex: false,
30
+ supportsBrinIndex: false,
31
+ supportsSpGistIndex: false,
32
+ supportsSchemas: true,
33
+ supportsTablePartitioning: false,
34
+ supportsTableInheritance: false,
35
+ supportsMaterializedViews: true,
36
+ supportsForeignTables: false,
37
+ supportsTriggers: false,
38
+ supportsStoredProcedures: false,
39
+ supportsSequences: false,
40
+ supportsDomains: true,
41
+ supportsTransactions: true,
42
+ supportsSavepoints: true,
43
+ supportsIsolationLevels: false,
44
+ supportsReadOnlyTransactions: true,
45
+ supportsWindowFunctions: true,
46
+ supportsCTE: true,
47
+ supportsRecursiveCTE: true,
48
+ supportsLateralJoin: true,
49
+ supportsReturning: true,
50
+ supportsOnConflict: true,
51
+ supportsDistinctOn: true,
52
+ supportsGroupingSets: true,
53
+ supportsFilter: true,
54
+ supportsListenNotify: false,
55
+ supportsLogicalReplication: false,
56
+ supportsComments: true,
57
+ supportsExtensions: false,
58
+ supportsCopyCommand: true,
59
+ };
60
+ exports.DSQL_TRANSACTION_LIMITS = {
61
+ maxRowsPerTransaction: 3000,
62
+ connectionTimeoutHours: 1,
63
+ maxDdlPerTransaction: 1,
64
+ isolationLevel: 'REPEATABLE READ',
65
+ };
66
+ exports.UNSUPPORTED_COLUMN_TYPES = [
67
+ 'SERIAL',
68
+ 'BIGSERIAL',
69
+ 'SMALLSERIAL',
70
+ 'JSON',
71
+ 'JSONB',
72
+ 'XML',
73
+ 'POINT',
74
+ 'LINE',
75
+ 'LSEG',
76
+ 'BOX',
77
+ 'PATH',
78
+ 'POLYGON',
79
+ 'CIRCLE',
80
+ 'INT4RANGE',
81
+ 'INT8RANGE',
82
+ 'NUMRANGE',
83
+ 'TSRANGE',
84
+ 'TSTZRANGE',
85
+ 'DATERANGE',
86
+ 'BIT',
87
+ 'VARBIT',
88
+ 'BIT VARYING',
89
+ 'CIDR',
90
+ 'MACADDR',
91
+ 'MACADDR8',
92
+ 'MONEY',
93
+ 'OID',
94
+ 'REGPROC',
95
+ 'REGCLASS',
96
+ 'REGTYPE',
97
+ 'TSVECTOR',
98
+ 'TSQUERY',
99
+ ];
100
+ exports.UNSUPPORTED_SQL_OPERATIONS = [
101
+ 'CREATE TRIGGER',
102
+ 'DROP TRIGGER',
103
+ 'CREATE SEQUENCE',
104
+ 'CREATE EXTENSION',
105
+ 'CREATE RULE',
106
+ 'TRUNCATE',
107
+ 'VACUUM',
108
+ 'ALTER SYSTEM',
109
+ 'LISTEN',
110
+ 'NOTIFY',
111
+ 'CREATE PUBLICATION',
112
+ 'CREATE SUBSCRIPTION',
113
+ 'DO $$',
114
+ 'LANGUAGE plpgsql',
115
+ 'LANGUAGE plpython',
116
+ 'LANGUAGE plperl',
117
+ ];
118
+ exports.DSQL_ALTERNATIVES = {
119
+ 'SERIAL': 'UUID PRIMARY KEY DEFAULT gen_random_uuid()',
120
+ 'BIGSERIAL': 'UUID PRIMARY KEY DEFAULT gen_random_uuid()',
121
+ 'SMALLSERIAL': 'UUID PRIMARY KEY DEFAULT gen_random_uuid()',
122
+ 'JSON': 'TEXT (cast to JSON at runtime: data::json)',
123
+ 'JSONB': 'TEXT (cast to JSONB at runtime: data::jsonb)',
124
+ 'ARRAY': 'TEXT (store as JSON string) or normalize to separate table',
125
+ 'triggers': 'Application code or AWS Lambda/EventBridge',
126
+ 'sequences': 'UUID with gen_random_uuid()',
127
+ 'plpgsql': 'LANGUAGE SQL functions or Lambda',
128
+ 'foreign_keys': 'Application-level referential integrity (JOINs still work)',
129
+ 'listen_notify': 'AWS SNS, SQS, or EventBridge',
130
+ 'extensions': 'Built-in functions only',
131
+ 'truncate': 'DELETE FROM table_name',
132
+ 'temp_tables': 'CTEs (WITH clause) or regular tables with session-specific names',
133
+ };
@@ -0,0 +1,135 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.DSQL_TRANSACTION_LIMITS = exports.DSQL_FEATURES = exports.DsqlAdapter = void 0;
37
+ const index_1 = require("../postgres/index.cjs");
38
+ const features_1 = require("./features.cjs");
39
+ const validator_1 = require("./validator.cjs");
40
+ class DsqlAdapter extends index_1.PostgresAdapter {
41
+ dialect = 'dsql';
42
+ displayName = 'AWS Aurora DSQL';
43
+ features = features_1.DSQL_FEATURES;
44
+ getTransactionLimits() {
45
+ return features_1.DSQL_TRANSACTION_LIMITS;
46
+ }
47
+ validate(schema) {
48
+ return (0, validator_1.validateSchemaForDsql)(schema);
49
+ }
50
+ validateTable(table) {
51
+ const issues = (0, validator_1.validateTableForDsql)(table);
52
+ const errors = issues.filter(i => i.severity === 'error').length;
53
+ const warnings = issues.filter(i => i.severity === 'warning').length;
54
+ const info = issues.filter(i => i.severity === 'info').length;
55
+ return {
56
+ valid: errors === 0,
57
+ issues,
58
+ summary: { errors, warnings, info },
59
+ };
60
+ }
61
+ validateSql(sql) {
62
+ return (0, validator_1.validateSqlForDsql)(sql);
63
+ }
64
+ isTypeSupported(type) {
65
+ return (0, validator_1.isTypeSupported)(type);
66
+ }
67
+ getAlternative(feature) {
68
+ return (0, validator_1.getAlternative)(feature);
69
+ }
70
+ getAlternativeType(type) {
71
+ return (0, validator_1.getAlternativeType)(type);
72
+ }
73
+ async testConnection(connection) {
74
+ const pgConfig = connection;
75
+ try {
76
+ const { Pool } = await Promise.resolve().then(() => __importStar(require("../../../addon/pg/index.cjs")));
77
+ const { buildPoolConfig } = await Promise.resolve().then(() => __importStar(require("../../../config/config.cjs")));
78
+ const poolConfig = await buildPoolConfig({
79
+ url: pgConfig.url,
80
+ host: pgConfig.host,
81
+ port: pgConfig.port,
82
+ database: pgConfig.database,
83
+ user: pgConfig.user,
84
+ password: pgConfig.password,
85
+ ssl: pgConfig.ssl,
86
+ aws: pgConfig.aws,
87
+ });
88
+ const pool = new Pool({ ...poolConfig, max: 1 });
89
+ try {
90
+ const client = await pool.connect();
91
+ await client.query('SELECT 1');
92
+ client.release();
93
+ return true;
94
+ }
95
+ finally {
96
+ await pool.end();
97
+ }
98
+ }
99
+ catch (error) {
100
+ return false;
101
+ }
102
+ }
103
+ async getDatabaseVersion(connection) {
104
+ const { Pool } = await Promise.resolve().then(() => __importStar(require("../../../addon/pg/index.cjs")));
105
+ const { buildPoolConfig } = await Promise.resolve().then(() => __importStar(require("../../../config/config.cjs")));
106
+ const config = connection;
107
+ const poolConfig = await buildPoolConfig({
108
+ url: config.url,
109
+ host: config.host,
110
+ port: config.port,
111
+ database: config.database,
112
+ user: config.user,
113
+ password: config.password,
114
+ ssl: config.ssl,
115
+ aws: config.aws,
116
+ });
117
+ const pool = new Pool({ ...poolConfig, max: 1 });
118
+ try {
119
+ const result = await pool.query('SHOW server_version');
120
+ const version = result.rows[0]?.server_version || 'unknown';
121
+ return `Aurora DSQL (PostgreSQL ${version})`;
122
+ }
123
+ finally {
124
+ await pool.end();
125
+ }
126
+ }
127
+ async introspect(connection, options) {
128
+ const schema = await super.introspect(connection, options);
129
+ return schema;
130
+ }
131
+ }
132
+ exports.DsqlAdapter = DsqlAdapter;
133
+ var features_2 = require("./features.cjs");
134
+ Object.defineProperty(exports, "DSQL_FEATURES", { enumerable: true, get: function () { return features_2.DSQL_FEATURES; } });
135
+ Object.defineProperty(exports, "DSQL_TRANSACTION_LIMITS", { enumerable: true, get: function () { return features_2.DSQL_TRANSACTION_LIMITS; } });