drizzle-orm 0.43.1-9811cd4 → 0.43.1-d1468f0

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 (839) hide show
  1. package/aws-data-api/pg/driver.cjs +5 -1
  2. package/aws-data-api/pg/driver.cjs.map +1 -1
  3. package/aws-data-api/pg/driver.d.cts +1 -0
  4. package/aws-data-api/pg/driver.d.ts +1 -0
  5. package/aws-data-api/pg/driver.js +5 -1
  6. package/aws-data-api/pg/driver.js.map +1 -1
  7. package/aws-data-api/pg/session.cjs +15 -4
  8. package/aws-data-api/pg/session.cjs.map +1 -1
  9. package/aws-data-api/pg/session.d.cts +13 -2
  10. package/aws-data-api/pg/session.d.ts +13 -2
  11. package/aws-data-api/pg/session.js +15 -4
  12. package/aws-data-api/pg/session.js.map +1 -1
  13. package/better-sqlite3/driver.cjs.map +1 -1
  14. package/better-sqlite3/driver.js.map +1 -1
  15. package/better-sqlite3/session.cjs +9 -3
  16. package/better-sqlite3/session.cjs.map +1 -1
  17. package/better-sqlite3/session.d.cts +12 -2
  18. package/better-sqlite3/session.d.ts +12 -2
  19. package/better-sqlite3/session.js +9 -3
  20. package/better-sqlite3/session.js.map +1 -1
  21. package/bun-sql/driver.cjs +5 -1
  22. package/bun-sql/driver.cjs.map +1 -1
  23. package/bun-sql/driver.js +5 -1
  24. package/bun-sql/driver.js.map +1 -1
  25. package/bun-sql/session.cjs +21 -9
  26. package/bun-sql/session.cjs.map +1 -1
  27. package/bun-sql/session.d.cts +12 -2
  28. package/bun-sql/session.d.ts +12 -2
  29. package/bun-sql/session.js +21 -9
  30. package/bun-sql/session.js.map +1 -1
  31. package/{mssql-core/columns/date.common.cjs → cache/core/cache.cjs} +22 -12
  32. package/cache/core/cache.cjs.map +1 -0
  33. package/cache/core/cache.d.cts +35 -0
  34. package/cache/core/cache.d.ts +35 -0
  35. package/cache/core/cache.js +22 -0
  36. package/cache/core/cache.js.map +1 -0
  37. package/{node-mssql → cache/core}/index.cjs +4 -6
  38. package/cache/core/index.cjs.map +1 -0
  39. package/cache/core/index.d.cts +1 -0
  40. package/cache/core/index.d.ts +1 -0
  41. package/cache/core/index.js +2 -0
  42. package/cache/core/index.js.map +1 -0
  43. package/{mssql-core/subquery.cjs → cache/core/types.cjs} +3 -3
  44. package/cache/core/types.cjs.map +1 -0
  45. package/cache/core/types.d.cts +33 -0
  46. package/cache/core/types.d.ts +33 -0
  47. package/cache/core/types.js +1 -0
  48. package/cache/upstash/cache.cjs +191 -0
  49. package/cache/upstash/cache.cjs.map +1 -0
  50. package/cache/upstash/cache.d.cts +59 -0
  51. package/cache/upstash/cache.d.ts +59 -0
  52. package/cache/upstash/cache.js +166 -0
  53. package/cache/upstash/cache.js.map +1 -0
  54. package/{mssql-core/view-common.cjs → cache/upstash/index.cjs} +6 -12
  55. package/cache/upstash/index.cjs.map +1 -0
  56. package/cache/upstash/index.d.cts +1 -0
  57. package/cache/upstash/index.d.ts +1 -0
  58. package/cache/upstash/index.js +2 -0
  59. package/cache/upstash/index.js.map +1 -0
  60. package/column-builder.cjs.map +1 -1
  61. package/column-builder.d.cts +4 -6
  62. package/column-builder.d.ts +4 -6
  63. package/column-builder.js.map +1 -1
  64. package/column.cjs +0 -2
  65. package/column.cjs.map +1 -1
  66. package/column.d.cts +0 -1
  67. package/column.d.ts +0 -1
  68. package/column.js +0 -2
  69. package/column.js.map +1 -1
  70. package/d1/driver.cjs +5 -1
  71. package/d1/driver.cjs.map +1 -1
  72. package/d1/driver.js +5 -1
  73. package/d1/driver.js.map +1 -1
  74. package/d1/session.cjs +23 -9
  75. package/d1/session.cjs.map +1 -1
  76. package/d1/session.d.cts +12 -2
  77. package/d1/session.d.ts +12 -2
  78. package/d1/session.js +23 -9
  79. package/d1/session.js.map +1 -1
  80. package/durable-sqlite/session.cjs +1 -1
  81. package/durable-sqlite/session.cjs.map +1 -1
  82. package/durable-sqlite/session.js +1 -1
  83. package/durable-sqlite/session.js.map +1 -1
  84. package/{mssql-core/alias.cjs → errors/index.cjs} +17 -9
  85. package/errors/index.cjs.map +1 -0
  86. package/errors/index.d.cts +6 -0
  87. package/errors/index.d.ts +6 -0
  88. package/errors/index.js +16 -0
  89. package/errors/index.js.map +1 -0
  90. package/gel/driver.cjs +9 -2
  91. package/gel/driver.cjs.map +1 -1
  92. package/gel/driver.d.cts +2 -0
  93. package/gel/driver.d.ts +2 -0
  94. package/gel/driver.js +9 -2
  95. package/gel/driver.js.map +1 -1
  96. package/gel/session.cjs +25 -10
  97. package/gel/session.cjs.map +1 -1
  98. package/gel/session.d.cts +12 -2
  99. package/gel/session.d.ts +12 -2
  100. package/gel/session.js +25 -10
  101. package/gel/session.js.map +1 -1
  102. package/gel-core/db.cjs +3 -0
  103. package/gel-core/db.cjs.map +1 -1
  104. package/gel-core/db.d.cts +4 -0
  105. package/gel-core/db.d.ts +4 -0
  106. package/gel-core/db.js +3 -0
  107. package/gel-core/db.js.map +1 -1
  108. package/gel-core/query-builders/delete.cjs +5 -1
  109. package/gel-core/query-builders/delete.cjs.map +1 -1
  110. package/gel-core/query-builders/delete.js +5 -1
  111. package/gel-core/query-builders/delete.js.map +1 -1
  112. package/gel-core/query-builders/insert.cjs +5 -1
  113. package/gel-core/query-builders/insert.cjs.map +1 -1
  114. package/gel-core/query-builders/insert.js +5 -1
  115. package/gel-core/query-builders/insert.js.map +1 -1
  116. package/gel-core/query-builders/select.cjs +29 -4
  117. package/gel-core/query-builders/select.cjs.map +1 -1
  118. package/gel-core/query-builders/select.d.cts +9 -0
  119. package/gel-core/query-builders/select.d.ts +9 -0
  120. package/gel-core/query-builders/select.js +29 -4
  121. package/gel-core/query-builders/select.js.map +1 -1
  122. package/gel-core/query-builders/update.cjs +5 -1
  123. package/gel-core/query-builders/update.cjs.map +1 -1
  124. package/gel-core/query-builders/update.js +5 -1
  125. package/gel-core/query-builders/update.js.map +1 -1
  126. package/gel-core/session.cjs +79 -1
  127. package/gel-core/session.cjs.map +1 -1
  128. package/gel-core/session.d.cts +14 -3
  129. package/gel-core/session.d.ts +14 -3
  130. package/gel-core/session.js +80 -2
  131. package/gel-core/session.js.map +1 -1
  132. package/gel-core/utils.cjs +16 -0
  133. package/gel-core/utils.cjs.map +1 -1
  134. package/gel-core/utils.d.cts +8 -4
  135. package/gel-core/utils.d.ts +8 -4
  136. package/gel-core/utils.js +15 -0
  137. package/gel-core/utils.js.map +1 -1
  138. package/libsql/driver-core.cjs +5 -1
  139. package/libsql/driver-core.cjs.map +1 -1
  140. package/libsql/driver-core.js +5 -1
  141. package/libsql/driver-core.js.map +1 -1
  142. package/libsql/session.cjs +27 -13
  143. package/libsql/session.cjs.map +1 -1
  144. package/libsql/session.d.cts +12 -2
  145. package/libsql/session.d.ts +12 -2
  146. package/libsql/session.js +27 -13
  147. package/libsql/session.js.map +1 -1
  148. package/mysql-core/db.cjs +3 -0
  149. package/mysql-core/db.cjs.map +1 -1
  150. package/mysql-core/db.d.cts +4 -0
  151. package/mysql-core/db.d.ts +4 -0
  152. package/mysql-core/db.js +3 -0
  153. package/mysql-core/db.js.map +1 -1
  154. package/mysql-core/query-builders/delete.cjs +9 -1
  155. package/mysql-core/query-builders/delete.cjs.map +1 -1
  156. package/mysql-core/query-builders/delete.js +9 -1
  157. package/mysql-core/query-builders/delete.js.map +1 -1
  158. package/mysql-core/query-builders/insert.cjs +8 -1
  159. package/mysql-core/query-builders/insert.cjs.map +1 -1
  160. package/mysql-core/query-builders/insert.d.cts +2 -0
  161. package/mysql-core/query-builders/insert.d.ts +2 -0
  162. package/mysql-core/query-builders/insert.js +8 -1
  163. package/mysql-core/query-builders/insert.js.map +1 -1
  164. package/mysql-core/query-builders/select.cjs +27 -3
  165. package/mysql-core/query-builders/select.cjs.map +1 -1
  166. package/mysql-core/query-builders/select.d.cts +9 -0
  167. package/mysql-core/query-builders/select.d.ts +9 -0
  168. package/mysql-core/query-builders/select.js +28 -4
  169. package/mysql-core/query-builders/select.js.map +1 -1
  170. package/mysql-core/query-builders/update.cjs +11 -1
  171. package/mysql-core/query-builders/update.cjs.map +1 -1
  172. package/mysql-core/query-builders/update.d.cts +2 -0
  173. package/mysql-core/query-builders/update.d.ts +2 -0
  174. package/mysql-core/query-builders/update.js +11 -1
  175. package/mysql-core/query-builders/update.js.map +1 -1
  176. package/mysql-core/session.cjs +80 -0
  177. package/mysql-core/session.cjs.map +1 -1
  178. package/mysql-core/session.d.cts +15 -2
  179. package/mysql-core/session.d.ts +15 -2
  180. package/mysql-core/session.js +81 -1
  181. package/mysql-core/session.js.map +1 -1
  182. package/mysql-core/utils.cjs +16 -0
  183. package/mysql-core/utils.cjs.map +1 -1
  184. package/mysql-core/utils.d.cts +6 -2
  185. package/mysql-core/utils.d.ts +6 -2
  186. package/mysql-core/utils.js +15 -0
  187. package/mysql-core/utils.js.map +1 -1
  188. package/mysql-proxy/session.cjs +15 -5
  189. package/mysql-proxy/session.cjs.map +1 -1
  190. package/mysql-proxy/session.d.cts +12 -2
  191. package/mysql-proxy/session.d.ts +12 -2
  192. package/mysql-proxy/session.js +15 -5
  193. package/mysql-proxy/session.js.map +1 -1
  194. package/mysql2/driver.cjs +10 -2
  195. package/mysql2/driver.cjs.map +1 -1
  196. package/mysql2/driver.d.cts +2 -0
  197. package/mysql2/driver.d.ts +2 -0
  198. package/mysql2/driver.js +10 -2
  199. package/mysql2/driver.js.map +1 -1
  200. package/mysql2/session.cjs +15 -5
  201. package/mysql2/session.cjs.map +1 -1
  202. package/mysql2/session.d.cts +12 -2
  203. package/mysql2/session.d.ts +12 -2
  204. package/mysql2/session.js +15 -5
  205. package/mysql2/session.js.map +1 -1
  206. package/neon-http/driver.cjs +9 -2
  207. package/neon-http/driver.cjs.map +1 -1
  208. package/neon-http/driver.d.cts +2 -0
  209. package/neon-http/driver.d.ts +2 -0
  210. package/neon-http/driver.js +9 -2
  211. package/neon-http/driver.js.map +1 -1
  212. package/neon-http/session.cjs +25 -15
  213. package/neon-http/session.cjs.map +1 -1
  214. package/neon-http/session.d.cts +12 -2
  215. package/neon-http/session.d.ts +12 -2
  216. package/neon-http/session.js +25 -15
  217. package/neon-http/session.js.map +1 -1
  218. package/neon-serverless/driver.cjs +9 -2
  219. package/neon-serverless/driver.cjs.map +1 -1
  220. package/neon-serverless/driver.d.cts +2 -0
  221. package/neon-serverless/driver.d.ts +2 -0
  222. package/neon-serverless/driver.js +9 -2
  223. package/neon-serverless/driver.js.map +1 -1
  224. package/neon-serverless/session.cjs +21 -7
  225. package/neon-serverless/session.cjs.map +1 -1
  226. package/neon-serverless/session.d.cts +12 -2
  227. package/neon-serverless/session.d.ts +12 -2
  228. package/neon-serverless/session.js +21 -7
  229. package/neon-serverless/session.js.map +1 -1
  230. package/node-postgres/driver.cjs +9 -2
  231. package/node-postgres/driver.cjs.map +1 -1
  232. package/node-postgres/driver.d.cts +2 -0
  233. package/node-postgres/driver.d.ts +2 -0
  234. package/node-postgres/driver.js +9 -2
  235. package/node-postgres/driver.js.map +1 -1
  236. package/node-postgres/session.cjs +19 -6
  237. package/node-postgres/session.cjs.map +1 -1
  238. package/node-postgres/session.d.cts +13 -2
  239. package/node-postgres/session.d.ts +13 -2
  240. package/node-postgres/session.js +19 -6
  241. package/node-postgres/session.js.map +1 -1
  242. package/op-sqlite/driver.cjs +5 -1
  243. package/op-sqlite/driver.cjs.map +1 -1
  244. package/op-sqlite/driver.js +5 -1
  245. package/op-sqlite/driver.js.map +1 -1
  246. package/op-sqlite/session.cjs +23 -9
  247. package/op-sqlite/session.cjs.map +1 -1
  248. package/op-sqlite/session.d.cts +12 -2
  249. package/op-sqlite/session.d.ts +12 -2
  250. package/op-sqlite/session.js +23 -9
  251. package/op-sqlite/session.js.map +1 -1
  252. package/package.json +75 -662
  253. package/pg-core/columns/common.cjs +10 -11
  254. package/pg-core/columns/common.cjs.map +1 -1
  255. package/pg-core/columns/common.d.cts +2 -3
  256. package/pg-core/columns/common.d.ts +2 -3
  257. package/pg-core/columns/common.js +10 -11
  258. package/pg-core/columns/common.js.map +1 -1
  259. package/pg-core/db.cjs +3 -0
  260. package/pg-core/db.cjs.map +1 -1
  261. package/pg-core/db.d.cts +4 -0
  262. package/pg-core/db.d.ts +4 -0
  263. package/pg-core/db.js +3 -0
  264. package/pg-core/db.js.map +1 -1
  265. package/pg-core/query-builders/delete.cjs +6 -1
  266. package/pg-core/query-builders/delete.cjs.map +1 -1
  267. package/pg-core/query-builders/delete.d.cts +3 -1
  268. package/pg-core/query-builders/delete.d.ts +3 -1
  269. package/pg-core/query-builders/delete.js +6 -1
  270. package/pg-core/query-builders/delete.js.map +1 -1
  271. package/pg-core/query-builders/insert.cjs +6 -1
  272. package/pg-core/query-builders/insert.cjs.map +1 -1
  273. package/pg-core/query-builders/insert.d.cts +2 -0
  274. package/pg-core/query-builders/insert.d.ts +2 -0
  275. package/pg-core/query-builders/insert.js +6 -1
  276. package/pg-core/query-builders/insert.js.map +1 -1
  277. package/pg-core/query-builders/select.cjs +31 -5
  278. package/pg-core/query-builders/select.cjs.map +1 -1
  279. package/pg-core/query-builders/select.d.cts +15 -6
  280. package/pg-core/query-builders/select.d.ts +15 -6
  281. package/pg-core/query-builders/select.js +31 -5
  282. package/pg-core/query-builders/select.js.map +1 -1
  283. package/pg-core/query-builders/update.cjs +6 -1
  284. package/pg-core/query-builders/update.cjs.map +1 -1
  285. package/pg-core/query-builders/update.d.cts +4 -2
  286. package/pg-core/query-builders/update.d.ts +4 -2
  287. package/pg-core/query-builders/update.js +6 -1
  288. package/pg-core/query-builders/update.js.map +1 -1
  289. package/pg-core/session.cjs +79 -1
  290. package/pg-core/session.cjs.map +1 -1
  291. package/pg-core/session.d.cts +14 -3
  292. package/pg-core/session.d.ts +14 -3
  293. package/pg-core/session.js +80 -2
  294. package/pg-core/session.js.map +1 -1
  295. package/pg-core/unique-constraint.cjs +1 -5
  296. package/pg-core/unique-constraint.cjs.map +1 -1
  297. package/pg-core/unique-constraint.d.cts +0 -2
  298. package/pg-core/unique-constraint.d.ts +0 -2
  299. package/pg-core/unique-constraint.js +1 -5
  300. package/pg-core/unique-constraint.js.map +1 -1
  301. package/pg-core/utils.cjs +16 -0
  302. package/pg-core/utils.cjs.map +1 -1
  303. package/pg-core/utils.d.cts +8 -4
  304. package/pg-core/utils.d.ts +8 -4
  305. package/pg-core/utils.js +16 -1
  306. package/pg-core/utils.js.map +1 -1
  307. package/pg-proxy/driver.cjs +7 -2
  308. package/pg-proxy/driver.cjs.map +1 -1
  309. package/pg-proxy/driver.js +7 -2
  310. package/pg-proxy/driver.js.map +1 -1
  311. package/pg-proxy/session.cjs +15 -5
  312. package/pg-proxy/session.cjs.map +1 -1
  313. package/pg-proxy/session.d.cts +12 -2
  314. package/pg-proxy/session.d.ts +12 -2
  315. package/pg-proxy/session.js +15 -5
  316. package/pg-proxy/session.js.map +1 -1
  317. package/pglite/driver.cjs +9 -2
  318. package/pglite/driver.cjs.map +1 -1
  319. package/pglite/driver.d.cts +2 -0
  320. package/pglite/driver.d.ts +2 -0
  321. package/pglite/driver.js +9 -2
  322. package/pglite/driver.js.map +1 -1
  323. package/pglite/session.cjs +19 -7
  324. package/pglite/session.cjs.map +1 -1
  325. package/pglite/session.d.cts +12 -2
  326. package/pglite/session.d.ts +12 -2
  327. package/pglite/session.js +19 -7
  328. package/pglite/session.js.map +1 -1
  329. package/planetscale-serverless/driver.cjs +5 -1
  330. package/planetscale-serverless/driver.cjs.map +1 -1
  331. package/planetscale-serverless/driver.d.cts +1 -0
  332. package/planetscale-serverless/driver.d.ts +1 -0
  333. package/planetscale-serverless/driver.js +5 -1
  334. package/planetscale-serverless/driver.js.map +1 -1
  335. package/planetscale-serverless/session.cjs +15 -5
  336. package/planetscale-serverless/session.cjs.map +1 -1
  337. package/planetscale-serverless/session.d.cts +12 -2
  338. package/planetscale-serverless/session.d.ts +12 -2
  339. package/planetscale-serverless/session.js +15 -5
  340. package/planetscale-serverless/session.js.map +1 -1
  341. package/postgres-js/driver.cjs +5 -1
  342. package/postgres-js/driver.cjs.map +1 -1
  343. package/postgres-js/driver.js +5 -1
  344. package/postgres-js/driver.js.map +1 -1
  345. package/postgres-js/session.cjs +18 -6
  346. package/postgres-js/session.cjs.map +1 -1
  347. package/postgres-js/session.d.cts +12 -2
  348. package/postgres-js/session.d.ts +12 -2
  349. package/postgres-js/session.js +18 -6
  350. package/postgres-js/session.js.map +1 -1
  351. package/prisma/mysql/session.cjs +1 -1
  352. package/prisma/mysql/session.cjs.map +1 -1
  353. package/prisma/mysql/session.js +1 -1
  354. package/prisma/mysql/session.js.map +1 -1
  355. package/prisma/pg/session.cjs +1 -1
  356. package/prisma/pg/session.cjs.map +1 -1
  357. package/prisma/pg/session.js +1 -1
  358. package/prisma/pg/session.js.map +1 -1
  359. package/query-builders/query-builder.cjs.map +1 -1
  360. package/query-builders/query-builder.d.cts +2 -1
  361. package/query-builders/query-builder.d.ts +2 -1
  362. package/query-builders/query-builder.js.map +1 -1
  363. package/relations.cjs +0 -48
  364. package/relations.cjs.map +1 -1
  365. package/relations.d.cts +0 -1
  366. package/relations.d.ts +0 -1
  367. package/relations.js +0 -47
  368. package/relations.js.map +1 -1
  369. package/singlestore/driver.cjs +12 -2
  370. package/singlestore/driver.cjs.map +1 -1
  371. package/singlestore/driver.d.cts +2 -0
  372. package/singlestore/driver.d.ts +2 -0
  373. package/singlestore/driver.js +12 -2
  374. package/singlestore/driver.js.map +1 -1
  375. package/singlestore/session.cjs +15 -5
  376. package/singlestore/session.cjs.map +1 -1
  377. package/singlestore/session.d.cts +12 -2
  378. package/singlestore/session.d.ts +12 -2
  379. package/singlestore/session.js +15 -5
  380. package/singlestore/session.js.map +1 -1
  381. package/singlestore-core/db.cjs +3 -0
  382. package/singlestore-core/db.cjs.map +1 -1
  383. package/singlestore-core/db.d.cts +4 -0
  384. package/singlestore-core/db.d.ts +4 -0
  385. package/singlestore-core/db.js +3 -0
  386. package/singlestore-core/db.js.map +1 -1
  387. package/singlestore-core/query-builders/delete.cjs +9 -1
  388. package/singlestore-core/query-builders/delete.cjs.map +1 -1
  389. package/singlestore-core/query-builders/delete.js +9 -1
  390. package/singlestore-core/query-builders/delete.js.map +1 -1
  391. package/singlestore-core/query-builders/insert.cjs +6 -1
  392. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  393. package/singlestore-core/query-builders/insert.js +6 -1
  394. package/singlestore-core/query-builders/insert.js.map +1 -1
  395. package/singlestore-core/query-builders/select.cjs +28 -3
  396. package/singlestore-core/query-builders/select.cjs.map +1 -1
  397. package/singlestore-core/query-builders/select.d.cts +9 -0
  398. package/singlestore-core/query-builders/select.d.ts +9 -0
  399. package/singlestore-core/query-builders/select.js +28 -3
  400. package/singlestore-core/query-builders/select.js.map +1 -1
  401. package/singlestore-core/query-builders/update.cjs +9 -1
  402. package/singlestore-core/query-builders/update.cjs.map +1 -1
  403. package/singlestore-core/query-builders/update.js +9 -1
  404. package/singlestore-core/query-builders/update.js.map +1 -1
  405. package/singlestore-core/session.cjs +80 -0
  406. package/singlestore-core/session.cjs.map +1 -1
  407. package/singlestore-core/session.d.cts +14 -2
  408. package/singlestore-core/session.d.ts +14 -2
  409. package/singlestore-core/session.js +81 -1
  410. package/singlestore-core/session.js.map +1 -1
  411. package/singlestore-core/utils.cjs +16 -0
  412. package/singlestore-core/utils.cjs.map +1 -1
  413. package/singlestore-core/utils.d.cts +3 -0
  414. package/singlestore-core/utils.d.ts +3 -0
  415. package/singlestore-core/utils.js +15 -0
  416. package/singlestore-core/utils.js.map +1 -1
  417. package/sql/sql.cjs +10 -0
  418. package/sql/sql.cjs.map +1 -1
  419. package/sql/sql.js +10 -0
  420. package/sql/sql.js.map +1 -1
  421. package/sqlite-core/db.cjs +3 -0
  422. package/sqlite-core/db.cjs.map +1 -1
  423. package/sqlite-core/db.d.cts +4 -0
  424. package/sqlite-core/db.d.ts +4 -0
  425. package/sqlite-core/db.js +3 -0
  426. package/sqlite-core/db.js.map +1 -1
  427. package/sqlite-core/query-builders/delete.cjs +7 -1
  428. package/sqlite-core/query-builders/delete.cjs.map +1 -1
  429. package/sqlite-core/query-builders/delete.js +7 -1
  430. package/sqlite-core/query-builders/delete.js.map +1 -1
  431. package/sqlite-core/query-builders/insert.cjs +7 -1
  432. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  433. package/sqlite-core/query-builders/insert.js +7 -1
  434. package/sqlite-core/query-builders/insert.js.map +1 -1
  435. package/sqlite-core/query-builders/select.cjs +31 -3
  436. package/sqlite-core/query-builders/select.cjs.map +1 -1
  437. package/sqlite-core/query-builders/select.d.cts +9 -0
  438. package/sqlite-core/query-builders/select.d.ts +9 -0
  439. package/sqlite-core/query-builders/select.js +31 -3
  440. package/sqlite-core/query-builders/select.js.map +1 -1
  441. package/sqlite-core/query-builders/update.cjs +7 -1
  442. package/sqlite-core/query-builders/update.cjs.map +1 -1
  443. package/sqlite-core/query-builders/update.js +7 -1
  444. package/sqlite-core/query-builders/update.js.map +1 -1
  445. package/sqlite-core/session.cjs +89 -3
  446. package/sqlite-core/session.cjs.map +1 -1
  447. package/sqlite-core/session.d.cts +18 -4
  448. package/sqlite-core/session.d.ts +18 -4
  449. package/sqlite-core/session.js +90 -4
  450. package/sqlite-core/session.js.map +1 -1
  451. package/sqlite-core/utils.cjs +16 -0
  452. package/sqlite-core/utils.cjs.map +1 -1
  453. package/sqlite-core/utils.d.cts +6 -2
  454. package/sqlite-core/utils.d.ts +6 -2
  455. package/sqlite-core/utils.js +15 -0
  456. package/sqlite-core/utils.js.map +1 -1
  457. package/sqlite-proxy/driver.cjs +9 -2
  458. package/sqlite-proxy/driver.cjs.map +1 -1
  459. package/sqlite-proxy/driver.js +9 -2
  460. package/sqlite-proxy/driver.js.map +1 -1
  461. package/sqlite-proxy/session.cjs +22 -8
  462. package/sqlite-proxy/session.cjs.map +1 -1
  463. package/sqlite-proxy/session.d.cts +12 -2
  464. package/sqlite-proxy/session.d.ts +12 -2
  465. package/sqlite-proxy/session.js +22 -8
  466. package/sqlite-proxy/session.js.map +1 -1
  467. package/subquery.cjs +4 -3
  468. package/subquery.cjs.map +1 -1
  469. package/subquery.d.cts +2 -1
  470. package/subquery.d.ts +2 -1
  471. package/subquery.js +4 -3
  472. package/subquery.js.map +1 -1
  473. package/tidb-serverless/driver.cjs +5 -1
  474. package/tidb-serverless/driver.cjs.map +1 -1
  475. package/tidb-serverless/driver.d.cts +1 -0
  476. package/tidb-serverless/driver.d.ts +1 -0
  477. package/tidb-serverless/driver.js +5 -1
  478. package/tidb-serverless/driver.js.map +1 -1
  479. package/tidb-serverless/session.cjs +15 -5
  480. package/tidb-serverless/session.cjs.map +1 -1
  481. package/tidb-serverless/session.d.cts +12 -2
  482. package/tidb-serverless/session.d.ts +12 -2
  483. package/tidb-serverless/session.js +15 -5
  484. package/tidb-serverless/session.js.map +1 -1
  485. package/utils.cjs +22 -0
  486. package/utils.cjs.map +1 -1
  487. package/utils.d.cts +3 -0
  488. package/utils.d.ts +3 -0
  489. package/utils.js +11 -0
  490. package/utils.js.map +1 -1
  491. package/vercel-postgres/driver.cjs +9 -2
  492. package/vercel-postgres/driver.cjs.map +1 -1
  493. package/vercel-postgres/driver.d.cts +2 -0
  494. package/vercel-postgres/driver.d.ts +2 -0
  495. package/vercel-postgres/driver.js +9 -2
  496. package/vercel-postgres/driver.js.map +1 -1
  497. package/vercel-postgres/session.cjs +21 -7
  498. package/vercel-postgres/session.cjs.map +1 -1
  499. package/vercel-postgres/session.d.cts +12 -2
  500. package/vercel-postgres/session.d.ts +12 -2
  501. package/vercel-postgres/session.js +21 -7
  502. package/vercel-postgres/session.js.map +1 -1
  503. package/version.cjs +2 -2
  504. package/version.cjs.map +1 -1
  505. package/version.d.cts +2 -2
  506. package/version.d.ts +2 -2
  507. package/version.js +2 -2
  508. package/version.js.map +1 -1
  509. package/xata-http/driver.cjs +7 -2
  510. package/xata-http/driver.cjs.map +1 -1
  511. package/xata-http/driver.d.cts +2 -0
  512. package/xata-http/driver.d.ts +2 -0
  513. package/xata-http/driver.js +7 -2
  514. package/xata-http/driver.js.map +1 -1
  515. package/xata-http/session.cjs +21 -7
  516. package/xata-http/session.cjs.map +1 -1
  517. package/xata-http/session.d.cts +12 -2
  518. package/xata-http/session.d.ts +12 -2
  519. package/xata-http/session.js +21 -7
  520. package/xata-http/session.js.map +1 -1
  521. package/mssql-core/alias.cjs.map +0 -1
  522. package/mssql-core/alias.d.cts +0 -4
  523. package/mssql-core/alias.d.ts +0 -4
  524. package/mssql-core/alias.js +0 -8
  525. package/mssql-core/alias.js.map +0 -1
  526. package/mssql-core/checks.cjs +0 -58
  527. package/mssql-core/checks.cjs.map +0 -1
  528. package/mssql-core/checks.d.cts +0 -18
  529. package/mssql-core/checks.d.ts +0 -18
  530. package/mssql-core/checks.js +0 -32
  531. package/mssql-core/checks.js.map +0 -1
  532. package/mssql-core/columns/all.cjs +0 -72
  533. package/mssql-core/columns/all.cjs.map +0 -1
  534. package/mssql-core/columns/all.d.cts +0 -43
  535. package/mssql-core/columns/all.d.ts +0 -43
  536. package/mssql-core/columns/all.js +0 -48
  537. package/mssql-core/columns/all.js.map +0 -1
  538. package/mssql-core/columns/bigint.cjs +0 -67
  539. package/mssql-core/columns/bigint.cjs.map +0 -1
  540. package/mssql-core/columns/bigint.d.cts +0 -33
  541. package/mssql-core/columns/bigint.d.ts +0 -33
  542. package/mssql-core/columns/bigint.js +0 -41
  543. package/mssql-core/columns/bigint.js.map +0 -1
  544. package/mssql-core/columns/binary.cjs +0 -57
  545. package/mssql-core/columns/binary.cjs.map +0 -1
  546. package/mssql-core/columns/binary.d.cts +0 -28
  547. package/mssql-core/columns/binary.d.ts +0 -28
  548. package/mssql-core/columns/binary.js +0 -31
  549. package/mssql-core/columns/binary.js.map +0 -1
  550. package/mssql-core/columns/bit.cjs +0 -54
  551. package/mssql-core/columns/bit.cjs.map +0 -1
  552. package/mssql-core/columns/bit.d.cts +0 -24
  553. package/mssql-core/columns/bit.d.ts +0 -24
  554. package/mssql-core/columns/bit.js +0 -28
  555. package/mssql-core/columns/bit.js.map +0 -1
  556. package/mssql-core/columns/char.cjs +0 -74
  557. package/mssql-core/columns/char.cjs.map +0 -1
  558. package/mssql-core/columns/char.d.cts +0 -37
  559. package/mssql-core/columns/char.d.ts +0 -37
  560. package/mssql-core/columns/char.js +0 -47
  561. package/mssql-core/columns/char.js.map +0 -1
  562. package/mssql-core/columns/common.cjs +0 -110
  563. package/mssql-core/columns/common.cjs.map +0 -1
  564. package/mssql-core/columns/common.d.cts +0 -67
  565. package/mssql-core/columns/common.d.ts +0 -67
  566. package/mssql-core/columns/common.js +0 -83
  567. package/mssql-core/columns/common.js.map +0 -1
  568. package/mssql-core/columns/custom.cjs +0 -75
  569. package/mssql-core/columns/custom.cjs.map +0 -1
  570. package/mssql-core/columns/custom.d.cts +0 -149
  571. package/mssql-core/columns/custom.d.ts +0 -149
  572. package/mssql-core/columns/custom.js +0 -49
  573. package/mssql-core/columns/custom.js.map +0 -1
  574. package/mssql-core/columns/date.cjs +0 -94
  575. package/mssql-core/columns/date.cjs.map +0 -1
  576. package/mssql-core/columns/date.common.cjs.map +0 -1
  577. package/mssql-core/columns/date.common.d.cts +0 -12
  578. package/mssql-core/columns/date.common.d.ts +0 -12
  579. package/mssql-core/columns/date.common.js +0 -13
  580. package/mssql-core/columns/date.common.js.map +0 -1
  581. package/mssql-core/columns/date.d.cts +0 -55
  582. package/mssql-core/columns/date.d.ts +0 -55
  583. package/mssql-core/columns/date.js +0 -66
  584. package/mssql-core/columns/date.js.map +0 -1
  585. package/mssql-core/columns/datetime.cjs +0 -94
  586. package/mssql-core/columns/datetime.cjs.map +0 -1
  587. package/mssql-core/columns/datetime.d.cts +0 -54
  588. package/mssql-core/columns/datetime.d.ts +0 -54
  589. package/mssql-core/columns/datetime.js +0 -66
  590. package/mssql-core/columns/datetime.js.map +0 -1
  591. package/mssql-core/columns/datetime2.cjs +0 -102
  592. package/mssql-core/columns/datetime2.cjs.map +0 -1
  593. package/mssql-core/columns/datetime2.d.cts +0 -54
  594. package/mssql-core/columns/datetime2.d.ts +0 -54
  595. package/mssql-core/columns/datetime2.js +0 -74
  596. package/mssql-core/columns/datetime2.js.map +0 -1
  597. package/mssql-core/columns/datetimeoffset.cjs +0 -102
  598. package/mssql-core/columns/datetimeoffset.cjs.map +0 -1
  599. package/mssql-core/columns/datetimeoffset.d.cts +0 -54
  600. package/mssql-core/columns/datetimeoffset.d.ts +0 -54
  601. package/mssql-core/columns/datetimeoffset.js +0 -74
  602. package/mssql-core/columns/datetimeoffset.js.map +0 -1
  603. package/mssql-core/columns/decimal.cjs +0 -68
  604. package/mssql-core/columns/decimal.cjs.map +0 -1
  605. package/mssql-core/columns/decimal.d.cts +0 -30
  606. package/mssql-core/columns/decimal.d.ts +0 -30
  607. package/mssql-core/columns/decimal.js +0 -42
  608. package/mssql-core/columns/decimal.js.map +0 -1
  609. package/mssql-core/columns/float.cjs +0 -58
  610. package/mssql-core/columns/float.cjs.map +0 -1
  611. package/mssql-core/columns/float.d.cts +0 -28
  612. package/mssql-core/columns/float.d.ts +0 -28
  613. package/mssql-core/columns/float.js +0 -32
  614. package/mssql-core/columns/float.js.map +0 -1
  615. package/mssql-core/columns/index.cjs +0 -63
  616. package/mssql-core/columns/index.cjs.map +0 -1
  617. package/mssql-core/columns/index.d.cts +0 -21
  618. package/mssql-core/columns/index.d.ts +0 -21
  619. package/mssql-core/columns/index.js +0 -22
  620. package/mssql-core/columns/index.js.map +0 -1
  621. package/mssql-core/columns/int.cjs +0 -53
  622. package/mssql-core/columns/int.cjs.map +0 -1
  623. package/mssql-core/columns/int.d.cts +0 -23
  624. package/mssql-core/columns/int.d.ts +0 -23
  625. package/mssql-core/columns/int.js +0 -27
  626. package/mssql-core/columns/int.js.map +0 -1
  627. package/mssql-core/columns/numeric.cjs +0 -68
  628. package/mssql-core/columns/numeric.cjs.map +0 -1
  629. package/mssql-core/columns/numeric.d.cts +0 -27
  630. package/mssql-core/columns/numeric.d.ts +0 -27
  631. package/mssql-core/columns/numeric.js +0 -42
  632. package/mssql-core/columns/numeric.js.map +0 -1
  633. package/mssql-core/columns/real.cjs +0 -53
  634. package/mssql-core/columns/real.cjs.map +0 -1
  635. package/mssql-core/columns/real.d.cts +0 -23
  636. package/mssql-core/columns/real.d.ts +0 -23
  637. package/mssql-core/columns/real.js +0 -27
  638. package/mssql-core/columns/real.js.map +0 -1
  639. package/mssql-core/columns/smallint.cjs +0 -62
  640. package/mssql-core/columns/smallint.cjs.map +0 -1
  641. package/mssql-core/columns/smallint.d.cts +0 -24
  642. package/mssql-core/columns/smallint.d.ts +0 -24
  643. package/mssql-core/columns/smallint.js +0 -36
  644. package/mssql-core/columns/smallint.js.map +0 -1
  645. package/mssql-core/columns/text.cjs +0 -68
  646. package/mssql-core/columns/text.cjs.map +0 -1
  647. package/mssql-core/columns/text.d.cts +0 -45
  648. package/mssql-core/columns/text.d.ts +0 -45
  649. package/mssql-core/columns/text.js +0 -41
  650. package/mssql-core/columns/text.js.map +0 -1
  651. package/mssql-core/columns/time.cjs +0 -90
  652. package/mssql-core/columns/time.cjs.map +0 -1
  653. package/mssql-core/columns/time.d.cts +0 -49
  654. package/mssql-core/columns/time.d.ts +0 -49
  655. package/mssql-core/columns/time.js +0 -62
  656. package/mssql-core/columns/time.js.map +0 -1
  657. package/mssql-core/columns/tinyint.cjs +0 -62
  658. package/mssql-core/columns/tinyint.cjs.map +0 -1
  659. package/mssql-core/columns/tinyint.d.cts +0 -24
  660. package/mssql-core/columns/tinyint.d.ts +0 -24
  661. package/mssql-core/columns/tinyint.js +0 -36
  662. package/mssql-core/columns/tinyint.js.map +0 -1
  663. package/mssql-core/columns/varbinary.cjs +0 -61
  664. package/mssql-core/columns/varbinary.cjs.map +0 -1
  665. package/mssql-core/columns/varbinary.d.cts +0 -27
  666. package/mssql-core/columns/varbinary.d.ts +0 -27
  667. package/mssql-core/columns/varbinary.js +0 -35
  668. package/mssql-core/columns/varbinary.js.map +0 -1
  669. package/mssql-core/columns/varchar.cjs +0 -117
  670. package/mssql-core/columns/varchar.cjs.map +0 -1
  671. package/mssql-core/columns/varchar.d.cts +0 -66
  672. package/mssql-core/columns/varchar.d.ts +0 -66
  673. package/mssql-core/columns/varchar.js +0 -88
  674. package/mssql-core/columns/varchar.js.map +0 -1
  675. package/mssql-core/db.cjs +0 -254
  676. package/mssql-core/db.cjs.map +0 -1
  677. package/mssql-core/db.d.cts +0 -228
  678. package/mssql-core/db.d.ts +0 -228
  679. package/mssql-core/db.js +0 -235
  680. package/mssql-core/db.js.map +0 -1
  681. package/mssql-core/dialect.cjs +0 -611
  682. package/mssql-core/dialect.cjs.map +0 -1
  683. package/mssql-core/dialect.d.cts +0 -58
  684. package/mssql-core/dialect.d.ts +0 -58
  685. package/mssql-core/dialect.js +0 -593
  686. package/mssql-core/dialect.js.map +0 -1
  687. package/mssql-core/expressions.cjs +0 -49
  688. package/mssql-core/expressions.cjs.map +0 -1
  689. package/mssql-core/expressions.d.cts +0 -8
  690. package/mssql-core/expressions.d.ts +0 -8
  691. package/mssql-core/expressions.js +0 -22
  692. package/mssql-core/expressions.js.map +0 -1
  693. package/mssql-core/foreign-keys.cjs +0 -91
  694. package/mssql-core/foreign-keys.cjs.map +0 -1
  695. package/mssql-core/foreign-keys.d.cts +0 -51
  696. package/mssql-core/foreign-keys.d.ts +0 -51
  697. package/mssql-core/foreign-keys.js +0 -65
  698. package/mssql-core/foreign-keys.js.map +0 -1
  699. package/mssql-core/index.cjs +0 -55
  700. package/mssql-core/index.cjs.map +0 -1
  701. package/mssql-core/index.d.cts +0 -17
  702. package/mssql-core/index.d.ts +0 -17
  703. package/mssql-core/index.js +0 -18
  704. package/mssql-core/index.js.map +0 -1
  705. package/mssql-core/indexes.cjs +0 -80
  706. package/mssql-core/indexes.cjs.map +0 -1
  707. package/mssql-core/indexes.d.cts +0 -49
  708. package/mssql-core/indexes.d.ts +0 -49
  709. package/mssql-core/indexes.js +0 -52
  710. package/mssql-core/indexes.js.map +0 -1
  711. package/mssql-core/primary-keys.cjs +0 -64
  712. package/mssql-core/primary-keys.cjs.map +0 -1
  713. package/mssql-core/primary-keys.d.cts +0 -23
  714. package/mssql-core/primary-keys.d.ts +0 -23
  715. package/mssql-core/primary-keys.js +0 -38
  716. package/mssql-core/primary-keys.js.map +0 -1
  717. package/mssql-core/query-builders/delete.cjs +0 -107
  718. package/mssql-core/query-builders/delete.cjs.map +0 -1
  719. package/mssql-core/query-builders/delete.d.cts +0 -98
  720. package/mssql-core/query-builders/delete.d.ts +0 -98
  721. package/mssql-core/query-builders/delete.js +0 -83
  722. package/mssql-core/query-builders/delete.js.map +0 -1
  723. package/mssql-core/query-builders/index.cjs +0 -33
  724. package/mssql-core/query-builders/index.cjs.map +0 -1
  725. package/mssql-core/query-builders/index.d.cts +0 -6
  726. package/mssql-core/query-builders/index.d.ts +0 -6
  727. package/mssql-core/query-builders/index.js +0 -7
  728. package/mssql-core/query-builders/index.js.map +0 -1
  729. package/mssql-core/query-builders/insert.cjs +0 -105
  730. package/mssql-core/query-builders/insert.cjs.map +0 -1
  731. package/mssql-core/query-builders/insert.d.cts +0 -78
  732. package/mssql-core/query-builders/insert.d.ts +0 -78
  733. package/mssql-core/query-builders/insert.js +0 -80
  734. package/mssql-core/query-builders/insert.js.map +0 -1
  735. package/mssql-core/query-builders/query-builder.cjs +0 -95
  736. package/mssql-core/query-builders/query-builder.cjs.map +0 -1
  737. package/mssql-core/query-builders/query-builder.d.cts +0 -32
  738. package/mssql-core/query-builders/query-builder.d.ts +0 -32
  739. package/mssql-core/query-builders/query-builder.js +0 -71
  740. package/mssql-core/query-builders/query-builder.js.map +0 -1
  741. package/mssql-core/query-builders/query.cjs +0 -126
  742. package/mssql-core/query-builders/query.cjs.map +0 -1
  743. package/mssql-core/query-builders/query.d.cts +0 -42
  744. package/mssql-core/query-builders/query.d.ts +0 -42
  745. package/mssql-core/query-builders/query.js +0 -103
  746. package/mssql-core/query-builders/query.js.map +0 -1
  747. package/mssql-core/query-builders/select.cjs +0 -679
  748. package/mssql-core/query-builders/select.cjs.map +0 -1
  749. package/mssql-core/query-builders/select.d.cts +0 -549
  750. package/mssql-core/query-builders/select.d.ts +0 -549
  751. package/mssql-core/query-builders/select.js +0 -649
  752. package/mssql-core/query-builders/select.js.map +0 -1
  753. package/mssql-core/query-builders/select.types.cjs +0 -17
  754. package/mssql-core/query-builders/select.types.cjs.map +0 -1
  755. package/mssql-core/query-builders/select.types.d.cts +0 -142
  756. package/mssql-core/query-builders/select.types.d.ts +0 -142
  757. package/mssql-core/query-builders/select.types.js +0 -1
  758. package/mssql-core/query-builders/update.cjs +0 -138
  759. package/mssql-core/query-builders/update.cjs.map +0 -1
  760. package/mssql-core/query-builders/update.d.cts +0 -141
  761. package/mssql-core/query-builders/update.d.ts +0 -141
  762. package/mssql-core/query-builders/update.js +0 -113
  763. package/mssql-core/query-builders/update.js.map +0 -1
  764. package/mssql-core/schema.cjs +0 -51
  765. package/mssql-core/schema.cjs.map +0 -1
  766. package/mssql-core/schema.d.cts +0 -22
  767. package/mssql-core/schema.d.ts +0 -22
  768. package/mssql-core/schema.js +0 -25
  769. package/mssql-core/schema.js.map +0 -1
  770. package/mssql-core/session.cjs +0 -74
  771. package/mssql-core/session.cjs.map +0 -1
  772. package/mssql-core/session.d.cts +0 -63
  773. package/mssql-core/session.d.ts +0 -63
  774. package/mssql-core/session.js +0 -48
  775. package/mssql-core/session.js.map +0 -1
  776. package/mssql-core/subquery.cjs.map +0 -1
  777. package/mssql-core/subquery.d.cts +0 -18
  778. package/mssql-core/subquery.d.ts +0 -18
  779. package/mssql-core/subquery.js +0 -1
  780. package/mssql-core/subquery.js.map +0 -1
  781. package/mssql-core/table.cjs +0 -81
  782. package/mssql-core/table.cjs.map +0 -1
  783. package/mssql-core/table.d.cts +0 -43
  784. package/mssql-core/table.d.ts +0 -43
  785. package/mssql-core/table.js +0 -53
  786. package/mssql-core/table.js.map +0 -1
  787. package/mssql-core/unique-constraint.cjs +0 -76
  788. package/mssql-core/unique-constraint.cjs.map +0 -1
  789. package/mssql-core/unique-constraint.d.cts +0 -23
  790. package/mssql-core/unique-constraint.d.ts +0 -23
  791. package/mssql-core/unique-constraint.js +0 -49
  792. package/mssql-core/unique-constraint.js.map +0 -1
  793. package/mssql-core/utils.cjs +0 -85
  794. package/mssql-core/utils.cjs.map +0 -1
  795. package/mssql-core/utils.d.cts +0 -31
  796. package/mssql-core/utils.d.ts +0 -31
  797. package/mssql-core/utils.js +0 -60
  798. package/mssql-core/utils.js.map +0 -1
  799. package/mssql-core/view-base.cjs +0 -33
  800. package/mssql-core/view-base.cjs.map +0 -1
  801. package/mssql-core/view-base.d.cts +0 -9
  802. package/mssql-core/view-base.d.ts +0 -9
  803. package/mssql-core/view-base.js +0 -9
  804. package/mssql-core/view-base.js.map +0 -1
  805. package/mssql-core/view-common.cjs.map +0 -1
  806. package/mssql-core/view-common.d.cts +0 -1
  807. package/mssql-core/view-common.d.ts +0 -1
  808. package/mssql-core/view-common.js +0 -5
  809. package/mssql-core/view-common.js.map +0 -1
  810. package/mssql-core/view.cjs +0 -154
  811. package/mssql-core/view.cjs.map +0 -1
  812. package/mssql-core/view.d.cts +0 -64
  813. package/mssql-core/view.d.ts +0 -64
  814. package/mssql-core/view.js +0 -125
  815. package/mssql-core/view.js.map +0 -1
  816. package/node-mssql/driver.cjs +0 -88
  817. package/node-mssql/driver.cjs.map +0 -1
  818. package/node-mssql/driver.d.cts +0 -34
  819. package/node-mssql/driver.d.ts +0 -34
  820. package/node-mssql/driver.js +0 -65
  821. package/node-mssql/driver.js.map +0 -1
  822. package/node-mssql/index.cjs.map +0 -1
  823. package/node-mssql/index.d.cts +0 -2
  824. package/node-mssql/index.d.ts +0 -2
  825. package/node-mssql/index.js +0 -3
  826. package/node-mssql/index.js.map +0 -1
  827. package/node-mssql/migrator.cjs +0 -33
  828. package/node-mssql/migrator.cjs.map +0 -1
  829. package/node-mssql/migrator.d.cts +0 -3
  830. package/node-mssql/migrator.d.ts +0 -3
  831. package/node-mssql/migrator.js +0 -9
  832. package/node-mssql/migrator.js.map +0 -1
  833. package/node-mssql/session.cjs +0 -243
  834. package/node-mssql/session.cjs.map +0 -1
  835. package/node-mssql/session.d.cts +0 -47
  836. package/node-mssql/session.d.ts +0 -47
  837. package/node-mssql/session.js +0 -211
  838. package/node-mssql/session.js.map +0 -1
  839. /package/{mssql-core/query-builders/select.types.js.map → cache/core/types.js.map} +0 -0
@@ -1,4 +1,5 @@
1
1
  import { sql } from '@vercel/postgres';
2
+ import type { Cache } from "../cache/core/cache.cjs";
2
3
  import { entityKind } from "../entity.cjs";
3
4
  import type { Logger } from "../logger.cjs";
4
5
  import { PgDatabase } from "../pg-core/db.cjs";
@@ -8,6 +9,7 @@ import { type DrizzleConfig } from "../utils.cjs";
8
9
  import { type VercelPgClient, type VercelPgQueryResultHKT, VercelPgSession } from "./session.cjs";
9
10
  export interface VercelPgDriverOptions {
10
11
  logger?: Logger;
12
+ cache?: Cache;
11
13
  }
12
14
  export declare class VercelPgDriver {
13
15
  private client;
@@ -1,4 +1,5 @@
1
1
  import { sql } from '@vercel/postgres';
2
+ import type { Cache } from "../cache/core/cache.js";
2
3
  import { entityKind } from "../entity.js";
3
4
  import type { Logger } from "../logger.js";
4
5
  import { PgDatabase } from "../pg-core/db.js";
@@ -8,6 +9,7 @@ import { type DrizzleConfig } from "../utils.js";
8
9
  import { type VercelPgClient, type VercelPgQueryResultHKT, VercelPgSession } from "./session.js";
9
10
  export interface VercelPgDriverOptions {
10
11
  logger?: Logger;
12
+ cache?: Cache;
11
13
  }
12
14
  export declare class VercelPgDriver {
13
15
  private client;
@@ -17,7 +17,10 @@ class VercelPgDriver {
17
17
  }
18
18
  static [entityKind] = "VercelPgDriver";
19
19
  createSession(schema) {
20
- return new VercelPgSession(this.client, this.dialect, schema, { logger: this.options.logger });
20
+ return new VercelPgSession(this.client, this.dialect, schema, {
21
+ logger: this.options.logger,
22
+ cache: this.options.cache
23
+ });
21
24
  }
22
25
  }
23
26
  class VercelPgDatabase extends PgDatabase {
@@ -43,10 +46,14 @@ function construct(client, config = {}) {
43
46
  tableNamesMap: tablesConfig.tableNamesMap
44
47
  };
45
48
  }
46
- const driver = new VercelPgDriver(client, dialect, { logger });
49
+ const driver = new VercelPgDriver(client, dialect, { logger, cache: config.cache });
47
50
  const session = driver.createSession(schema);
48
51
  const db = new VercelPgDatabase(dialect, session, schema);
49
52
  db.$client = client;
53
+ db.$cache = config.cache;
54
+ if (db.$cache) {
55
+ db.$cache["invalidate"] = config.cache?.onMutate;
56
+ }
50
57
  return db;
51
58
  }
52
59
  function drizzle(...params) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/vercel-postgres/driver.ts"],"sourcesContent":["import { sql } from '@vercel/postgres';\nimport { entityKind } from '~/entity.ts';\nimport type { Logger } from '~/logger.ts';\nimport { DefaultLogger } from '~/logger.ts';\nimport { PgDatabase } from '~/pg-core/db.ts';\nimport { PgDialect } from '~/pg-core/index.ts';\nimport {\n\tcreateTableRelationsHelpers,\n\textractTablesRelationalConfig,\n\ttype RelationalSchemaConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport { type DrizzleConfig, isConfig } from '~/utils.ts';\nimport { type VercelPgClient, type VercelPgQueryResultHKT, VercelPgSession } from './session.ts';\n\nexport interface VercelPgDriverOptions {\n\tlogger?: Logger;\n}\n\nexport class VercelPgDriver {\n\tstatic readonly [entityKind]: string = 'VercelPgDriver';\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tprivate dialect: PgDialect,\n\t\tprivate options: VercelPgDriverOptions = {},\n\t) {\n\t}\n\n\tcreateSession(\n\t\tschema: RelationalSchemaConfig<TablesRelationalConfig> | undefined,\n\t): VercelPgSession<Record<string, unknown>, TablesRelationalConfig> {\n\t\treturn new VercelPgSession(this.client, this.dialect, schema, { logger: this.options.logger });\n\t}\n}\n\nexport class VercelPgDatabase<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n> extends PgDatabase<VercelPgQueryResultHKT, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgDatabase';\n}\n\nfunction construct<TSchema extends Record<string, unknown> = Record<string, never>>(\n\tclient: VercelPgClient,\n\tconfig: DrizzleConfig<TSchema> = {},\n): VercelPgDatabase<TSchema> & {\n\t$client: VercelPgClient;\n} {\n\tconst dialect = new PgDialect({ casing: config.casing });\n\tlet logger;\n\tif (config.logger === true) {\n\t\tlogger = new DefaultLogger();\n\t} else if (config.logger !== false) {\n\t\tlogger = config.logger;\n\t}\n\n\tlet schema: RelationalSchemaConfig<TablesRelationalConfig> | undefined;\n\tif (config.schema) {\n\t\tconst tablesConfig = extractTablesRelationalConfig(\n\t\t\tconfig.schema,\n\t\t\tcreateTableRelationsHelpers,\n\t\t);\n\t\tschema = {\n\t\t\tfullSchema: config.schema,\n\t\t\tschema: tablesConfig.tables,\n\t\t\ttableNamesMap: tablesConfig.tableNamesMap,\n\t\t};\n\t}\n\n\tconst driver = new VercelPgDriver(client, dialect, { logger });\n\tconst session = driver.createSession(schema);\n\tconst db = new VercelPgDatabase(dialect, session, schema as any) as VercelPgDatabase<TSchema>;\n\t(<any> db).$client = client;\n\n\treturn db as any;\n}\n\nexport function drizzle<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n\tTClient extends VercelPgClient = typeof sql,\n>(\n\t...params: [] | [\n\t\tTClient,\n\t] | [\n\t\tTClient,\n\t\tDrizzleConfig<TSchema>,\n\t] | [\n\t\t(\n\t\t\t& DrizzleConfig<TSchema>\n\t\t\t& ({\n\t\t\t\tclient?: TClient;\n\t\t\t})\n\t\t),\n\t]\n): VercelPgDatabase<TSchema> & {\n\t$client: TClient;\n} {\n\tif (isConfig(params[0])) {\n\t\tconst { client, ...drizzleConfig } = params[0] as ({ client?: TClient } & DrizzleConfig<TSchema>);\n\t\treturn construct(client ?? sql, drizzleConfig) as any;\n\t}\n\n\treturn construct((params[0] ?? sql) as TClient, params[1] as DrizzleConfig<TSchema> | undefined) as any;\n}\n\nexport namespace drizzle {\n\texport function mock<TSchema extends Record<string, unknown> = Record<string, never>>(\n\t\tconfig?: DrizzleConfig<TSchema>,\n\t): VercelPgDatabase<TSchema> & {\n\t\t$client: '$client is not available on drizzle.mock()';\n\t} {\n\t\treturn construct({} as any, config) as any;\n\t}\n}\n"],"mappings":"AAAA,SAAS,WAAW;AACpB,SAAS,kBAAkB;AAE3B,SAAS,qBAAqB;AAC9B,SAAS,kBAAkB;AAC3B,SAAS,iBAAiB;AAC1B;AAAA,EACC;AAAA,EACA;AAAA,OAGM;AACP,SAA6B,gBAAgB;AAC7C,SAA2D,uBAAuB;AAM3E,MAAM,eAAe;AAAA,EAG3B,YACS,QACA,SACA,UAAiC,CAAC,GACzC;AAHO;AACA;AACA;AAAA,EAET;AAAA,EAPA,QAAiB,UAAU,IAAY;AAAA,EASvC,cACC,QACmE;AACnE,WAAO,IAAI,gBAAgB,KAAK,QAAQ,KAAK,SAAS,QAAQ,EAAE,QAAQ,KAAK,QAAQ,OAAO,CAAC;AAAA,EAC9F;AACD;AAEO,MAAM,yBAEH,WAA4C;AAAA,EACrD,QAA0B,UAAU,IAAY;AACjD;AAEA,SAAS,UACR,QACA,SAAiC,CAAC,GAGjC;AACD,QAAM,UAAU,IAAI,UAAU,EAAE,QAAQ,OAAO,OAAO,CAAC;AACvD,MAAI;AACJ,MAAI,OAAO,WAAW,MAAM;AAC3B,aAAS,IAAI,cAAc;AAAA,EAC5B,WAAW,OAAO,WAAW,OAAO;AACnC,aAAS,OAAO;AAAA,EACjB;AAEA,MAAI;AACJ,MAAI,OAAO,QAAQ;AAClB,UAAM,eAAe;AAAA,MACpB,OAAO;AAAA,MACP;AAAA,IACD;AACA,aAAS;AAAA,MACR,YAAY,OAAO;AAAA,MACnB,QAAQ,aAAa;AAAA,MACrB,eAAe,aAAa;AAAA,IAC7B;AAAA,EACD;AAEA,QAAM,SAAS,IAAI,eAAe,QAAQ,SAAS,EAAE,OAAO,CAAC;AAC7D,QAAM,UAAU,OAAO,cAAc,MAAM;AAC3C,QAAM,KAAK,IAAI,iBAAiB,SAAS,SAAS,MAAa;AAC/D,EAAO,GAAI,UAAU;AAErB,SAAO;AACR;AAEO,SAAS,WAIZ,QAeF;AACD,MAAI,SAAS,OAAO,CAAC,CAAC,GAAG;AACxB,UAAM,EAAE,QAAQ,GAAG,cAAc,IAAI,OAAO,CAAC;AAC7C,WAAO,UAAU,UAAU,KAAK,aAAa;AAAA,EAC9C;AAEA,SAAO,UAAW,OAAO,CAAC,KAAK,KAAiB,OAAO,CAAC,CAAuC;AAChG;AAAA,CAEO,CAAUA,aAAV;AACC,WAAS,KACf,QAGC;AACD,WAAO,UAAU,CAAC,GAAU,MAAM;AAAA,EACnC;AANO,EAAAA,SAAS;AAAA,GADA;","names":["drizzle"]}
1
+ {"version":3,"sources":["../../src/vercel-postgres/driver.ts"],"sourcesContent":["import { sql } from '@vercel/postgres';\nimport type { Cache } from '~/cache/core/cache.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { Logger } from '~/logger.ts';\nimport { DefaultLogger } from '~/logger.ts';\nimport { PgDatabase } from '~/pg-core/db.ts';\nimport { PgDialect } from '~/pg-core/index.ts';\nimport {\n\tcreateTableRelationsHelpers,\n\textractTablesRelationalConfig,\n\ttype RelationalSchemaConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport { type DrizzleConfig, isConfig } from '~/utils.ts';\nimport { type VercelPgClient, type VercelPgQueryResultHKT, VercelPgSession } from './session.ts';\n\nexport interface VercelPgDriverOptions {\n\tlogger?: Logger;\n\tcache?: Cache;\n}\n\nexport class VercelPgDriver {\n\tstatic readonly [entityKind]: string = 'VercelPgDriver';\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tprivate dialect: PgDialect,\n\t\tprivate options: VercelPgDriverOptions = {},\n\t) {\n\t}\n\n\tcreateSession(\n\t\tschema: RelationalSchemaConfig<TablesRelationalConfig> | undefined,\n\t): VercelPgSession<Record<string, unknown>, TablesRelationalConfig> {\n\t\treturn new VercelPgSession(this.client, this.dialect, schema, {\n\t\t\tlogger: this.options.logger,\n\t\t\tcache: this.options.cache,\n\t\t});\n\t}\n}\n\nexport class VercelPgDatabase<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n> extends PgDatabase<VercelPgQueryResultHKT, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgDatabase';\n}\n\nfunction construct<TSchema extends Record<string, unknown> = Record<string, never>>(\n\tclient: VercelPgClient,\n\tconfig: DrizzleConfig<TSchema> = {},\n): VercelPgDatabase<TSchema> & {\n\t$client: VercelPgClient;\n} {\n\tconst dialect = new PgDialect({ casing: config.casing });\n\tlet logger;\n\tif (config.logger === true) {\n\t\tlogger = new DefaultLogger();\n\t} else if (config.logger !== false) {\n\t\tlogger = config.logger;\n\t}\n\n\tlet schema: RelationalSchemaConfig<TablesRelationalConfig> | undefined;\n\tif (config.schema) {\n\t\tconst tablesConfig = extractTablesRelationalConfig(\n\t\t\tconfig.schema,\n\t\t\tcreateTableRelationsHelpers,\n\t\t);\n\t\tschema = {\n\t\t\tfullSchema: config.schema,\n\t\t\tschema: tablesConfig.tables,\n\t\t\ttableNamesMap: tablesConfig.tableNamesMap,\n\t\t};\n\t}\n\n\tconst driver = new VercelPgDriver(client, dialect, { logger, cache: config.cache });\n\tconst session = driver.createSession(schema);\n\tconst db = new VercelPgDatabase(dialect, session, schema as any) as VercelPgDatabase<TSchema>;\n\t(<any> db).$client = client;\n\t(<any> db).$cache = config.cache;\n\tif ((<any> db).$cache) {\n\t\t(<any> db).$cache['invalidate'] = config.cache?.onMutate;\n\t}\n\n\treturn db as any;\n}\n\nexport function drizzle<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n\tTClient extends VercelPgClient = typeof sql,\n>(\n\t...params: [] | [\n\t\tTClient,\n\t] | [\n\t\tTClient,\n\t\tDrizzleConfig<TSchema>,\n\t] | [\n\t\t(\n\t\t\t& DrizzleConfig<TSchema>\n\t\t\t& ({\n\t\t\t\tclient?: TClient;\n\t\t\t})\n\t\t),\n\t]\n): VercelPgDatabase<TSchema> & {\n\t$client: TClient;\n} {\n\tif (isConfig(params[0])) {\n\t\tconst { client, ...drizzleConfig } = params[0] as ({ client?: TClient } & DrizzleConfig<TSchema>);\n\t\treturn construct(client ?? sql, drizzleConfig) as any;\n\t}\n\n\treturn construct((params[0] ?? sql) as TClient, params[1] as DrizzleConfig<TSchema> | undefined) as any;\n}\n\nexport namespace drizzle {\n\texport function mock<TSchema extends Record<string, unknown> = Record<string, never>>(\n\t\tconfig?: DrizzleConfig<TSchema>,\n\t): VercelPgDatabase<TSchema> & {\n\t\t$client: '$client is not available on drizzle.mock()';\n\t} {\n\t\treturn construct({} as any, config) as any;\n\t}\n}\n"],"mappings":"AAAA,SAAS,WAAW;AAEpB,SAAS,kBAAkB;AAE3B,SAAS,qBAAqB;AAC9B,SAAS,kBAAkB;AAC3B,SAAS,iBAAiB;AAC1B;AAAA,EACC;AAAA,EACA;AAAA,OAGM;AACP,SAA6B,gBAAgB;AAC7C,SAA2D,uBAAuB;AAO3E,MAAM,eAAe;AAAA,EAG3B,YACS,QACA,SACA,UAAiC,CAAC,GACzC;AAHO;AACA;AACA;AAAA,EAET;AAAA,EAPA,QAAiB,UAAU,IAAY;AAAA,EASvC,cACC,QACmE;AACnE,WAAO,IAAI,gBAAgB,KAAK,QAAQ,KAAK,SAAS,QAAQ;AAAA,MAC7D,QAAQ,KAAK,QAAQ;AAAA,MACrB,OAAO,KAAK,QAAQ;AAAA,IACrB,CAAC;AAAA,EACF;AACD;AAEO,MAAM,yBAEH,WAA4C;AAAA,EACrD,QAA0B,UAAU,IAAY;AACjD;AAEA,SAAS,UACR,QACA,SAAiC,CAAC,GAGjC;AACD,QAAM,UAAU,IAAI,UAAU,EAAE,QAAQ,OAAO,OAAO,CAAC;AACvD,MAAI;AACJ,MAAI,OAAO,WAAW,MAAM;AAC3B,aAAS,IAAI,cAAc;AAAA,EAC5B,WAAW,OAAO,WAAW,OAAO;AACnC,aAAS,OAAO;AAAA,EACjB;AAEA,MAAI;AACJ,MAAI,OAAO,QAAQ;AAClB,UAAM,eAAe;AAAA,MACpB,OAAO;AAAA,MACP;AAAA,IACD;AACA,aAAS;AAAA,MACR,YAAY,OAAO;AAAA,MACnB,QAAQ,aAAa;AAAA,MACrB,eAAe,aAAa;AAAA,IAC7B;AAAA,EACD;AAEA,QAAM,SAAS,IAAI,eAAe,QAAQ,SAAS,EAAE,QAAQ,OAAO,OAAO,MAAM,CAAC;AAClF,QAAM,UAAU,OAAO,cAAc,MAAM;AAC3C,QAAM,KAAK,IAAI,iBAAiB,SAAS,SAAS,MAAa;AAC/D,EAAO,GAAI,UAAU;AACrB,EAAO,GAAI,SAAS,OAAO;AAC3B,MAAW,GAAI,QAAQ;AACtB,IAAO,GAAI,OAAO,YAAY,IAAI,OAAO,OAAO;AAAA,EACjD;AAEA,SAAO;AACR;AAEO,SAAS,WAIZ,QAeF;AACD,MAAI,SAAS,OAAO,CAAC,CAAC,GAAG;AACxB,UAAM,EAAE,QAAQ,GAAG,cAAc,IAAI,OAAO,CAAC;AAC7C,WAAO,UAAU,UAAU,KAAK,aAAa;AAAA,EAC9C;AAEA,SAAO,UAAW,OAAO,CAAC,KAAK,KAAiB,OAAO,CAAC,CAAuC;AAChG;AAAA,CAEO,CAAUA,aAAV;AACC,WAAS,KACf,QAGC;AACD,WAAO,UAAU,CAAC,GAAU,MAAM;AAAA,EACnC;AANO,EAAAA,SAAS;AAAA,GADA;","names":["drizzle"]}
@@ -24,6 +24,7 @@ __export(session_exports, {
24
24
  });
25
25
  module.exports = __toCommonJS(session_exports);
26
26
  var import_postgres = require("@vercel/postgres");
27
+ var import_cache = require("../cache/core/cache.cjs");
27
28
  var import_entity = require("../entity.cjs");
28
29
  var import_logger = require("../logger.cjs");
29
30
  var import_pg_core = require("../pg-core/index.cjs");
@@ -31,8 +32,8 @@ var import_session = require("../pg-core/session.cjs");
31
32
  var import_sql = require("../sql/sql.cjs");
32
33
  var import_utils = require("../utils.cjs");
33
34
  class VercelPgPreparedQuery extends import_session.PgPreparedQuery {
34
- constructor(client, queryString, params, logger, fields, name, _isResponseInArrayMode, customResultMapper) {
35
- super({ sql: queryString, params });
35
+ constructor(client, queryString, params, logger, cache, queryMetadata, cacheConfig, fields, name, _isResponseInArrayMode, customResultMapper) {
36
+ super({ sql: queryString, params }, cache, queryMetadata, cacheConfig);
36
37
  this.client = client;
37
38
  this.params = params;
38
39
  this.logger = logger;
@@ -123,9 +124,13 @@ class VercelPgPreparedQuery extends import_session.PgPreparedQuery {
123
124
  this.logger.logQuery(this.rawQuery.text, params);
124
125
  const { fields, rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } = this;
125
126
  if (!fields && !customResultMapper) {
126
- return client.query(rawQuery, params);
127
+ return this.queryWithCache(rawQuery.text, params, async () => {
128
+ return await client.query(rawQuery, params);
129
+ });
127
130
  }
128
- const { rows } = await client.query(query, params);
131
+ const { rows } = await this.queryWithCache(query.text, params, async () => {
132
+ return await client.query(query, params);
133
+ });
129
134
  if (customResultMapper) {
130
135
  return customResultMapper(rows);
131
136
  }
@@ -134,12 +139,16 @@ class VercelPgPreparedQuery extends import_session.PgPreparedQuery {
134
139
  all(placeholderValues = {}) {
135
140
  const params = (0, import_sql.fillPlaceholders)(this.params, placeholderValues);
136
141
  this.logger.logQuery(this.rawQuery.text, params);
137
- return this.client.query(this.rawQuery, params).then((result) => result.rows);
142
+ return this.queryWithCache(this.rawQuery.text, params, async () => {
143
+ return await this.client.query(this.rawQuery, params);
144
+ }).then((result) => result.rows);
138
145
  }
139
146
  values(placeholderValues = {}) {
140
147
  const params = (0, import_sql.fillPlaceholders)(this.params, placeholderValues);
141
148
  this.logger.logQuery(this.rawQuery.text, params);
142
- return this.client.query(this.queryConfig, params).then((result) => result.rows);
149
+ return this.queryWithCache(this.queryConfig.text, params, async () => {
150
+ return await this.client.query(this.queryConfig, params);
151
+ }).then((result) => result.rows);
143
152
  }
144
153
  /** @internal */
145
154
  isResponseInArrayMode() {
@@ -153,15 +162,20 @@ class VercelPgSession extends import_session.PgSession {
153
162
  this.schema = schema;
154
163
  this.options = options;
155
164
  this.logger = options.logger ?? new import_logger.NoopLogger();
165
+ this.cache = options.cache ?? new import_cache.NoopCache();
156
166
  }
157
167
  static [import_entity.entityKind] = "VercelPgSession";
158
168
  logger;
159
- prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper) {
169
+ cache;
170
+ prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {
160
171
  return new VercelPgPreparedQuery(
161
172
  this.client,
162
173
  query.sql,
163
174
  query.params,
164
175
  this.logger,
176
+ this.cache,
177
+ queryMetadata,
178
+ cacheConfig,
165
179
  fields,
166
180
  name,
167
181
  isResponseInArrayMode,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/vercel-postgres/session.ts"],"sourcesContent":["import {\n\ttype QueryArrayConfig,\n\ttype QueryConfig,\n\ttype QueryResult,\n\ttype QueryResultRow,\n\ttypes,\n\ttype VercelClient,\n\tVercelPool,\n\ttype VercelPoolClient,\n} from '@vercel/postgres';\nimport { entityKind } from '~/entity.ts';\nimport { type Logger, NoopLogger } from '~/logger.ts';\nimport { type PgDialect, PgTransaction } from '~/pg-core/index.ts';\nimport type { SelectedFieldsOrdered } from '~/pg-core/query-builders/select.types.ts';\nimport type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from '~/pg-core/session.ts';\nimport { PgPreparedQuery, PgSession } from '~/pg-core/session.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, type SQL, sql } from '~/sql/sql.ts';\nimport { type Assume, mapResultRow } from '~/utils.ts';\n\nexport type VercelPgClient = VercelPool | VercelClient | VercelPoolClient;\n\nexport class VercelPgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {\n\tstatic override readonly [entityKind]: string = 'VercelPgPreparedQuery';\n\n\tprivate rawQuery: QueryConfig;\n\tprivate queryConfig: QueryArrayConfig;\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tqueryString: string,\n\t\tprivate params: unknown[],\n\t\tprivate logger: Logger,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => T['execute'],\n\t) {\n\t\tsuper({ sql: queryString, params });\n\t\tthis.rawQuery = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// numeric[]\n\t\t\t\t\tif (typeId === 1231 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp[]\n\t\t\t\t\tif (typeId === 1115 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp with timezone[]\n\t\t\t\t\tif (typeId === 1185 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// interval[]\n\t\t\t\t\tif (typeId === 1187 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// date[]\n\t\t\t\t\tif (typeId === 1182 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t\tthis.queryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\trowMode: 'array',\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// numeric[]\n\t\t\t\t\tif (typeId === 1231 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp[]\n\t\t\t\t\tif (typeId === 1115 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp with timezone[]\n\t\t\t\t\tif (typeId === 1185 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// interval[]\n\t\t\t\t\tif (typeId === 1187 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// date[]\n\t\t\t\t\tif (typeId === 1182 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t}\n\n\tasync execute(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['execute']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\n\t\tconst { fields, rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } = this;\n\t\tif (!fields && !customResultMapper) {\n\t\t\treturn client.query(rawQuery, params);\n\t\t}\n\n\t\tconst { rows } = await client.query(query, params);\n\n\t\tif (customResultMapper) {\n\t\t\treturn customResultMapper(rows);\n\t\t}\n\n\t\treturn rows.map((row) => mapResultRow<T['execute']>(fields!, row, joinsNotNullableMap));\n\t}\n\n\tall(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['all']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\t\treturn this.client.query(this.rawQuery, params).then((result) => result.rows);\n\t}\n\n\tvalues(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['values']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\t\treturn this.client.query(this.queryConfig, params).then((result) => result.rows);\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n\nexport interface VercelPgSessionOptions {\n\tlogger?: Logger;\n}\n\nexport class VercelPgSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgSession<VercelPgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgSession';\n\n\tprivate logger: Logger;\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tdialect: PgDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\tprivate options: VercelPgSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t}\n\n\tprepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][]) => T['execute'],\n\t): PgPreparedQuery<T> {\n\t\treturn new VercelPgPreparedQuery(\n\t\t\tthis.client,\n\t\t\tquery.sql,\n\t\t\tquery.params,\n\t\t\tthis.logger,\n\t\t\tfields,\n\t\t\tname,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\tasync query(query: string, params: unknown[]): Promise<QueryResult> {\n\t\tthis.logger.logQuery(query, params);\n\t\tconst result = await this.client.query({\n\t\t\trowMode: 'array',\n\t\t\ttext: query,\n\t\t\tvalues: params,\n\t\t});\n\t\treturn result;\n\t}\n\n\tasync queryObjects<T extends QueryResultRow>(\n\t\tquery: string,\n\t\tparams: unknown[],\n\t): Promise<QueryResult<T>> {\n\t\treturn this.client.query<T>(query, params);\n\t}\n\n\toverride async count(sql: SQL): Promise<number> {\n\t\tconst result = await this.execute(sql);\n\n\t\treturn Number((result as any)['rows'][0]['count']);\n\t}\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: VercelPgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t\tconfig?: PgTransactionConfig | undefined,\n\t): Promise<T> {\n\t\tconst session = this.client instanceof VercelPool // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t? new VercelPgSession(await this.client.connect(), this.dialect, this.schema, this.options)\n\t\t\t: this;\n\t\tconst tx = new VercelPgTransaction<TFullSchema, TSchema>(this.dialect, session, this.schema);\n\t\tawait tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : undefined}`);\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql`commit`);\n\t\t\treturn result;\n\t\t} catch (error) {\n\t\t\tawait tx.execute(sql`rollback`);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\tif (this.client instanceof VercelPool) { // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t(session.client as VercelPoolClient).release();\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport class VercelPgTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgTransaction<VercelPgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgTransaction';\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: VercelPgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T> {\n\t\tconst savepointName = `sp${this.nestedIndex + 1}`;\n\t\tconst tx = new VercelPgTransaction<TFullSchema, TSchema>(\n\t\t\tthis.dialect,\n\t\t\tthis.session,\n\t\t\tthis.schema,\n\t\t\tthis.nestedIndex + 1,\n\t\t);\n\t\tawait tx.execute(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tawait tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport interface VercelPgQueryResultHKT extends PgQueryResultHKT {\n\ttype: QueryResult<Assume<this['row'], QueryResultRow>>;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBASO;AACP,oBAA2B;AAC3B,oBAAwC;AACxC,qBAA8C;AAG9C,qBAA2C;AAE3C,iBAA4D;AAC5D,mBAA0C;AAInC,MAAM,8BAA6D,+BAAmB;AAAA,EAM5F,YACS,QACR,aACQ,QACA,QACA,QACR,MACQ,wBACA,oBACP;AACD,UAAM,EAAE,KAAK,aAAa,OAAO,CAAC;AAT1B;AAEA;AACA;AACA;AAEA;AACA;AAGR,SAAK,WAAW;AAAA,MACf;AAAA,MACA,MAAM;AAAA,MACN,OAAO;AAAA;AAAA,QAEN,eAAe,CAAC,QAAQ,WAAW;AAClC,cAAI,WAAW,sBAAM,SAAS,aAAa;AAC1C,mBAAO,CAAC,QAAa;AAAA,UACtB;AACA,cAAI,WAAW,sBAAM,SAAS,WAAW;AACxC,mBAAO,CAAC,QAAa;AAAA,UACtB;AACA,cAAI,WAAW,sBAAM,SAAS,MAAM;AACnC,mBAAO,CAAC,QAAa;AAAA,UACtB;AACA,cAAI,WAAW,sBAAM,SAAS,UAAU;AACvC,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,iBAAO,sBAAM,cAAc,QAAQ,MAAM;AAAA,QAC1C;AAAA,MACD;AAAA,IACD;AACA,SAAK,cAAc;AAAA,MAClB;AAAA,MACA,MAAM;AAAA,MACN,SAAS;AAAA,MACT,OAAO;AAAA;AAAA,QAEN,eAAe,CAAC,QAAQ,WAAW;AAClC,cAAI,WAAW,sBAAM,SAAS,aAAa;AAC1C,mBAAO,CAAC,QAAa;AAAA,UACtB;AACA,cAAI,WAAW,sBAAM,SAAS,WAAW;AACxC,mBAAO,CAAC,QAAa;AAAA,UACtB;AACA,cAAI,WAAW,sBAAM,SAAS,MAAM;AACnC,mBAAO,CAAC,QAAa;AAAA,UACtB;AACA,cAAI,WAAW,sBAAM,SAAS,UAAU;AACvC,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,cAAI,WAAW,MAAa;AAC3B,mBAAO,CAAC,QAAa;AAAA,UACtB;AAEA,iBAAO,sBAAM,cAAc,QAAQ,MAAM;AAAA,QAC1C;AAAA,MACD;AAAA,IACD;AAAA,EACD;AAAA,EAvGA,QAA0B,wBAAU,IAAY;AAAA,EAExC;AAAA,EACA;AAAA,EAsGR,MAAM,QAAQ,oBAAyD,CAAC,GAA0B;AACjG,UAAM,aAAS,6BAAiB,KAAK,QAAQ,iBAAiB;AAE9D,SAAK,OAAO,SAAS,KAAK,SAAS,MAAM,MAAM;AAE/C,UAAM,EAAE,QAAQ,UAAU,QAAQ,aAAa,OAAO,qBAAqB,mBAAmB,IAAI;AAClG,QAAI,CAAC,UAAU,CAAC,oBAAoB;AACnC,aAAO,OAAO,MAAM,UAAU,MAAM;AAAA,IACrC;AAEA,UAAM,EAAE,KAAK,IAAI,MAAM,OAAO,MAAM,OAAO,MAAM;AAEjD,QAAI,oBAAoB;AACvB,aAAO,mBAAmB,IAAI;AAAA,IAC/B;AAEA,WAAO,KAAK,IAAI,CAAC,YAAQ,2BAA2B,QAAS,KAAK,mBAAmB,CAAC;AAAA,EACvF;AAAA,EAEA,IAAI,oBAAyD,CAAC,GAAsB;AACnF,UAAM,aAAS,6BAAiB,KAAK,QAAQ,iBAAiB;AAC9D,SAAK,OAAO,SAAS,KAAK,SAAS,MAAM,MAAM;AAC/C,WAAO,KAAK,OAAO,MAAM,KAAK,UAAU,MAAM,EAAE,KAAK,CAAC,WAAW,OAAO,IAAI;AAAA,EAC7E;AAAA,EAEA,OAAO,oBAAyD,CAAC,GAAyB;AACzF,UAAM,aAAS,6BAAiB,KAAK,QAAQ,iBAAiB;AAC9D,SAAK,OAAO,SAAS,KAAK,SAAS,MAAM,MAAM;AAC/C,WAAO,KAAK,OAAO,MAAM,KAAK,aAAa,MAAM,EAAE,KAAK,CAAC,WAAW,OAAO,IAAI;AAAA,EAChF;AAAA;AAAA,EAGA,wBAAiC;AAChC,WAAO,KAAK;AAAA,EACb;AACD;AAMO,MAAM,wBAGH,yBAAwD;AAAA,EAKjE,YACS,QACR,SACQ,QACA,UAAkC,CAAC,GAC1C;AACD,UAAM,OAAO;AALL;AAEA;AACA;AAGR,SAAK,SAAS,QAAQ,UAAU,IAAI,yBAAW;AAAA,EAChD;AAAA,EAZA,QAA0B,wBAAU,IAAY;AAAA,EAExC;AAAA,EAYR,aACC,OACA,QACA,MACA,uBACA,oBACqB;AACrB,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,MAAM;AAAA,MACN,MAAM;AAAA,MACN,KAAK;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,EACD;AAAA,EAEA,MAAM,MAAM,OAAe,QAAyC;AACnE,SAAK,OAAO,SAAS,OAAO,MAAM;AAClC,UAAM,SAAS,MAAM,KAAK,OAAO,MAAM;AAAA,MACtC,SAAS;AAAA,MACT,MAAM;AAAA,MACN,QAAQ;AAAA,IACT,CAAC;AACD,WAAO;AAAA,EACR;AAAA,EAEA,MAAM,aACL,OACA,QAC0B;AAC1B,WAAO,KAAK,OAAO,MAAS,OAAO,MAAM;AAAA,EAC1C;AAAA,EAEA,MAAe,MAAMA,MAA2B;AAC/C,UAAM,SAAS,MAAM,KAAK,QAAQA,IAAG;AAErC,WAAO,OAAQ,OAAe,MAAM,EAAE,CAAC,EAAE,OAAO,CAAC;AAAA,EAClD;AAAA,EAEA,MAAe,YACd,aACA,QACa;AACb,UAAM,UAAU,KAAK,kBAAkB,6BACpC,IAAI,gBAAgB,MAAM,KAAK,OAAO,QAAQ,GAAG,KAAK,SAAS,KAAK,QAAQ,KAAK,OAAO,IACxF;AACH,UAAM,KAAK,IAAI,oBAA0C,KAAK,SAAS,SAAS,KAAK,MAAM;AAC3F,UAAM,GAAG,QAAQ,sBAAW,SAAS,kBAAO,GAAG,wBAAwB,MAAM,CAAC,KAAK,MAAS,EAAE;AAC9F,QAAI;AACH,YAAM,SAAS,MAAM,YAAY,EAAE;AACnC,YAAM,GAAG,QAAQ,sBAAW;AAC5B,aAAO;AAAA,IACR,SAAS,OAAO;AACf,YAAM,GAAG,QAAQ,wBAAa;AAC9B,YAAM;AAAA,IACP,UAAE;AACD,UAAI,KAAK,kBAAkB,4BAAY;AACtC,QAAC,QAAQ,OAA4B,QAAQ;AAAA,MAC9C;AAAA,IACD;AAAA,EACD;AACD;AAEO,MAAM,4BAGH,6BAA4D;AAAA,EACrE,QAA0B,wBAAU,IAAY;AAAA,EAEhD,MAAe,YACd,aACa;AACb,UAAM,gBAAgB,KAAK,KAAK,cAAc,CAAC;AAC/C,UAAM,KAAK,IAAI;AAAA,MACd,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK,cAAc;AAAA,IACpB;AACA,UAAM,GAAG,QAAQ,eAAI,IAAI,aAAa,aAAa,EAAE,CAAC;AACtD,QAAI;AACH,YAAM,SAAS,MAAM,YAAY,EAAE;AACnC,YAAM,GAAG,QAAQ,eAAI,IAAI,qBAAqB,aAAa,EAAE,CAAC;AAC9D,aAAO;AAAA,IACR,SAAS,KAAK;AACb,YAAM,GAAG,QAAQ,eAAI,IAAI,yBAAyB,aAAa,EAAE,CAAC;AAClE,YAAM;AAAA,IACP;AAAA,EACD;AACD;","names":["sql"]}
1
+ {"version":3,"sources":["../../src/vercel-postgres/session.ts"],"sourcesContent":["import {\n\ttype QueryArrayConfig,\n\ttype QueryConfig,\n\ttype QueryResult,\n\ttype QueryResultRow,\n\ttypes,\n\ttype VercelClient,\n\tVercelPool,\n\ttype VercelPoolClient,\n} from '@vercel/postgres';\nimport type { Cache } from '~/cache/core/cache.ts';\nimport { NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind } from '~/entity.ts';\nimport { type Logger, NoopLogger } from '~/logger.ts';\nimport { type PgDialect, PgTransaction } from '~/pg-core/index.ts';\nimport type { SelectedFieldsOrdered } from '~/pg-core/query-builders/select.types.ts';\nimport type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from '~/pg-core/session.ts';\nimport { PgPreparedQuery, PgSession } from '~/pg-core/session.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, type SQL, sql } from '~/sql/sql.ts';\nimport { type Assume, mapResultRow } from '~/utils.ts';\n\nexport type VercelPgClient = VercelPool | VercelClient | VercelPoolClient;\n\nexport class VercelPgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {\n\tstatic override readonly [entityKind]: string = 'VercelPgPreparedQuery';\n\n\tprivate rawQuery: QueryConfig;\n\tprivate queryConfig: QueryArrayConfig;\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tqueryString: string,\n\t\tprivate params: unknown[],\n\t\tprivate logger: Logger,\n\t\tcache: Cache,\n\t\tqueryMetadata: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\tcacheConfig: WithCacheConfig | undefined,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => T['execute'],\n\t) {\n\t\tsuper({ sql: queryString, params }, cache, queryMetadata, cacheConfig);\n\t\tthis.rawQuery = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// numeric[]\n\t\t\t\t\tif (typeId === 1231 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp[]\n\t\t\t\t\tif (typeId === 1115 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp with timezone[]\n\t\t\t\t\tif (typeId === 1185 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// interval[]\n\t\t\t\t\tif (typeId === 1187 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// date[]\n\t\t\t\t\tif (typeId === 1182 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t\tthis.queryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\trowMode: 'array',\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// numeric[]\n\t\t\t\t\tif (typeId === 1231 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp[]\n\t\t\t\t\tif (typeId === 1115 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp with timezone[]\n\t\t\t\t\tif (typeId === 1185 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// interval[]\n\t\t\t\t\tif (typeId === 1187 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// date[]\n\t\t\t\t\tif (typeId === 1182 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t}\n\n\tasync execute(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['execute']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\n\t\tconst { fields, rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } = this;\n\t\tif (!fields && !customResultMapper) {\n\t\t\treturn this.queryWithCache(rawQuery.text, params, async () => {\n\t\t\t\treturn await client.query(rawQuery, params);\n\t\t\t});\n\t\t}\n\n\t\tconst { rows } = await this.queryWithCache(query.text, params, async () => {\n\t\t\treturn await client.query(query, params);\n\t\t});\n\n\t\tif (customResultMapper) {\n\t\t\treturn customResultMapper(rows);\n\t\t}\n\n\t\treturn rows.map((row) => mapResultRow<T['execute']>(fields!, row, joinsNotNullableMap));\n\t}\n\n\tall(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['all']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\t\treturn this.queryWithCache(this.rawQuery.text, params, async () => {\n\t\t\treturn await this.client.query(this.rawQuery, params);\n\t\t}).then((result) => result.rows);\n\t}\n\n\tvalues(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['values']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\t\treturn this.queryWithCache(this.queryConfig.text, params, async () => {\n\t\t\treturn await this.client.query(this.queryConfig, params);\n\t\t}).then((result) => result.rows);\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n\nexport interface VercelPgSessionOptions {\n\tlogger?: Logger;\n\tcache?: Cache;\n}\n\nexport class VercelPgSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgSession<VercelPgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgSession';\n\n\tprivate logger: Logger;\n\tprivate cache: Cache;\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tdialect: PgDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\tprivate options: VercelPgSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t\tthis.cache = options.cache ?? new NoopCache();\n\t}\n\n\tprepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][]) => T['execute'],\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): PgPreparedQuery<T> {\n\t\treturn new VercelPgPreparedQuery(\n\t\t\tthis.client,\n\t\t\tquery.sql,\n\t\t\tquery.params,\n\t\t\tthis.logger,\n\t\t\tthis.cache,\n\t\t\tqueryMetadata,\n\t\t\tcacheConfig,\n\t\t\tfields,\n\t\t\tname,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\tasync query(query: string, params: unknown[]): Promise<QueryResult> {\n\t\tthis.logger.logQuery(query, params);\n\t\tconst result = await this.client.query({\n\t\t\trowMode: 'array',\n\t\t\ttext: query,\n\t\t\tvalues: params,\n\t\t});\n\t\treturn result;\n\t}\n\n\tasync queryObjects<T extends QueryResultRow>(\n\t\tquery: string,\n\t\tparams: unknown[],\n\t): Promise<QueryResult<T>> {\n\t\treturn this.client.query<T>(query, params);\n\t}\n\n\toverride async count(sql: SQL): Promise<number> {\n\t\tconst result = await this.execute(sql);\n\n\t\treturn Number((result as any)['rows'][0]['count']);\n\t}\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: VercelPgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t\tconfig?: PgTransactionConfig | undefined,\n\t): Promise<T> {\n\t\tconst session = this.client instanceof VercelPool // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t? new VercelPgSession(await this.client.connect(), this.dialect, this.schema, this.options)\n\t\t\t: this;\n\t\tconst tx = new VercelPgTransaction<TFullSchema, TSchema>(this.dialect, session, this.schema);\n\t\tawait tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : undefined}`);\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql`commit`);\n\t\t\treturn result;\n\t\t} catch (error) {\n\t\t\tawait tx.execute(sql`rollback`);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\tif (this.client instanceof VercelPool) { // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t(session.client as VercelPoolClient).release();\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport class VercelPgTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgTransaction<VercelPgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgTransaction';\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: VercelPgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T> {\n\t\tconst savepointName = `sp${this.nestedIndex + 1}`;\n\t\tconst tx = new VercelPgTransaction<TFullSchema, TSchema>(\n\t\t\tthis.dialect,\n\t\t\tthis.session,\n\t\t\tthis.schema,\n\t\t\tthis.nestedIndex + 1,\n\t\t);\n\t\tawait tx.execute(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tawait tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport interface VercelPgQueryResultHKT extends PgQueryResultHKT {\n\ttype: QueryResult<Assume<this['row'], QueryResultRow>>;\n}\n"],"mappings":"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","names":["sql"]}
@@ -1,4 +1,6 @@
1
1
  import { type QueryResult, type QueryResultRow, type VercelClient, VercelPool, type VercelPoolClient } from '@vercel/postgres';
2
+ import type { Cache } from "../cache/core/cache.cjs";
3
+ import type { WithCacheConfig } from "../cache/core/types.cjs";
2
4
  import { entityKind } from "../entity.cjs";
3
5
  import { type Logger } from "../logger.cjs";
4
6
  import { type PgDialect, PgTransaction } from "../pg-core/index.cjs";
@@ -19,13 +21,17 @@ export declare class VercelPgPreparedQuery<T extends PreparedQueryConfig> extend
19
21
  static readonly [entityKind]: string;
20
22
  private rawQuery;
21
23
  private queryConfig;
22
- constructor(client: VercelPgClient, queryString: string, params: unknown[], logger: Logger, fields: SelectedFieldsOrdered | undefined, name: string | undefined, _isResponseInArrayMode: boolean, customResultMapper?: ((rows: unknown[][]) => T["execute"]) | undefined);
24
+ constructor(client: VercelPgClient, queryString: string, params: unknown[], logger: Logger, cache: Cache, queryMetadata: {
25
+ type: 'select' | 'update' | 'delete' | 'insert';
26
+ tables: string[];
27
+ } | undefined, cacheConfig: WithCacheConfig | undefined, fields: SelectedFieldsOrdered | undefined, name: string | undefined, _isResponseInArrayMode: boolean, customResultMapper?: ((rows: unknown[][]) => T["execute"]) | undefined);
23
28
  execute(placeholderValues?: Record<string, unknown> | undefined): Promise<T['execute']>;
24
29
  all(placeholderValues?: Record<string, unknown> | undefined): Promise<T['all']>;
25
30
  values(placeholderValues?: Record<string, unknown> | undefined): Promise<T['values']>;
26
31
  }
27
32
  export interface VercelPgSessionOptions {
28
33
  logger?: Logger;
34
+ cache?: Cache;
29
35
  }
30
36
  export declare class VercelPgSession<TFullSchema extends Record<string, unknown>, TSchema extends TablesRelationalConfig> extends PgSession<VercelPgQueryResultHKT, TFullSchema, TSchema> {
31
37
  private client;
@@ -33,8 +39,12 @@ export declare class VercelPgSession<TFullSchema extends Record<string, unknown>
33
39
  private options;
34
40
  static readonly [entityKind]: string;
35
41
  private logger;
42
+ private cache;
36
43
  constructor(client: VercelPgClient, dialect: PgDialect, schema: RelationalSchemaConfig<TSchema> | undefined, options?: VercelPgSessionOptions);
37
- prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][]) => T['execute']): PgPreparedQuery<T>;
44
+ prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][]) => T['execute'], queryMetadata?: {
45
+ type: 'select' | 'update' | 'delete' | 'insert';
46
+ tables: string[];
47
+ }, cacheConfig?: WithCacheConfig): PgPreparedQuery<T>;
38
48
  query(query: string, params: unknown[]): Promise<QueryResult>;
39
49
  queryObjects<T extends QueryResultRow>(query: string, params: unknown[]): Promise<QueryResult<T>>;
40
50
  count(sql: SQL): Promise<number>;
@@ -1,4 +1,6 @@
1
1
  import { type QueryResult, type QueryResultRow, type VercelClient, VercelPool, type VercelPoolClient } from '@vercel/postgres';
2
+ import type { Cache } from "../cache/core/cache.js";
3
+ import type { WithCacheConfig } from "../cache/core/types.js";
2
4
  import { entityKind } from "../entity.js";
3
5
  import { type Logger } from "../logger.js";
4
6
  import { type PgDialect, PgTransaction } from "../pg-core/index.js";
@@ -19,13 +21,17 @@ export declare class VercelPgPreparedQuery<T extends PreparedQueryConfig> extend
19
21
  static readonly [entityKind]: string;
20
22
  private rawQuery;
21
23
  private queryConfig;
22
- constructor(client: VercelPgClient, queryString: string, params: unknown[], logger: Logger, fields: SelectedFieldsOrdered | undefined, name: string | undefined, _isResponseInArrayMode: boolean, customResultMapper?: ((rows: unknown[][]) => T["execute"]) | undefined);
24
+ constructor(client: VercelPgClient, queryString: string, params: unknown[], logger: Logger, cache: Cache, queryMetadata: {
25
+ type: 'select' | 'update' | 'delete' | 'insert';
26
+ tables: string[];
27
+ } | undefined, cacheConfig: WithCacheConfig | undefined, fields: SelectedFieldsOrdered | undefined, name: string | undefined, _isResponseInArrayMode: boolean, customResultMapper?: ((rows: unknown[][]) => T["execute"]) | undefined);
23
28
  execute(placeholderValues?: Record<string, unknown> | undefined): Promise<T['execute']>;
24
29
  all(placeholderValues?: Record<string, unknown> | undefined): Promise<T['all']>;
25
30
  values(placeholderValues?: Record<string, unknown> | undefined): Promise<T['values']>;
26
31
  }
27
32
  export interface VercelPgSessionOptions {
28
33
  logger?: Logger;
34
+ cache?: Cache;
29
35
  }
30
36
  export declare class VercelPgSession<TFullSchema extends Record<string, unknown>, TSchema extends TablesRelationalConfig> extends PgSession<VercelPgQueryResultHKT, TFullSchema, TSchema> {
31
37
  private client;
@@ -33,8 +39,12 @@ export declare class VercelPgSession<TFullSchema extends Record<string, unknown>
33
39
  private options;
34
40
  static readonly [entityKind]: string;
35
41
  private logger;
42
+ private cache;
36
43
  constructor(client: VercelPgClient, dialect: PgDialect, schema: RelationalSchemaConfig<TSchema> | undefined, options?: VercelPgSessionOptions);
37
- prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][]) => T['execute']): PgPreparedQuery<T>;
44
+ prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][]) => T['execute'], queryMetadata?: {
45
+ type: 'select' | 'update' | 'delete' | 'insert';
46
+ tables: string[];
47
+ }, cacheConfig?: WithCacheConfig): PgPreparedQuery<T>;
38
48
  query(query: string, params: unknown[]): Promise<QueryResult>;
39
49
  queryObjects<T extends QueryResultRow>(query: string, params: unknown[]): Promise<QueryResult<T>>;
40
50
  count(sql: SQL): Promise<number>;
@@ -2,6 +2,7 @@ import {
2
2
  types,
3
3
  VercelPool
4
4
  } from "@vercel/postgres";
5
+ import { NoopCache } from "../cache/core/cache.js";
5
6
  import { entityKind } from "../entity.js";
6
7
  import { NoopLogger } from "../logger.js";
7
8
  import { PgTransaction } from "../pg-core/index.js";
@@ -9,8 +10,8 @@ import { PgPreparedQuery, PgSession } from "../pg-core/session.js";
9
10
  import { fillPlaceholders, sql } from "../sql/sql.js";
10
11
  import { mapResultRow } from "../utils.js";
11
12
  class VercelPgPreparedQuery extends PgPreparedQuery {
12
- constructor(client, queryString, params, logger, fields, name, _isResponseInArrayMode, customResultMapper) {
13
- super({ sql: queryString, params });
13
+ constructor(client, queryString, params, logger, cache, queryMetadata, cacheConfig, fields, name, _isResponseInArrayMode, customResultMapper) {
14
+ super({ sql: queryString, params }, cache, queryMetadata, cacheConfig);
14
15
  this.client = client;
15
16
  this.params = params;
16
17
  this.logger = logger;
@@ -101,9 +102,13 @@ class VercelPgPreparedQuery extends PgPreparedQuery {
101
102
  this.logger.logQuery(this.rawQuery.text, params);
102
103
  const { fields, rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } = this;
103
104
  if (!fields && !customResultMapper) {
104
- return client.query(rawQuery, params);
105
+ return this.queryWithCache(rawQuery.text, params, async () => {
106
+ return await client.query(rawQuery, params);
107
+ });
105
108
  }
106
- const { rows } = await client.query(query, params);
109
+ const { rows } = await this.queryWithCache(query.text, params, async () => {
110
+ return await client.query(query, params);
111
+ });
107
112
  if (customResultMapper) {
108
113
  return customResultMapper(rows);
109
114
  }
@@ -112,12 +117,16 @@ class VercelPgPreparedQuery extends PgPreparedQuery {
112
117
  all(placeholderValues = {}) {
113
118
  const params = fillPlaceholders(this.params, placeholderValues);
114
119
  this.logger.logQuery(this.rawQuery.text, params);
115
- return this.client.query(this.rawQuery, params).then((result) => result.rows);
120
+ return this.queryWithCache(this.rawQuery.text, params, async () => {
121
+ return await this.client.query(this.rawQuery, params);
122
+ }).then((result) => result.rows);
116
123
  }
117
124
  values(placeholderValues = {}) {
118
125
  const params = fillPlaceholders(this.params, placeholderValues);
119
126
  this.logger.logQuery(this.rawQuery.text, params);
120
- return this.client.query(this.queryConfig, params).then((result) => result.rows);
127
+ return this.queryWithCache(this.queryConfig.text, params, async () => {
128
+ return await this.client.query(this.queryConfig, params);
129
+ }).then((result) => result.rows);
121
130
  }
122
131
  /** @internal */
123
132
  isResponseInArrayMode() {
@@ -131,15 +140,20 @@ class VercelPgSession extends PgSession {
131
140
  this.schema = schema;
132
141
  this.options = options;
133
142
  this.logger = options.logger ?? new NoopLogger();
143
+ this.cache = options.cache ?? new NoopCache();
134
144
  }
135
145
  static [entityKind] = "VercelPgSession";
136
146
  logger;
137
- prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper) {
147
+ cache;
148
+ prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {
138
149
  return new VercelPgPreparedQuery(
139
150
  this.client,
140
151
  query.sql,
141
152
  query.params,
142
153
  this.logger,
154
+ this.cache,
155
+ queryMetadata,
156
+ cacheConfig,
143
157
  fields,
144
158
  name,
145
159
  isResponseInArrayMode,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/vercel-postgres/session.ts"],"sourcesContent":["import {\n\ttype QueryArrayConfig,\n\ttype QueryConfig,\n\ttype QueryResult,\n\ttype QueryResultRow,\n\ttypes,\n\ttype VercelClient,\n\tVercelPool,\n\ttype VercelPoolClient,\n} from '@vercel/postgres';\nimport { entityKind } from '~/entity.ts';\nimport { type Logger, NoopLogger } from '~/logger.ts';\nimport { type PgDialect, PgTransaction } from '~/pg-core/index.ts';\nimport type { SelectedFieldsOrdered } from '~/pg-core/query-builders/select.types.ts';\nimport type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from '~/pg-core/session.ts';\nimport { PgPreparedQuery, PgSession } from '~/pg-core/session.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, type SQL, sql } from '~/sql/sql.ts';\nimport { type Assume, mapResultRow } from '~/utils.ts';\n\nexport type VercelPgClient = VercelPool | VercelClient | VercelPoolClient;\n\nexport class VercelPgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {\n\tstatic override readonly [entityKind]: string = 'VercelPgPreparedQuery';\n\n\tprivate rawQuery: QueryConfig;\n\tprivate queryConfig: QueryArrayConfig;\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tqueryString: string,\n\t\tprivate params: unknown[],\n\t\tprivate logger: Logger,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => T['execute'],\n\t) {\n\t\tsuper({ sql: queryString, params });\n\t\tthis.rawQuery = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// numeric[]\n\t\t\t\t\tif (typeId === 1231 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp[]\n\t\t\t\t\tif (typeId === 1115 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp with timezone[]\n\t\t\t\t\tif (typeId === 1185 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// interval[]\n\t\t\t\t\tif (typeId === 1187 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// date[]\n\t\t\t\t\tif (typeId === 1182 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t\tthis.queryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\trowMode: 'array',\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// numeric[]\n\t\t\t\t\tif (typeId === 1231 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp[]\n\t\t\t\t\tif (typeId === 1115 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp with timezone[]\n\t\t\t\t\tif (typeId === 1185 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// interval[]\n\t\t\t\t\tif (typeId === 1187 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// date[]\n\t\t\t\t\tif (typeId === 1182 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t}\n\n\tasync execute(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['execute']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\n\t\tconst { fields, rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } = this;\n\t\tif (!fields && !customResultMapper) {\n\t\t\treturn client.query(rawQuery, params);\n\t\t}\n\n\t\tconst { rows } = await client.query(query, params);\n\n\t\tif (customResultMapper) {\n\t\t\treturn customResultMapper(rows);\n\t\t}\n\n\t\treturn rows.map((row) => mapResultRow<T['execute']>(fields!, row, joinsNotNullableMap));\n\t}\n\n\tall(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['all']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\t\treturn this.client.query(this.rawQuery, params).then((result) => result.rows);\n\t}\n\n\tvalues(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['values']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\t\treturn this.client.query(this.queryConfig, params).then((result) => result.rows);\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n\nexport interface VercelPgSessionOptions {\n\tlogger?: Logger;\n}\n\nexport class VercelPgSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgSession<VercelPgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgSession';\n\n\tprivate logger: Logger;\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tdialect: PgDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\tprivate options: VercelPgSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t}\n\n\tprepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][]) => T['execute'],\n\t): PgPreparedQuery<T> {\n\t\treturn new VercelPgPreparedQuery(\n\t\t\tthis.client,\n\t\t\tquery.sql,\n\t\t\tquery.params,\n\t\t\tthis.logger,\n\t\t\tfields,\n\t\t\tname,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\tasync query(query: string, params: unknown[]): Promise<QueryResult> {\n\t\tthis.logger.logQuery(query, params);\n\t\tconst result = await this.client.query({\n\t\t\trowMode: 'array',\n\t\t\ttext: query,\n\t\t\tvalues: params,\n\t\t});\n\t\treturn result;\n\t}\n\n\tasync queryObjects<T extends QueryResultRow>(\n\t\tquery: string,\n\t\tparams: unknown[],\n\t): Promise<QueryResult<T>> {\n\t\treturn this.client.query<T>(query, params);\n\t}\n\n\toverride async count(sql: SQL): Promise<number> {\n\t\tconst result = await this.execute(sql);\n\n\t\treturn Number((result as any)['rows'][0]['count']);\n\t}\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: VercelPgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t\tconfig?: PgTransactionConfig | undefined,\n\t): Promise<T> {\n\t\tconst session = this.client instanceof VercelPool // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t? new VercelPgSession(await this.client.connect(), this.dialect, this.schema, this.options)\n\t\t\t: this;\n\t\tconst tx = new VercelPgTransaction<TFullSchema, TSchema>(this.dialect, session, this.schema);\n\t\tawait tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : undefined}`);\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql`commit`);\n\t\t\treturn result;\n\t\t} catch (error) {\n\t\t\tawait tx.execute(sql`rollback`);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\tif (this.client instanceof VercelPool) { // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t(session.client as VercelPoolClient).release();\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport class VercelPgTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgTransaction<VercelPgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgTransaction';\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: VercelPgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T> {\n\t\tconst savepointName = `sp${this.nestedIndex + 1}`;\n\t\tconst tx = new VercelPgTransaction<TFullSchema, TSchema>(\n\t\t\tthis.dialect,\n\t\t\tthis.session,\n\t\t\tthis.schema,\n\t\t\tthis.nestedIndex + 1,\n\t\t);\n\t\tawait tx.execute(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tawait tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport interface VercelPgQueryResultHKT extends PgQueryResultHKT {\n\ttype: QueryResult<Assume<this['row'], QueryResultRow>>;\n}\n"],"mappings":"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","names":["sql"]}
1
+ {"version":3,"sources":["../../src/vercel-postgres/session.ts"],"sourcesContent":["import {\n\ttype QueryArrayConfig,\n\ttype QueryConfig,\n\ttype QueryResult,\n\ttype QueryResultRow,\n\ttypes,\n\ttype VercelClient,\n\tVercelPool,\n\ttype VercelPoolClient,\n} from '@vercel/postgres';\nimport type { Cache } from '~/cache/core/cache.ts';\nimport { NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind } from '~/entity.ts';\nimport { type Logger, NoopLogger } from '~/logger.ts';\nimport { type PgDialect, PgTransaction } from '~/pg-core/index.ts';\nimport type { SelectedFieldsOrdered } from '~/pg-core/query-builders/select.types.ts';\nimport type { PgQueryResultHKT, PgTransactionConfig, PreparedQueryConfig } from '~/pg-core/session.ts';\nimport { PgPreparedQuery, PgSession } from '~/pg-core/session.ts';\nimport type { RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { fillPlaceholders, type Query, type SQL, sql } from '~/sql/sql.ts';\nimport { type Assume, mapResultRow } from '~/utils.ts';\n\nexport type VercelPgClient = VercelPool | VercelClient | VercelPoolClient;\n\nexport class VercelPgPreparedQuery<T extends PreparedQueryConfig> extends PgPreparedQuery<T> {\n\tstatic override readonly [entityKind]: string = 'VercelPgPreparedQuery';\n\n\tprivate rawQuery: QueryConfig;\n\tprivate queryConfig: QueryArrayConfig;\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tqueryString: string,\n\t\tprivate params: unknown[],\n\t\tprivate logger: Logger,\n\t\tcache: Cache,\n\t\tqueryMetadata: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\tcacheConfig: WithCacheConfig | undefined,\n\t\tprivate fields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tprivate _isResponseInArrayMode: boolean,\n\t\tprivate customResultMapper?: (rows: unknown[][]) => T['execute'],\n\t) {\n\t\tsuper({ sql: queryString, params }, cache, queryMetadata, cacheConfig);\n\t\tthis.rawQuery = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// numeric[]\n\t\t\t\t\tif (typeId === 1231 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp[]\n\t\t\t\t\tif (typeId === 1115 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp with timezone[]\n\t\t\t\t\tif (typeId === 1185 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// interval[]\n\t\t\t\t\tif (typeId === 1187 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// date[]\n\t\t\t\t\tif (typeId === 1182 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t\tthis.queryConfig = {\n\t\t\tname,\n\t\t\ttext: queryString,\n\t\t\trowMode: 'array',\n\t\t\ttypes: {\n\t\t\t\t// @ts-ignore\n\t\t\t\tgetTypeParser: (typeId, format) => {\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMPTZ) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.TIMESTAMP) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.DATE) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\tif (typeId === types.builtins.INTERVAL) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// numeric[]\n\t\t\t\t\tif (typeId === 1231 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp[]\n\t\t\t\t\tif (typeId === 1115 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// timestamp with timezone[]\n\t\t\t\t\tif (typeId === 1185 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// interval[]\n\t\t\t\t\tif (typeId === 1187 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// date[]\n\t\t\t\t\tif (typeId === 1182 as any) {\n\t\t\t\t\t\treturn (val: any) => val;\n\t\t\t\t\t}\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\treturn types.getTypeParser(typeId, format);\n\t\t\t\t},\n\t\t\t},\n\t\t};\n\t}\n\n\tasync execute(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['execute']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\n\t\tconst { fields, rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } = this;\n\t\tif (!fields && !customResultMapper) {\n\t\t\treturn this.queryWithCache(rawQuery.text, params, async () => {\n\t\t\t\treturn await client.query(rawQuery, params);\n\t\t\t});\n\t\t}\n\n\t\tconst { rows } = await this.queryWithCache(query.text, params, async () => {\n\t\t\treturn await client.query(query, params);\n\t\t});\n\n\t\tif (customResultMapper) {\n\t\t\treturn customResultMapper(rows);\n\t\t}\n\n\t\treturn rows.map((row) => mapResultRow<T['execute']>(fields!, row, joinsNotNullableMap));\n\t}\n\n\tall(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['all']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\t\treturn this.queryWithCache(this.rawQuery.text, params, async () => {\n\t\t\treturn await this.client.query(this.rawQuery, params);\n\t\t}).then((result) => result.rows);\n\t}\n\n\tvalues(placeholderValues: Record<string, unknown> | undefined = {}): Promise<T['values']> {\n\t\tconst params = fillPlaceholders(this.params, placeholderValues);\n\t\tthis.logger.logQuery(this.rawQuery.text, params);\n\t\treturn this.queryWithCache(this.queryConfig.text, params, async () => {\n\t\t\treturn await this.client.query(this.queryConfig, params);\n\t\t}).then((result) => result.rows);\n\t}\n\n\t/** @internal */\n\tisResponseInArrayMode(): boolean {\n\t\treturn this._isResponseInArrayMode;\n\t}\n}\n\nexport interface VercelPgSessionOptions {\n\tlogger?: Logger;\n\tcache?: Cache;\n}\n\nexport class VercelPgSession<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgSession<VercelPgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgSession';\n\n\tprivate logger: Logger;\n\tprivate cache: Cache;\n\n\tconstructor(\n\t\tprivate client: VercelPgClient,\n\t\tdialect: PgDialect,\n\t\tprivate schema: RelationalSchemaConfig<TSchema> | undefined,\n\t\tprivate options: VercelPgSessionOptions = {},\n\t) {\n\t\tsuper(dialect);\n\t\tthis.logger = options.logger ?? new NoopLogger();\n\t\tthis.cache = options.cache ?? new NoopCache();\n\t}\n\n\tprepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(\n\t\tquery: Query,\n\t\tfields: SelectedFieldsOrdered | undefined,\n\t\tname: string | undefined,\n\t\tisResponseInArrayMode: boolean,\n\t\tcustomResultMapper?: (rows: unknown[][]) => T['execute'],\n\t\tqueryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t},\n\t\tcacheConfig?: WithCacheConfig,\n\t): PgPreparedQuery<T> {\n\t\treturn new VercelPgPreparedQuery(\n\t\t\tthis.client,\n\t\t\tquery.sql,\n\t\t\tquery.params,\n\t\t\tthis.logger,\n\t\t\tthis.cache,\n\t\t\tqueryMetadata,\n\t\t\tcacheConfig,\n\t\t\tfields,\n\t\t\tname,\n\t\t\tisResponseInArrayMode,\n\t\t\tcustomResultMapper,\n\t\t);\n\t}\n\n\tasync query(query: string, params: unknown[]): Promise<QueryResult> {\n\t\tthis.logger.logQuery(query, params);\n\t\tconst result = await this.client.query({\n\t\t\trowMode: 'array',\n\t\t\ttext: query,\n\t\t\tvalues: params,\n\t\t});\n\t\treturn result;\n\t}\n\n\tasync queryObjects<T extends QueryResultRow>(\n\t\tquery: string,\n\t\tparams: unknown[],\n\t): Promise<QueryResult<T>> {\n\t\treturn this.client.query<T>(query, params);\n\t}\n\n\toverride async count(sql: SQL): Promise<number> {\n\t\tconst result = await this.execute(sql);\n\n\t\treturn Number((result as any)['rows'][0]['count']);\n\t}\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: VercelPgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t\tconfig?: PgTransactionConfig | undefined,\n\t): Promise<T> {\n\t\tconst session = this.client instanceof VercelPool // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t? new VercelPgSession(await this.client.connect(), this.dialect, this.schema, this.options)\n\t\t\t: this;\n\t\tconst tx = new VercelPgTransaction<TFullSchema, TSchema>(this.dialect, session, this.schema);\n\t\tawait tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : undefined}`);\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql`commit`);\n\t\t\treturn result;\n\t\t} catch (error) {\n\t\t\tawait tx.execute(sql`rollback`);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\tif (this.client instanceof VercelPool) { // eslint-disable-line no-instanceof/no-instanceof\n\t\t\t\t(session.client as VercelPoolClient).release();\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport class VercelPgTransaction<\n\tTFullSchema extends Record<string, unknown>,\n\tTSchema extends TablesRelationalConfig,\n> extends PgTransaction<VercelPgQueryResultHKT, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'VercelPgTransaction';\n\n\toverride async transaction<T>(\n\t\ttransaction: (tx: VercelPgTransaction<TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T> {\n\t\tconst savepointName = `sp${this.nestedIndex + 1}`;\n\t\tconst tx = new VercelPgTransaction<TFullSchema, TSchema>(\n\t\t\tthis.dialect,\n\t\t\tthis.session,\n\t\t\tthis.schema,\n\t\t\tthis.nestedIndex + 1,\n\t\t);\n\t\tawait tx.execute(sql.raw(`savepoint ${savepointName}`));\n\t\ttry {\n\t\t\tconst result = await transaction(tx);\n\t\t\tawait tx.execute(sql.raw(`release savepoint ${savepointName}`));\n\t\t\treturn result;\n\t\t} catch (err) {\n\t\t\tawait tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n\t\t\tthrow err;\n\t\t}\n\t}\n}\n\nexport interface VercelPgQueryResultHKT extends PgQueryResultHKT {\n\ttype: QueryResult<Assume<this['row'], QueryResultRow>>;\n}\n"],"mappings":"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","names":["sql"]}
package/version.cjs CHANGED
@@ -26,10 +26,10 @@ __export(version_exports, {
26
26
  module.exports = __toCommonJS(version_exports);
27
27
 
28
28
  // package.json
29
- var version = "0.43.1-9811cd4";
29
+ var version = "0.43.1-d1468f0";
30
30
 
31
31
  // src/version.ts
32
- var compatibilityVersion = 11;
32
+ var compatibilityVersion = 10;
33
33
  // Annotate the CommonJS export names for ESM import in node:
34
34
  0 && (module.exports = {
35
35
  compatibilityVersion,
package/version.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/version.ts"],"sourcesContent":["// @ts-ignore - imported using Rollup json plugin\nexport { version as npmVersion } from '../package.json';\n// In version 7, we changed the PostgreSQL indexes API\nexport const compatibilityVersion = 11;\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,qBAAsC;AAE/B,MAAM,uBAAuB;","names":[]}
1
+ {"version":3,"sources":["../src/version.ts"],"sourcesContent":["// @ts-ignore - imported using Rollup json plugin\nexport { version as npmVersion } from '../package.json';\n// In version 7, we changed the PostgreSQL indexes API\nexport const compatibilityVersion = 10;\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,qBAAsC;AAE/B,MAAM,uBAAuB;","names":[]}
package/version.d.cts CHANGED
@@ -1,5 +1,5 @@
1
- var version = "0.43.1-9811cd4";
1
+ var version = "0.43.1-d1468f0";
2
2
 
3
- declare const compatibilityVersion = 11;
3
+ declare const compatibilityVersion = 10;
4
4
 
5
5
  export { compatibilityVersion, version as npmVersion };
package/version.d.ts CHANGED
@@ -1,5 +1,5 @@
1
- var version = "0.43.1-9811cd4";
1
+ var version = "0.43.1-d1468f0";
2
2
 
3
- declare const compatibilityVersion = 11;
3
+ declare const compatibilityVersion = 10;
4
4
 
5
5
  export { compatibilityVersion, version as npmVersion };
package/version.js CHANGED
@@ -1,8 +1,8 @@
1
1
  // package.json
2
- var version = "0.43.1-9811cd4";
2
+ var version = "0.43.1-d1468f0";
3
3
 
4
4
  // src/version.ts
5
- var compatibilityVersion = 11;
5
+ var compatibilityVersion = 10;
6
6
  export {
7
7
  compatibilityVersion,
8
8
  version as npmVersion
package/version.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/version.ts"],"sourcesContent":["// @ts-ignore - imported using Rollup json plugin\nexport { version as npmVersion } from '../package.json';\n// In version 7, we changed the PostgreSQL indexes API\nexport const compatibilityVersion = 11;\n"],"mappings":"AACA,SAAoB,eAAkB;AAE/B,MAAM,uBAAuB;","names":[]}
1
+ {"version":3,"sources":["../src/version.ts"],"sourcesContent":["// @ts-ignore - imported using Rollup json plugin\nexport { version as npmVersion } from '../package.json';\n// In version 7, we changed the PostgreSQL indexes API\nexport const compatibilityVersion = 10;\n"],"mappings":"AACA,SAAoB,eAAkB;AAE/B,MAAM,uBAAuB;","names":[]}
@@ -39,7 +39,8 @@ class XataHttpDriver {
39
39
  static [import_entity.entityKind] = "XataDriver";
40
40
  createSession(schema) {
41
41
  return new import_session.XataHttpSession(this.client, this.dialect, schema, {
42
- logger: this.options.logger
42
+ logger: this.options.logger,
43
+ cache: this.options.cache
43
44
  });
44
45
  }
45
46
  initMappers() {
@@ -65,7 +66,7 @@ function drizzle(client, config = {}) {
65
66
  tableNamesMap: tablesConfig.tableNamesMap
66
67
  };
67
68
  }
68
- const driver = new XataHttpDriver(client, dialect, { logger });
69
+ const driver = new XataHttpDriver(client, dialect, { logger, cache: config.cache });
69
70
  const session = driver.createSession(schema);
70
71
  const db = new XataHttpDatabase(
71
72
  dialect,
@@ -73,6 +74,10 @@ function drizzle(client, config = {}) {
73
74
  schema
74
75
  );
75
76
  db.$client = client;
77
+ db.$cache = config.cache;
78
+ if (db.$cache) {
79
+ db.$cache["invalidate"] = config.cache?.onMutate;
80
+ }
76
81
  return db;
77
82
  }
78
83
  // Annotate the CommonJS export names for ESM import in node:
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/xata-http/driver.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport type { Logger } from '~/logger.ts';\nimport { DefaultLogger } from '~/logger.ts';\nimport { PgDatabase } from '~/pg-core/db.ts';\nimport { PgDialect } from '~/pg-core/dialect.ts';\nimport type { ExtractTablesWithRelations, RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { createTableRelationsHelpers, extractTablesRelationalConfig } from '~/relations.ts';\nimport type { DrizzleConfig } from '~/utils.ts';\nimport type { XataHttpClient, XataHttpQueryResultHKT } from './session.ts';\nimport { XataHttpSession } from './session.ts';\n\nexport interface XataDriverOptions {\n\tlogger?: Logger;\n}\n\nexport class XataHttpDriver {\n\tstatic readonly [entityKind]: string = 'XataDriver';\n\n\tconstructor(\n\t\tprivate client: XataHttpClient,\n\t\tprivate dialect: PgDialect,\n\t\tprivate options: XataDriverOptions = {},\n\t) {\n\t\tthis.initMappers();\n\t}\n\n\tcreateSession(\n\t\tschema: RelationalSchemaConfig<TablesRelationalConfig> | undefined,\n\t): XataHttpSession<Record<string, unknown>, TablesRelationalConfig> {\n\t\treturn new XataHttpSession(this.client, this.dialect, schema, {\n\t\t\tlogger: this.options.logger,\n\t\t});\n\t}\n\n\tinitMappers() {\n\t\t// TODO: Add custom type parsers\n\t}\n}\n\nexport class XataHttpDatabase<TSchema extends Record<string, unknown> = Record<string, never>>\n\textends PgDatabase<XataHttpQueryResultHKT, TSchema>\n{\n\tstatic override readonly [entityKind]: string = 'XataHttpDatabase';\n\n\t/** @internal */\n\tdeclare readonly session: XataHttpSession<TSchema, ExtractTablesWithRelations<TSchema>>;\n}\n\nexport function drizzle<TSchema extends Record<string, unknown> = Record<string, never>>(\n\tclient: XataHttpClient,\n\tconfig: DrizzleConfig<TSchema> = {},\n): XataHttpDatabase<TSchema> & {\n\t$client: XataHttpClient;\n} {\n\tconst dialect = new PgDialect({ casing: config.casing });\n\tlet logger;\n\tif (config.logger === true) {\n\t\tlogger = new DefaultLogger();\n\t} else if (config.logger !== false) {\n\t\tlogger = config.logger;\n\t}\n\n\tlet schema: RelationalSchemaConfig<TablesRelationalConfig> | undefined;\n\tif (config.schema) {\n\t\tconst tablesConfig = extractTablesRelationalConfig(config.schema, createTableRelationsHelpers);\n\t\tschema = {\n\t\t\tfullSchema: config.schema,\n\t\t\tschema: tablesConfig.tables,\n\t\t\ttableNamesMap: tablesConfig.tableNamesMap,\n\t\t};\n\t}\n\n\tconst driver = new XataHttpDriver(client, dialect, { logger });\n\tconst session = driver.createSession(schema);\n\n\tconst db = new XataHttpDatabase(\n\t\tdialect,\n\t\tsession,\n\t\tschema as RelationalSchemaConfig<ExtractTablesWithRelations<TSchema>> | undefined,\n\t);\n\t(<any> db).$client = client;\n\n\treturn db as any;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAE3B,oBAA8B;AAC9B,gBAA2B;AAC3B,qBAA0B;AAE1B,uBAA2E;AAG3E,qBAAgC;AAMzB,MAAM,eAAe;AAAA,EAG3B,YACS,QACA,SACA,UAA6B,CAAC,GACrC;AAHO;AACA;AACA;AAER,SAAK,YAAY;AAAA,EAClB;AAAA,EARA,QAAiB,wBAAU,IAAY;AAAA,EAUvC,cACC,QACmE;AACnE,WAAO,IAAI,+BAAgB,KAAK,QAAQ,KAAK,SAAS,QAAQ;AAAA,MAC7D,QAAQ,KAAK,QAAQ;AAAA,IACtB,CAAC;AAAA,EACF;AAAA,EAEA,cAAc;AAAA,EAEd;AACD;AAEO,MAAM,yBACJ,qBACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAIjD;AAEO,SAAS,QACf,QACA,SAAiC,CAAC,GAGjC;AACD,QAAM,UAAU,IAAI,yBAAU,EAAE,QAAQ,OAAO,OAAO,CAAC;AACvD,MAAI;AACJ,MAAI,OAAO,WAAW,MAAM;AAC3B,aAAS,IAAI,4BAAc;AAAA,EAC5B,WAAW,OAAO,WAAW,OAAO;AACnC,aAAS,OAAO;AAAA,EACjB;AAEA,MAAI;AACJ,MAAI,OAAO,QAAQ;AAClB,UAAM,mBAAe,gDAA8B,OAAO,QAAQ,4CAA2B;AAC7F,aAAS;AAAA,MACR,YAAY,OAAO;AAAA,MACnB,QAAQ,aAAa;AAAA,MACrB,eAAe,aAAa;AAAA,IAC7B;AAAA,EACD;AAEA,QAAM,SAAS,IAAI,eAAe,QAAQ,SAAS,EAAE,OAAO,CAAC;AAC7D,QAAM,UAAU,OAAO,cAAc,MAAM;AAE3C,QAAM,KAAK,IAAI;AAAA,IACd;AAAA,IACA;AAAA,IACA;AAAA,EACD;AACA,EAAO,GAAI,UAAU;AAErB,SAAO;AACR;","names":[]}
1
+ {"version":3,"sources":["../../src/xata-http/driver.ts"],"sourcesContent":["import type { Cache } from '~/cache/core/cache.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { Logger } from '~/logger.ts';\nimport { DefaultLogger } from '~/logger.ts';\nimport { PgDatabase } from '~/pg-core/db.ts';\nimport { PgDialect } from '~/pg-core/dialect.ts';\nimport type { ExtractTablesWithRelations, RelationalSchemaConfig, TablesRelationalConfig } from '~/relations.ts';\nimport { createTableRelationsHelpers, extractTablesRelationalConfig } from '~/relations.ts';\nimport type { DrizzleConfig } from '~/utils.ts';\nimport type { XataHttpClient, XataHttpQueryResultHKT } from './session.ts';\nimport { XataHttpSession } from './session.ts';\n\nexport interface XataDriverOptions {\n\tlogger?: Logger;\n\tcache?: Cache;\n}\n\nexport class XataHttpDriver {\n\tstatic readonly [entityKind]: string = 'XataDriver';\n\n\tconstructor(\n\t\tprivate client: XataHttpClient,\n\t\tprivate dialect: PgDialect,\n\t\tprivate options: XataDriverOptions = {},\n\t) {\n\t\tthis.initMappers();\n\t}\n\n\tcreateSession(\n\t\tschema: RelationalSchemaConfig<TablesRelationalConfig> | undefined,\n\t): XataHttpSession<Record<string, unknown>, TablesRelationalConfig> {\n\t\treturn new XataHttpSession(this.client, this.dialect, schema, {\n\t\t\tlogger: this.options.logger,\n\t\t\tcache: this.options.cache,\n\t\t});\n\t}\n\n\tinitMappers() {\n\t\t// TODO: Add custom type parsers\n\t}\n}\n\nexport class XataHttpDatabase<TSchema extends Record<string, unknown> = Record<string, never>>\n\textends PgDatabase<XataHttpQueryResultHKT, TSchema>\n{\n\tstatic override readonly [entityKind]: string = 'XataHttpDatabase';\n\n\t/** @internal */\n\tdeclare readonly session: XataHttpSession<TSchema, ExtractTablesWithRelations<TSchema>>;\n}\n\nexport function drizzle<TSchema extends Record<string, unknown> = Record<string, never>>(\n\tclient: XataHttpClient,\n\tconfig: DrizzleConfig<TSchema> = {},\n): XataHttpDatabase<TSchema> & {\n\t$client: XataHttpClient;\n} {\n\tconst dialect = new PgDialect({ casing: config.casing });\n\tlet logger;\n\tif (config.logger === true) {\n\t\tlogger = new DefaultLogger();\n\t} else if (config.logger !== false) {\n\t\tlogger = config.logger;\n\t}\n\n\tlet schema: RelationalSchemaConfig<TablesRelationalConfig> | undefined;\n\tif (config.schema) {\n\t\tconst tablesConfig = extractTablesRelationalConfig(config.schema, createTableRelationsHelpers);\n\t\tschema = {\n\t\t\tfullSchema: config.schema,\n\t\t\tschema: tablesConfig.tables,\n\t\t\ttableNamesMap: tablesConfig.tableNamesMap,\n\t\t};\n\t}\n\n\tconst driver = new XataHttpDriver(client, dialect, { logger, cache: config.cache });\n\tconst session = driver.createSession(schema);\n\n\tconst db = new XataHttpDatabase(\n\t\tdialect,\n\t\tsession,\n\t\tschema as RelationalSchemaConfig<ExtractTablesWithRelations<TSchema>> | undefined,\n\t);\n\t(<any> db).$client = client;\n\t(<any> db).$cache = config.cache;\n\tif ((<any> db).$cache) {\n\t\t(<any> db).$cache['invalidate'] = config.cache?.onMutate;\n\t}\n\n\treturn db as any;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAA8B;AAC9B,gBAA2B;AAC3B,qBAA0B;AAE1B,uBAA2E;AAG3E,qBAAgC;AAOzB,MAAM,eAAe;AAAA,EAG3B,YACS,QACA,SACA,UAA6B,CAAC,GACrC;AAHO;AACA;AACA;AAER,SAAK,YAAY;AAAA,EAClB;AAAA,EARA,QAAiB,wBAAU,IAAY;AAAA,EAUvC,cACC,QACmE;AACnE,WAAO,IAAI,+BAAgB,KAAK,QAAQ,KAAK,SAAS,QAAQ;AAAA,MAC7D,QAAQ,KAAK,QAAQ;AAAA,MACrB,OAAO,KAAK,QAAQ;AAAA,IACrB,CAAC;AAAA,EACF;AAAA,EAEA,cAAc;AAAA,EAEd;AACD;AAEO,MAAM,yBACJ,qBACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAIjD;AAEO,SAAS,QACf,QACA,SAAiC,CAAC,GAGjC;AACD,QAAM,UAAU,IAAI,yBAAU,EAAE,QAAQ,OAAO,OAAO,CAAC;AACvD,MAAI;AACJ,MAAI,OAAO,WAAW,MAAM;AAC3B,aAAS,IAAI,4BAAc;AAAA,EAC5B,WAAW,OAAO,WAAW,OAAO;AACnC,aAAS,OAAO;AAAA,EACjB;AAEA,MAAI;AACJ,MAAI,OAAO,QAAQ;AAClB,UAAM,mBAAe,gDAA8B,OAAO,QAAQ,4CAA2B;AAC7F,aAAS;AAAA,MACR,YAAY,OAAO;AAAA,MACnB,QAAQ,aAAa;AAAA,MACrB,eAAe,aAAa;AAAA,IAC7B;AAAA,EACD;AAEA,QAAM,SAAS,IAAI,eAAe,QAAQ,SAAS,EAAE,QAAQ,OAAO,OAAO,MAAM,CAAC;AAClF,QAAM,UAAU,OAAO,cAAc,MAAM;AAE3C,QAAM,KAAK,IAAI;AAAA,IACd;AAAA,IACA;AAAA,IACA;AAAA,EACD;AACA,EAAO,GAAI,UAAU;AACrB,EAAO,GAAI,SAAS,OAAO;AAC3B,MAAW,GAAI,QAAQ;AACtB,IAAO,GAAI,OAAO,YAAY,IAAI,OAAO,OAAO;AAAA,EACjD;AAEA,SAAO;AACR;","names":[]}
@@ -1,3 +1,4 @@
1
+ import type { Cache } from "../cache/core/cache.cjs";
1
2
  import { entityKind } from "../entity.cjs";
2
3
  import type { Logger } from "../logger.cjs";
3
4
  import { PgDatabase } from "../pg-core/db.cjs";
@@ -8,6 +9,7 @@ import type { XataHttpClient, XataHttpQueryResultHKT } from "./session.cjs";
8
9
  import { XataHttpSession } from "./session.cjs";
9
10
  export interface XataDriverOptions {
10
11
  logger?: Logger;
12
+ cache?: Cache;
11
13
  }
12
14
  export declare class XataHttpDriver {
13
15
  private client;
@@ -1,3 +1,4 @@
1
+ import type { Cache } from "../cache/core/cache.js";
1
2
  import { entityKind } from "../entity.js";
2
3
  import type { Logger } from "../logger.js";
3
4
  import { PgDatabase } from "../pg-core/db.js";
@@ -8,6 +9,7 @@ import type { XataHttpClient, XataHttpQueryResultHKT } from "./session.js";
8
9
  import { XataHttpSession } from "./session.js";
9
10
  export interface XataDriverOptions {
10
11
  logger?: Logger;
12
+ cache?: Cache;
11
13
  }
12
14
  export declare class XataHttpDriver {
13
15
  private client;