drizzle-orm 0.43.1-b08434e → 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 (491) 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/cache/core/cache.cjs +47 -0
  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/cache/core/index.cjs +23 -0
  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/cache/core/types.cjs +17 -0
  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/core/types.js.map +1 -0
  49. package/cache/upstash/cache.cjs +191 -0
  50. package/cache/upstash/cache.cjs.map +1 -0
  51. package/cache/upstash/cache.d.cts +59 -0
  52. package/cache/upstash/cache.d.ts +59 -0
  53. package/cache/upstash/cache.js +166 -0
  54. package/cache/upstash/cache.js.map +1 -0
  55. package/cache/upstash/index.cjs +23 -0
  56. package/cache/upstash/index.cjs.map +1 -0
  57. package/cache/upstash/index.d.cts +1 -0
  58. package/cache/upstash/index.d.ts +1 -0
  59. package/cache/upstash/index.js +2 -0
  60. package/cache/upstash/index.js.map +1 -0
  61. package/d1/driver.cjs +5 -1
  62. package/d1/driver.cjs.map +1 -1
  63. package/d1/driver.js +5 -1
  64. package/d1/driver.js.map +1 -1
  65. package/d1/session.cjs +23 -9
  66. package/d1/session.cjs.map +1 -1
  67. package/d1/session.d.cts +12 -2
  68. package/d1/session.d.ts +12 -2
  69. package/d1/session.js +23 -9
  70. package/d1/session.js.map +1 -1
  71. package/durable-sqlite/session.cjs +1 -1
  72. package/durable-sqlite/session.cjs.map +1 -1
  73. package/durable-sqlite/session.js +1 -1
  74. package/durable-sqlite/session.js.map +1 -1
  75. package/errors/index.cjs +40 -0
  76. package/errors/index.cjs.map +1 -0
  77. package/errors/index.d.cts +6 -0
  78. package/errors/index.d.ts +6 -0
  79. package/errors/index.js +16 -0
  80. package/errors/index.js.map +1 -0
  81. package/gel/driver.cjs +9 -2
  82. package/gel/driver.cjs.map +1 -1
  83. package/gel/driver.d.cts +2 -0
  84. package/gel/driver.d.ts +2 -0
  85. package/gel/driver.js +9 -2
  86. package/gel/driver.js.map +1 -1
  87. package/gel/session.cjs +25 -10
  88. package/gel/session.cjs.map +1 -1
  89. package/gel/session.d.cts +12 -2
  90. package/gel/session.d.ts +12 -2
  91. package/gel/session.js +25 -10
  92. package/gel/session.js.map +1 -1
  93. package/gel-core/db.cjs +3 -0
  94. package/gel-core/db.cjs.map +1 -1
  95. package/gel-core/db.d.cts +4 -0
  96. package/gel-core/db.d.ts +4 -0
  97. package/gel-core/db.js +3 -0
  98. package/gel-core/db.js.map +1 -1
  99. package/gel-core/query-builders/delete.cjs +5 -1
  100. package/gel-core/query-builders/delete.cjs.map +1 -1
  101. package/gel-core/query-builders/delete.js +5 -1
  102. package/gel-core/query-builders/delete.js.map +1 -1
  103. package/gel-core/query-builders/insert.cjs +5 -1
  104. package/gel-core/query-builders/insert.cjs.map +1 -1
  105. package/gel-core/query-builders/insert.js +5 -1
  106. package/gel-core/query-builders/insert.js.map +1 -1
  107. package/gel-core/query-builders/select.cjs +29 -4
  108. package/gel-core/query-builders/select.cjs.map +1 -1
  109. package/gel-core/query-builders/select.d.cts +9 -0
  110. package/gel-core/query-builders/select.d.ts +9 -0
  111. package/gel-core/query-builders/select.js +29 -4
  112. package/gel-core/query-builders/select.js.map +1 -1
  113. package/gel-core/query-builders/update.cjs +5 -1
  114. package/gel-core/query-builders/update.cjs.map +1 -1
  115. package/gel-core/query-builders/update.js +5 -1
  116. package/gel-core/query-builders/update.js.map +1 -1
  117. package/gel-core/session.cjs +79 -1
  118. package/gel-core/session.cjs.map +1 -1
  119. package/gel-core/session.d.cts +14 -3
  120. package/gel-core/session.d.ts +14 -3
  121. package/gel-core/session.js +80 -2
  122. package/gel-core/session.js.map +1 -1
  123. package/gel-core/utils.cjs +16 -0
  124. package/gel-core/utils.cjs.map +1 -1
  125. package/gel-core/utils.d.cts +8 -4
  126. package/gel-core/utils.d.ts +8 -4
  127. package/gel-core/utils.js +15 -0
  128. package/gel-core/utils.js.map +1 -1
  129. package/libsql/driver-core.cjs +5 -1
  130. package/libsql/driver-core.cjs.map +1 -1
  131. package/libsql/driver-core.js +5 -1
  132. package/libsql/driver-core.js.map +1 -1
  133. package/libsql/session.cjs +27 -13
  134. package/libsql/session.cjs.map +1 -1
  135. package/libsql/session.d.cts +12 -2
  136. package/libsql/session.d.ts +12 -2
  137. package/libsql/session.js +27 -13
  138. package/libsql/session.js.map +1 -1
  139. package/mysql-core/db.cjs +3 -0
  140. package/mysql-core/db.cjs.map +1 -1
  141. package/mysql-core/db.d.cts +4 -0
  142. package/mysql-core/db.d.ts +4 -0
  143. package/mysql-core/db.js +3 -0
  144. package/mysql-core/db.js.map +1 -1
  145. package/mysql-core/query-builders/delete.cjs +9 -1
  146. package/mysql-core/query-builders/delete.cjs.map +1 -1
  147. package/mysql-core/query-builders/delete.js +9 -1
  148. package/mysql-core/query-builders/delete.js.map +1 -1
  149. package/mysql-core/query-builders/insert.cjs +8 -1
  150. package/mysql-core/query-builders/insert.cjs.map +1 -1
  151. package/mysql-core/query-builders/insert.d.cts +2 -0
  152. package/mysql-core/query-builders/insert.d.ts +2 -0
  153. package/mysql-core/query-builders/insert.js +8 -1
  154. package/mysql-core/query-builders/insert.js.map +1 -1
  155. package/mysql-core/query-builders/select.cjs +27 -3
  156. package/mysql-core/query-builders/select.cjs.map +1 -1
  157. package/mysql-core/query-builders/select.d.cts +9 -0
  158. package/mysql-core/query-builders/select.d.ts +9 -0
  159. package/mysql-core/query-builders/select.js +28 -4
  160. package/mysql-core/query-builders/select.js.map +1 -1
  161. package/mysql-core/query-builders/update.cjs +11 -1
  162. package/mysql-core/query-builders/update.cjs.map +1 -1
  163. package/mysql-core/query-builders/update.d.cts +2 -0
  164. package/mysql-core/query-builders/update.d.ts +2 -0
  165. package/mysql-core/query-builders/update.js +11 -1
  166. package/mysql-core/query-builders/update.js.map +1 -1
  167. package/mysql-core/session.cjs +80 -0
  168. package/mysql-core/session.cjs.map +1 -1
  169. package/mysql-core/session.d.cts +15 -2
  170. package/mysql-core/session.d.ts +15 -2
  171. package/mysql-core/session.js +81 -1
  172. package/mysql-core/session.js.map +1 -1
  173. package/mysql-core/utils.cjs +16 -0
  174. package/mysql-core/utils.cjs.map +1 -1
  175. package/mysql-core/utils.d.cts +6 -2
  176. package/mysql-core/utils.d.ts +6 -2
  177. package/mysql-core/utils.js +15 -0
  178. package/mysql-core/utils.js.map +1 -1
  179. package/mysql-proxy/session.cjs +15 -5
  180. package/mysql-proxy/session.cjs.map +1 -1
  181. package/mysql-proxy/session.d.cts +12 -2
  182. package/mysql-proxy/session.d.ts +12 -2
  183. package/mysql-proxy/session.js +15 -5
  184. package/mysql-proxy/session.js.map +1 -1
  185. package/mysql2/driver.cjs +10 -2
  186. package/mysql2/driver.cjs.map +1 -1
  187. package/mysql2/driver.d.cts +2 -0
  188. package/mysql2/driver.d.ts +2 -0
  189. package/mysql2/driver.js +10 -2
  190. package/mysql2/driver.js.map +1 -1
  191. package/mysql2/session.cjs +15 -5
  192. package/mysql2/session.cjs.map +1 -1
  193. package/mysql2/session.d.cts +12 -2
  194. package/mysql2/session.d.ts +12 -2
  195. package/mysql2/session.js +15 -5
  196. package/mysql2/session.js.map +1 -1
  197. package/neon-http/driver.cjs +9 -2
  198. package/neon-http/driver.cjs.map +1 -1
  199. package/neon-http/driver.d.cts +2 -0
  200. package/neon-http/driver.d.ts +2 -0
  201. package/neon-http/driver.js +9 -2
  202. package/neon-http/driver.js.map +1 -1
  203. package/neon-http/session.cjs +25 -15
  204. package/neon-http/session.cjs.map +1 -1
  205. package/neon-http/session.d.cts +12 -2
  206. package/neon-http/session.d.ts +12 -2
  207. package/neon-http/session.js +25 -15
  208. package/neon-http/session.js.map +1 -1
  209. package/neon-serverless/driver.cjs +9 -2
  210. package/neon-serverless/driver.cjs.map +1 -1
  211. package/neon-serverless/driver.d.cts +2 -0
  212. package/neon-serverless/driver.d.ts +2 -0
  213. package/neon-serverless/driver.js +9 -2
  214. package/neon-serverless/driver.js.map +1 -1
  215. package/neon-serverless/session.cjs +21 -7
  216. package/neon-serverless/session.cjs.map +1 -1
  217. package/neon-serverless/session.d.cts +12 -2
  218. package/neon-serverless/session.d.ts +12 -2
  219. package/neon-serverless/session.js +21 -7
  220. package/neon-serverless/session.js.map +1 -1
  221. package/node-postgres/driver.cjs +9 -2
  222. package/node-postgres/driver.cjs.map +1 -1
  223. package/node-postgres/driver.d.cts +2 -0
  224. package/node-postgres/driver.d.ts +2 -0
  225. package/node-postgres/driver.js +9 -2
  226. package/node-postgres/driver.js.map +1 -1
  227. package/node-postgres/session.cjs +19 -6
  228. package/node-postgres/session.cjs.map +1 -1
  229. package/node-postgres/session.d.cts +13 -2
  230. package/node-postgres/session.d.ts +13 -2
  231. package/node-postgres/session.js +19 -6
  232. package/node-postgres/session.js.map +1 -1
  233. package/op-sqlite/driver.cjs +5 -1
  234. package/op-sqlite/driver.cjs.map +1 -1
  235. package/op-sqlite/driver.js +5 -1
  236. package/op-sqlite/driver.js.map +1 -1
  237. package/op-sqlite/session.cjs +23 -9
  238. package/op-sqlite/session.cjs.map +1 -1
  239. package/op-sqlite/session.d.cts +12 -2
  240. package/op-sqlite/session.d.ts +12 -2
  241. package/op-sqlite/session.js +23 -9
  242. package/op-sqlite/session.js.map +1 -1
  243. package/package.json +75 -10
  244. package/pg-core/db.cjs +3 -0
  245. package/pg-core/db.cjs.map +1 -1
  246. package/pg-core/db.d.cts +4 -0
  247. package/pg-core/db.d.ts +4 -0
  248. package/pg-core/db.js +3 -0
  249. package/pg-core/db.js.map +1 -1
  250. package/pg-core/query-builders/delete.cjs +6 -1
  251. package/pg-core/query-builders/delete.cjs.map +1 -1
  252. package/pg-core/query-builders/delete.d.cts +3 -1
  253. package/pg-core/query-builders/delete.d.ts +3 -1
  254. package/pg-core/query-builders/delete.js +6 -1
  255. package/pg-core/query-builders/delete.js.map +1 -1
  256. package/pg-core/query-builders/insert.cjs +6 -1
  257. package/pg-core/query-builders/insert.cjs.map +1 -1
  258. package/pg-core/query-builders/insert.d.cts +2 -0
  259. package/pg-core/query-builders/insert.d.ts +2 -0
  260. package/pg-core/query-builders/insert.js +6 -1
  261. package/pg-core/query-builders/insert.js.map +1 -1
  262. package/pg-core/query-builders/select.cjs +31 -5
  263. package/pg-core/query-builders/select.cjs.map +1 -1
  264. package/pg-core/query-builders/select.d.cts +15 -6
  265. package/pg-core/query-builders/select.d.ts +15 -6
  266. package/pg-core/query-builders/select.js +31 -5
  267. package/pg-core/query-builders/select.js.map +1 -1
  268. package/pg-core/query-builders/update.cjs +6 -1
  269. package/pg-core/query-builders/update.cjs.map +1 -1
  270. package/pg-core/query-builders/update.d.cts +4 -2
  271. package/pg-core/query-builders/update.d.ts +4 -2
  272. package/pg-core/query-builders/update.js +6 -1
  273. package/pg-core/query-builders/update.js.map +1 -1
  274. package/pg-core/session.cjs +79 -1
  275. package/pg-core/session.cjs.map +1 -1
  276. package/pg-core/session.d.cts +14 -3
  277. package/pg-core/session.d.ts +14 -3
  278. package/pg-core/session.js +80 -2
  279. package/pg-core/session.js.map +1 -1
  280. package/pg-core/utils.cjs +16 -0
  281. package/pg-core/utils.cjs.map +1 -1
  282. package/pg-core/utils.d.cts +8 -4
  283. package/pg-core/utils.d.ts +8 -4
  284. package/pg-core/utils.js +16 -1
  285. package/pg-core/utils.js.map +1 -1
  286. package/pg-proxy/driver.cjs +7 -2
  287. package/pg-proxy/driver.cjs.map +1 -1
  288. package/pg-proxy/driver.js +7 -2
  289. package/pg-proxy/driver.js.map +1 -1
  290. package/pg-proxy/session.cjs +15 -5
  291. package/pg-proxy/session.cjs.map +1 -1
  292. package/pg-proxy/session.d.cts +12 -2
  293. package/pg-proxy/session.d.ts +12 -2
  294. package/pg-proxy/session.js +15 -5
  295. package/pg-proxy/session.js.map +1 -1
  296. package/pglite/driver.cjs +9 -2
  297. package/pglite/driver.cjs.map +1 -1
  298. package/pglite/driver.d.cts +2 -0
  299. package/pglite/driver.d.ts +2 -0
  300. package/pglite/driver.js +9 -2
  301. package/pglite/driver.js.map +1 -1
  302. package/pglite/session.cjs +19 -7
  303. package/pglite/session.cjs.map +1 -1
  304. package/pglite/session.d.cts +12 -2
  305. package/pglite/session.d.ts +12 -2
  306. package/pglite/session.js +19 -7
  307. package/pglite/session.js.map +1 -1
  308. package/planetscale-serverless/driver.cjs +5 -1
  309. package/planetscale-serverless/driver.cjs.map +1 -1
  310. package/planetscale-serverless/driver.d.cts +1 -0
  311. package/planetscale-serverless/driver.d.ts +1 -0
  312. package/planetscale-serverless/driver.js +5 -1
  313. package/planetscale-serverless/driver.js.map +1 -1
  314. package/planetscale-serverless/session.cjs +15 -5
  315. package/planetscale-serverless/session.cjs.map +1 -1
  316. package/planetscale-serverless/session.d.cts +12 -2
  317. package/planetscale-serverless/session.d.ts +12 -2
  318. package/planetscale-serverless/session.js +15 -5
  319. package/planetscale-serverless/session.js.map +1 -1
  320. package/postgres-js/driver.cjs +5 -1
  321. package/postgres-js/driver.cjs.map +1 -1
  322. package/postgres-js/driver.js +5 -1
  323. package/postgres-js/driver.js.map +1 -1
  324. package/postgres-js/session.cjs +18 -6
  325. package/postgres-js/session.cjs.map +1 -1
  326. package/postgres-js/session.d.cts +12 -2
  327. package/postgres-js/session.d.ts +12 -2
  328. package/postgres-js/session.js +18 -6
  329. package/postgres-js/session.js.map +1 -1
  330. package/prisma/mysql/session.cjs +1 -1
  331. package/prisma/mysql/session.cjs.map +1 -1
  332. package/prisma/mysql/session.js +1 -1
  333. package/prisma/mysql/session.js.map +1 -1
  334. package/prisma/pg/session.cjs +1 -1
  335. package/prisma/pg/session.cjs.map +1 -1
  336. package/prisma/pg/session.js +1 -1
  337. package/prisma/pg/session.js.map +1 -1
  338. package/query-builders/query-builder.cjs.map +1 -1
  339. package/query-builders/query-builder.d.cts +2 -1
  340. package/query-builders/query-builder.d.ts +2 -1
  341. package/query-builders/query-builder.js.map +1 -1
  342. package/singlestore/driver.cjs +12 -2
  343. package/singlestore/driver.cjs.map +1 -1
  344. package/singlestore/driver.d.cts +2 -0
  345. package/singlestore/driver.d.ts +2 -0
  346. package/singlestore/driver.js +12 -2
  347. package/singlestore/driver.js.map +1 -1
  348. package/singlestore/session.cjs +15 -5
  349. package/singlestore/session.cjs.map +1 -1
  350. package/singlestore/session.d.cts +12 -2
  351. package/singlestore/session.d.ts +12 -2
  352. package/singlestore/session.js +15 -5
  353. package/singlestore/session.js.map +1 -1
  354. package/singlestore-core/db.cjs +3 -0
  355. package/singlestore-core/db.cjs.map +1 -1
  356. package/singlestore-core/db.d.cts +4 -0
  357. package/singlestore-core/db.d.ts +4 -0
  358. package/singlestore-core/db.js +3 -0
  359. package/singlestore-core/db.js.map +1 -1
  360. package/singlestore-core/query-builders/delete.cjs +9 -1
  361. package/singlestore-core/query-builders/delete.cjs.map +1 -1
  362. package/singlestore-core/query-builders/delete.js +9 -1
  363. package/singlestore-core/query-builders/delete.js.map +1 -1
  364. package/singlestore-core/query-builders/insert.cjs +6 -1
  365. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  366. package/singlestore-core/query-builders/insert.js +6 -1
  367. package/singlestore-core/query-builders/insert.js.map +1 -1
  368. package/singlestore-core/query-builders/select.cjs +28 -3
  369. package/singlestore-core/query-builders/select.cjs.map +1 -1
  370. package/singlestore-core/query-builders/select.d.cts +9 -0
  371. package/singlestore-core/query-builders/select.d.ts +9 -0
  372. package/singlestore-core/query-builders/select.js +28 -3
  373. package/singlestore-core/query-builders/select.js.map +1 -1
  374. package/singlestore-core/query-builders/update.cjs +9 -1
  375. package/singlestore-core/query-builders/update.cjs.map +1 -1
  376. package/singlestore-core/query-builders/update.js +9 -1
  377. package/singlestore-core/query-builders/update.js.map +1 -1
  378. package/singlestore-core/session.cjs +80 -0
  379. package/singlestore-core/session.cjs.map +1 -1
  380. package/singlestore-core/session.d.cts +14 -2
  381. package/singlestore-core/session.d.ts +14 -2
  382. package/singlestore-core/session.js +81 -1
  383. package/singlestore-core/session.js.map +1 -1
  384. package/singlestore-core/utils.cjs +16 -0
  385. package/singlestore-core/utils.cjs.map +1 -1
  386. package/singlestore-core/utils.d.cts +3 -0
  387. package/singlestore-core/utils.d.ts +3 -0
  388. package/singlestore-core/utils.js +15 -0
  389. package/singlestore-core/utils.js.map +1 -1
  390. package/sql/sql.cjs +10 -0
  391. package/sql/sql.cjs.map +1 -1
  392. package/sql/sql.js +10 -0
  393. package/sql/sql.js.map +1 -1
  394. package/sqlite-core/db.cjs +3 -0
  395. package/sqlite-core/db.cjs.map +1 -1
  396. package/sqlite-core/db.d.cts +4 -0
  397. package/sqlite-core/db.d.ts +4 -0
  398. package/sqlite-core/db.js +3 -0
  399. package/sqlite-core/db.js.map +1 -1
  400. package/sqlite-core/query-builders/delete.cjs +7 -1
  401. package/sqlite-core/query-builders/delete.cjs.map +1 -1
  402. package/sqlite-core/query-builders/delete.js +7 -1
  403. package/sqlite-core/query-builders/delete.js.map +1 -1
  404. package/sqlite-core/query-builders/insert.cjs +7 -1
  405. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  406. package/sqlite-core/query-builders/insert.js +7 -1
  407. package/sqlite-core/query-builders/insert.js.map +1 -1
  408. package/sqlite-core/query-builders/select.cjs +31 -3
  409. package/sqlite-core/query-builders/select.cjs.map +1 -1
  410. package/sqlite-core/query-builders/select.d.cts +9 -0
  411. package/sqlite-core/query-builders/select.d.ts +9 -0
  412. package/sqlite-core/query-builders/select.js +31 -3
  413. package/sqlite-core/query-builders/select.js.map +1 -1
  414. package/sqlite-core/query-builders/update.cjs +7 -1
  415. package/sqlite-core/query-builders/update.cjs.map +1 -1
  416. package/sqlite-core/query-builders/update.js +7 -1
  417. package/sqlite-core/query-builders/update.js.map +1 -1
  418. package/sqlite-core/session.cjs +89 -3
  419. package/sqlite-core/session.cjs.map +1 -1
  420. package/sqlite-core/session.d.cts +18 -4
  421. package/sqlite-core/session.d.ts +18 -4
  422. package/sqlite-core/session.js +90 -4
  423. package/sqlite-core/session.js.map +1 -1
  424. package/sqlite-core/utils.cjs +16 -0
  425. package/sqlite-core/utils.cjs.map +1 -1
  426. package/sqlite-core/utils.d.cts +6 -2
  427. package/sqlite-core/utils.d.ts +6 -2
  428. package/sqlite-core/utils.js +15 -0
  429. package/sqlite-core/utils.js.map +1 -1
  430. package/sqlite-proxy/driver.cjs +9 -2
  431. package/sqlite-proxy/driver.cjs.map +1 -1
  432. package/sqlite-proxy/driver.js +9 -2
  433. package/sqlite-proxy/driver.js.map +1 -1
  434. package/sqlite-proxy/session.cjs +22 -8
  435. package/sqlite-proxy/session.cjs.map +1 -1
  436. package/sqlite-proxy/session.d.cts +12 -2
  437. package/sqlite-proxy/session.d.ts +12 -2
  438. package/sqlite-proxy/session.js +22 -8
  439. package/sqlite-proxy/session.js.map +1 -1
  440. package/subquery.cjs +4 -3
  441. package/subquery.cjs.map +1 -1
  442. package/subquery.d.cts +2 -1
  443. package/subquery.d.ts +2 -1
  444. package/subquery.js +4 -3
  445. package/subquery.js.map +1 -1
  446. package/tidb-serverless/driver.cjs +5 -1
  447. package/tidb-serverless/driver.cjs.map +1 -1
  448. package/tidb-serverless/driver.d.cts +1 -0
  449. package/tidb-serverless/driver.d.ts +1 -0
  450. package/tidb-serverless/driver.js +5 -1
  451. package/tidb-serverless/driver.js.map +1 -1
  452. package/tidb-serverless/session.cjs +15 -5
  453. package/tidb-serverless/session.cjs.map +1 -1
  454. package/tidb-serverless/session.d.cts +12 -2
  455. package/tidb-serverless/session.d.ts +12 -2
  456. package/tidb-serverless/session.js +15 -5
  457. package/tidb-serverless/session.js.map +1 -1
  458. package/utils.cjs +22 -0
  459. package/utils.cjs.map +1 -1
  460. package/utils.d.cts +3 -0
  461. package/utils.d.ts +3 -0
  462. package/utils.js +11 -0
  463. package/utils.js.map +1 -1
  464. package/vercel-postgres/driver.cjs +9 -2
  465. package/vercel-postgres/driver.cjs.map +1 -1
  466. package/vercel-postgres/driver.d.cts +2 -0
  467. package/vercel-postgres/driver.d.ts +2 -0
  468. package/vercel-postgres/driver.js +9 -2
  469. package/vercel-postgres/driver.js.map +1 -1
  470. package/vercel-postgres/session.cjs +21 -7
  471. package/vercel-postgres/session.cjs.map +1 -1
  472. package/vercel-postgres/session.d.cts +12 -2
  473. package/vercel-postgres/session.d.ts +12 -2
  474. package/vercel-postgres/session.js +21 -7
  475. package/vercel-postgres/session.js.map +1 -1
  476. package/version.cjs +1 -1
  477. package/version.d.cts +1 -1
  478. package/version.d.ts +1 -1
  479. package/version.js +1 -1
  480. package/xata-http/driver.cjs +7 -2
  481. package/xata-http/driver.cjs.map +1 -1
  482. package/xata-http/driver.d.cts +2 -0
  483. package/xata-http/driver.d.ts +2 -0
  484. package/xata-http/driver.js +7 -2
  485. package/xata-http/driver.js.map +1 -1
  486. package/xata-http/session.cjs +21 -7
  487. package/xata-http/session.cjs.map +1 -1
  488. package/xata-http/session.d.cts +12 -2
  489. package/xata-http/session.d.ts +12 -2
  490. package/xata-http/session.js +21 -7
  491. package/xata-http/session.js.map +1 -1
@@ -23,13 +23,91 @@ __export(session_exports, {
23
23
  GelTransaction: () => GelTransaction
24
24
  });
25
25
  module.exports = __toCommonJS(session_exports);
26
+ var import_cache = require("../cache/core/cache.cjs");
26
27
  var import_entity = require("../entity.cjs");
27
28
  var import_errors = require("../errors.cjs");
29
+ var import_errors2 = require("../errors/index.cjs");
28
30
  var import_tracing = require("../tracing.cjs");
31
+ var import_utils = require("../utils.cjs");
29
32
  var import_db = require("./db.cjs");
30
33
  class GelPreparedQuery {
31
- constructor(query) {
34
+ constructor(query, cache, queryMetadata, cacheConfig) {
32
35
  this.query = query;
36
+ this.cache = cache;
37
+ this.queryMetadata = queryMetadata;
38
+ this.cacheConfig = cacheConfig;
39
+ if (cache && cache.strategy() === "all" && cacheConfig === void 0) {
40
+ this.cacheConfig = { enable: true, autoInvalidate: true };
41
+ }
42
+ if (!this.cacheConfig?.enable) {
43
+ this.cacheConfig = void 0;
44
+ }
45
+ }
46
+ /** @internal */
47
+ async queryWithCache(queryString, params, query) {
48
+ if (this.cache === void 0 || (0, import_entity.is)(this.cache, import_cache.NoopCache) || this.queryMetadata === void 0) {
49
+ try {
50
+ return await query();
51
+ } catch (e) {
52
+ throw new import_errors2.DrizzleQueryError(queryString, params, e);
53
+ }
54
+ }
55
+ if (this.cacheConfig && !this.cacheConfig.enable) {
56
+ try {
57
+ return await query();
58
+ } catch (e) {
59
+ throw new import_errors2.DrizzleQueryError(queryString, params, e);
60
+ }
61
+ }
62
+ if ((this.queryMetadata.type === "insert" || this.queryMetadata.type === "update" || this.queryMetadata.type === "delete") && this.queryMetadata.tables.length > 0) {
63
+ try {
64
+ const [res] = await Promise.all([
65
+ query(),
66
+ this.cache.onMutate({ tables: this.queryMetadata.tables })
67
+ ]);
68
+ return res;
69
+ } catch (e) {
70
+ throw new import_errors2.DrizzleQueryError(queryString, params, e);
71
+ }
72
+ }
73
+ if (!this.cacheConfig) {
74
+ try {
75
+ return await query();
76
+ } catch (e) {
77
+ throw new import_errors2.DrizzleQueryError(queryString, params, e);
78
+ }
79
+ }
80
+ if (this.queryMetadata.type === "select") {
81
+ const fromCache = await this.cache.get(
82
+ this.cacheConfig.tag ?? (await (0, import_utils.hashQuery)(queryString, params)),
83
+ this.queryMetadata.tables,
84
+ this.cacheConfig.tag !== void 0,
85
+ this.cacheConfig.autoInvalidate
86
+ );
87
+ if (fromCache === void 0) {
88
+ let result;
89
+ try {
90
+ result = await query();
91
+ } catch (e) {
92
+ throw new import_errors2.DrizzleQueryError(queryString, params, e);
93
+ }
94
+ await this.cache.put(
95
+ this.cacheConfig.tag ?? (await (0, import_utils.hashQuery)(queryString, params)),
96
+ result,
97
+ // make sure we send tables that were used in a query only if user wants to invalidate it on each write
98
+ this.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],
99
+ this.cacheConfig.tag !== void 0,
100
+ this.cacheConfig.config
101
+ );
102
+ return result;
103
+ }
104
+ return fromCache;
105
+ }
106
+ try {
107
+ return await query();
108
+ } catch (e) {
109
+ throw new import_errors2.DrizzleQueryError(queryString, params, e);
110
+ }
33
111
  }
34
112
  authToken;
35
113
  getQuery() {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/gel-core/session.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { TransactionRollbackError } from '~/errors.ts';\nimport type { TablesRelationalConfig } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/index.ts';\nimport { tracer } from '~/tracing.ts';\nimport type { NeonAuthToken } from '~/utils.ts';\nimport { GelDatabase } from './db.ts';\nimport type { GelDialect } from './dialect.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\texecute: unknown;\n\tall: unknown;\n\tvalues: unknown;\n}\n\nexport abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tconstructor(protected query: Query) {}\n\n\tprotected authToken?: NeonAuthToken;\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tmapResult(response: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn response;\n\t}\n\n\tstatic readonly [entityKind]: string = 'GelPreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tabstract execute(placeholderValues?: Record<string, unknown>): Promise<T['execute']>;\n\n\t/** @internal */\n\tabstract all(placeholderValues?: Record<string, unknown>): Promise<T['all']>;\n\n\t/** @internal */\n\tabstract isResponseInArrayMode(): boolean;\n}\n\nexport abstract class GelSession<\n\tTQueryResult extends GelQueryResultHKT = any, // TO\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = Record<string, never>,\n> {\n\tstatic readonly [entityKind]: string = 'GelSession';\n\n\tconstructor(protected dialect: GelDialect) {}\n\n\tabstract prepareQuery<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[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'],\n\t): GelPreparedQuery<T>;\n\n\texecute<T>(query: SQL): Promise<T> {\n\t\treturn tracer.startActiveSpan('drizzle.operation', () => {\n\t\t\tconst prepared = tracer.startActiveSpan('drizzle.prepareQuery', () => {\n\t\t\t\treturn this.prepareQuery<PreparedQueryConfig & { execute: T }>(\n\t\t\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\t\t\tundefined,\n\t\t\t\t\tundefined,\n\t\t\t\t\tfalse,\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn prepared.execute(undefined);\n\t\t});\n\t}\n\n\tall<T = unknown>(query: SQL): Promise<T[]> {\n\t\treturn this.prepareQuery<PreparedQueryConfig & { all: T[] }>(\n\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tfalse,\n\t\t).all();\n\t}\n\n\tasync count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<[{ count: string }]>(sql);\n\n\t\treturn Number(\n\t\t\tres[0]['count'],\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport abstract class GelTransaction<\n\tTQueryResult extends GelQueryResultHKT,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = Record<string, never>,\n> extends GelDatabase<TQueryResult, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'GelTransaction';\n\n\tconstructor(\n\t\tdialect: GelDialect,\n\t\tsession: GelSession<any, any, any>,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t) {\n\t\tsuper(dialect, session, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n\n\tabstract override transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport interface GelQueryResultHKT {\n\treadonly $brand: 'GelQueryResultHKT';\n\treadonly row: unknown;\n\treadonly type: unknown;\n}\n\nexport type GelQueryResultKind<TKind extends GelQueryResultHKT, TRow> = (TKind & {\n\treadonly row: TRow;\n})['type'];\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA2B;AAC3B,oBAAyC;AAIzC,qBAAuB;AAEvB,gBAA4B;AAUrB,MAAe,iBAAyE;AAAA,EAC9F,YAAsB,OAAc;AAAd;AAAA,EAAe;AAAA,EAE3B;AAAA,EAEV,WAAkB;AACjB,WAAO,KAAK;AAAA,EACb;AAAA,EAEA,UAAU,UAAmB,cAAiC;AAC7D,WAAO;AAAA,EACR;AAAA,EAEA,QAAiB,wBAAU,IAAY;AAAA;AAAA,EAGvC;AASD;AAEO,MAAe,WAIpB;AAAA,EAGD,YAAsB,SAAqB;AAArB;AAAA,EAAsB;AAAA,EAF5C,QAAiB,wBAAU,IAAY;AAAA,EAYvC,QAAW,OAAwB;AAClC,WAAO,sBAAO,gBAAgB,qBAAqB,MAAM;AACxD,YAAM,WAAW,sBAAO,gBAAgB,wBAAwB,MAAM;AACrE,eAAO,KAAK;AAAA,UACX,KAAK,QAAQ,WAAW,KAAK;AAAA,UAC7B;AAAA,UACA;AAAA,UACA;AAAA,QACD;AAAA,MACD,CAAC;AAED,aAAO,SAAS,QAAQ,MAAS;AAAA,IAClC,CAAC;AAAA,EACF;AAAA,EAEA,IAAiB,OAA0B;AAC1C,WAAO,KAAK;AAAA,MACX,KAAK,QAAQ,WAAW,KAAK;AAAA,MAC7B;AAAA,MACA;AAAA,MACA;AAAA,IACD,EAAE,IAAI;AAAA,EACP;AAAA,EAEA,MAAM,MAAM,KAA2B;AACtC,UAAM,MAAM,MAAM,KAAK,QAA6B,GAAG;AAEvD,WAAO;AAAA,MACN,IAAI,CAAC,EAAE,OAAO;AAAA,IACf;AAAA,EACD;AAKD;AAEO,MAAe,uBAIZ,sBAAgD;AAAA,EAGzD,YACC,SACA,SACU,QAKT;AACD,UAAM,SAAS,SAAS,MAAM;AANpB;AAAA,EAOX;AAAA,EAZA,QAA0B,wBAAU,IAAY;AAAA,EAchD,WAAkB;AACjB,UAAM,IAAI,uCAAyB;AAAA,EACpC;AAKD;","names":[]}
1
+ {"version":3,"sources":["../../src/gel-core/session.ts"],"sourcesContent":["import { type Cache, NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { TransactionRollbackError } from '~/errors.ts';\nimport { DrizzleQueryError } from '~/errors/index.ts';\nimport type { TablesRelationalConfig } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/index.ts';\nimport { tracer } from '~/tracing.ts';\nimport { hashQuery, type NeonAuthToken } from '~/utils.ts';\nimport { GelDatabase } from './db.ts';\nimport type { GelDialect } from './dialect.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\texecute: unknown;\n\tall: unknown;\n\tvalues: unknown;\n}\n\nexport abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tconstructor(\n\t\tprotected query: Query,\n\t\tprivate cache?: Cache,\n\t\t// per query related metadata\n\t\tprivate queryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\t// config that was passed through $withCache\n\t\tprivate cacheConfig?: WithCacheConfig,\n\t) {\n\t\t// it means that no $withCache options were passed and it should be just enabled\n\t\tif (cache && cache.strategy() === 'all' && cacheConfig === undefined) {\n\t\t\tthis.cacheConfig = { enable: true, autoInvalidate: true };\n\t\t}\n\t\tif (!this.cacheConfig?.enable) {\n\t\t\tthis.cacheConfig = undefined;\n\t\t}\n\t}\n\n\t/** @internal */\n\tprotected async queryWithCache<T>(\n\t\tqueryString: string,\n\t\tparams: any[],\n\t\tquery: () => Promise<T>,\n\t): Promise<T> {\n\t\tif (this.cache === undefined || is(this.cache, NoopCache) || this.queryMetadata === undefined) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any mutations, if globally is false\n\t\tif (this.cacheConfig && !this.cacheConfig.enable) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// For mutate queries, we should query the database, wait for a response, and then perform invalidation\n\t\tif (\n\t\t\t(\n\t\t\t\tthis.queryMetadata.type === 'insert' || this.queryMetadata.type === 'update'\n\t\t\t\t|| this.queryMetadata.type === 'delete'\n\t\t\t) && this.queryMetadata.tables.length > 0\n\t\t) {\n\t\t\ttry {\n\t\t\t\tconst [res] = await Promise.all([\n\t\t\t\t\tquery(),\n\t\t\t\t\tthis.cache.onMutate({ tables: this.queryMetadata.tables }),\n\t\t\t\t]);\n\t\t\t\treturn res;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any reads if globally disabled\n\t\tif (!this.cacheConfig) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\tif (this.queryMetadata.type === 'select') {\n\t\t\tconst fromCache = await this.cache.get(\n\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\tthis.queryMetadata.tables,\n\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\tthis.cacheConfig.autoInvalidate,\n\t\t\t);\n\t\t\tif (fromCache === undefined) {\n\t\t\t\tlet result;\n\t\t\t\ttry {\n\t\t\t\t\tresult = await query();\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t\t}\n\n\t\t\t\t// put actual key\n\t\t\t\tawait this.cache.put(\n\t\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\t\tresult,\n\t\t\t\t\t// make sure we send tables that were used in a query only if user wants to invalidate it on each write\n\t\t\t\t\tthis.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n\t\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\t\tthis.cacheConfig.config,\n\t\t\t\t);\n\t\t\t\t// put flag if we should invalidate or not\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\treturn fromCache as unknown as T;\n\t\t}\n\t\ttry {\n\t\t\treturn await query();\n\t\t} catch (e) {\n\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t}\n\t}\n\n\tprotected authToken?: NeonAuthToken;\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tmapResult(response: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn response;\n\t}\n\n\tstatic readonly [entityKind]: string = 'GelPreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tabstract execute(placeholderValues?: Record<string, unknown>): Promise<T['execute']>;\n\n\t/** @internal */\n\tabstract all(placeholderValues?: Record<string, unknown>): Promise<T['all']>;\n\n\t/** @internal */\n\tabstract isResponseInArrayMode(): boolean;\n}\n\nexport abstract class GelSession<\n\tTQueryResult extends GelQueryResultHKT = any, // TO\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = Record<string, never>,\n> {\n\tstatic readonly [entityKind]: string = 'GelSession';\n\n\tconstructor(protected dialect: GelDialect) {}\n\n\tabstract prepareQuery<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[][], mapColumnValue?: (value: unknown) => 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): GelPreparedQuery<T>;\n\n\texecute<T>(query: SQL): Promise<T> {\n\t\treturn tracer.startActiveSpan('drizzle.operation', () => {\n\t\t\tconst prepared = tracer.startActiveSpan('drizzle.prepareQuery', () => {\n\t\t\t\treturn this.prepareQuery<PreparedQueryConfig & { execute: T }>(\n\t\t\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\t\t\tundefined,\n\t\t\t\t\tundefined,\n\t\t\t\t\tfalse,\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn prepared.execute(undefined);\n\t\t});\n\t}\n\n\tall<T = unknown>(query: SQL): Promise<T[]> {\n\t\treturn this.prepareQuery<PreparedQueryConfig & { all: T[] }>(\n\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tfalse,\n\t\t).all();\n\t}\n\n\tasync count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<[{ count: string }]>(sql);\n\n\t\treturn Number(\n\t\t\tres[0]['count'],\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport abstract class GelTransaction<\n\tTQueryResult extends GelQueryResultHKT,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = Record<string, never>,\n> extends GelDatabase<TQueryResult, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'GelTransaction';\n\n\tconstructor(\n\t\tdialect: GelDialect,\n\t\tsession: GelSession<any, any, any>,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t) {\n\t\tsuper(dialect, session, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n\n\tabstract override transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport interface GelQueryResultHKT {\n\treadonly $brand: 'GelQueryResultHKT';\n\treadonly row: unknown;\n\treadonly type: unknown;\n}\n\nexport type GelQueryResultKind<TKind extends GelQueryResultHKT, TRow> = (TKind & {\n\treadonly row: TRow;\n})['type'];\n"],"mappings":"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","names":["import_errors"]}
@@ -1,8 +1,10 @@
1
+ import { type Cache } from "../cache/core/cache.cjs";
2
+ import type { WithCacheConfig } from "../cache/core/types.cjs";
1
3
  import { entityKind } from "../entity.cjs";
2
4
  import type { TablesRelationalConfig } from "../relations.cjs";
3
5
  import type { PreparedQuery } from "../session.cjs";
4
6
  import type { Query, SQL } from "../sql/index.cjs";
5
- import type { NeonAuthToken } from "../utils.cjs";
7
+ import { type NeonAuthToken } from "../utils.cjs";
6
8
  import { GelDatabase } from "./db.cjs";
7
9
  import type { GelDialect } from "./dialect.cjs";
8
10
  import type { SelectedFieldsOrdered } from "./query-builders/select.types.cjs";
@@ -13,7 +15,13 @@ export interface PreparedQueryConfig {
13
15
  }
14
16
  export declare abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {
15
17
  protected query: Query;
16
- constructor(query: Query);
18
+ private cache?;
19
+ private queryMetadata?;
20
+ private cacheConfig?;
21
+ constructor(query: Query, cache?: Cache | undefined, queryMetadata?: {
22
+ type: 'select' | 'update' | 'delete' | 'insert';
23
+ tables: string[];
24
+ } | undefined, cacheConfig?: WithCacheConfig | undefined);
17
25
  protected authToken?: NeonAuthToken;
18
26
  getQuery(): Query;
19
27
  mapResult(response: unknown, _isFromBatch?: boolean): unknown;
@@ -25,7 +33,10 @@ TFullSchema extends Record<string, unknown> = Record<string, never>, TSchema ext
25
33
  protected dialect: GelDialect;
26
34
  static readonly [entityKind]: string;
27
35
  constructor(dialect: GelDialect);
28
- abstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute']): GelPreparedQuery<T>;
36
+ abstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'], queryMetadata?: {
37
+ type: 'select' | 'update' | 'delete' | 'insert';
38
+ tables: string[];
39
+ }, cacheConfig?: WithCacheConfig): GelPreparedQuery<T>;
29
40
  execute<T>(query: SQL): Promise<T>;
30
41
  all<T = unknown>(query: SQL): Promise<T[]>;
31
42
  count(sql: SQL): Promise<number>;
@@ -1,8 +1,10 @@
1
+ import { type Cache } from "../cache/core/cache.js";
2
+ import type { WithCacheConfig } from "../cache/core/types.js";
1
3
  import { entityKind } from "../entity.js";
2
4
  import type { TablesRelationalConfig } from "../relations.js";
3
5
  import type { PreparedQuery } from "../session.js";
4
6
  import type { Query, SQL } from "../sql/index.js";
5
- import type { NeonAuthToken } from "../utils.js";
7
+ import { type NeonAuthToken } from "../utils.js";
6
8
  import { GelDatabase } from "./db.js";
7
9
  import type { GelDialect } from "./dialect.js";
8
10
  import type { SelectedFieldsOrdered } from "./query-builders/select.types.js";
@@ -13,7 +15,13 @@ export interface PreparedQueryConfig {
13
15
  }
14
16
  export declare abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {
15
17
  protected query: Query;
16
- constructor(query: Query);
18
+ private cache?;
19
+ private queryMetadata?;
20
+ private cacheConfig?;
21
+ constructor(query: Query, cache?: Cache | undefined, queryMetadata?: {
22
+ type: 'select' | 'update' | 'delete' | 'insert';
23
+ tables: string[];
24
+ } | undefined, cacheConfig?: WithCacheConfig | undefined);
17
25
  protected authToken?: NeonAuthToken;
18
26
  getQuery(): Query;
19
27
  mapResult(response: unknown, _isFromBatch?: boolean): unknown;
@@ -25,7 +33,10 @@ TFullSchema extends Record<string, unknown> = Record<string, never>, TSchema ext
25
33
  protected dialect: GelDialect;
26
34
  static readonly [entityKind]: string;
27
35
  constructor(dialect: GelDialect);
28
- abstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute']): GelPreparedQuery<T>;
36
+ abstract prepareQuery<T extends PreparedQueryConfig = PreparedQueryConfig>(query: Query, fields: SelectedFieldsOrdered | undefined, name: string | undefined, isResponseInArrayMode: boolean, customResultMapper?: (rows: unknown[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'], queryMetadata?: {
37
+ type: 'select' | 'update' | 'delete' | 'insert';
38
+ tables: string[];
39
+ }, cacheConfig?: WithCacheConfig): GelPreparedQuery<T>;
29
40
  execute<T>(query: SQL): Promise<T>;
30
41
  all<T = unknown>(query: SQL): Promise<T[]>;
31
42
  count(sql: SQL): Promise<number>;
@@ -1,10 +1,88 @@
1
- import { entityKind } from "../entity.js";
1
+ import { NoopCache } from "../cache/core/cache.js";
2
+ import { entityKind, is } from "../entity.js";
2
3
  import { TransactionRollbackError } from "../errors.js";
4
+ import { DrizzleQueryError } from "../errors/index.js";
3
5
  import { tracer } from "../tracing.js";
6
+ import { hashQuery } from "../utils.js";
4
7
  import { GelDatabase } from "./db.js";
5
8
  class GelPreparedQuery {
6
- constructor(query) {
9
+ constructor(query, cache, queryMetadata, cacheConfig) {
7
10
  this.query = query;
11
+ this.cache = cache;
12
+ this.queryMetadata = queryMetadata;
13
+ this.cacheConfig = cacheConfig;
14
+ if (cache && cache.strategy() === "all" && cacheConfig === void 0) {
15
+ this.cacheConfig = { enable: true, autoInvalidate: true };
16
+ }
17
+ if (!this.cacheConfig?.enable) {
18
+ this.cacheConfig = void 0;
19
+ }
20
+ }
21
+ /** @internal */
22
+ async queryWithCache(queryString, params, query) {
23
+ if (this.cache === void 0 || is(this.cache, NoopCache) || this.queryMetadata === void 0) {
24
+ try {
25
+ return await query();
26
+ } catch (e) {
27
+ throw new DrizzleQueryError(queryString, params, e);
28
+ }
29
+ }
30
+ if (this.cacheConfig && !this.cacheConfig.enable) {
31
+ try {
32
+ return await query();
33
+ } catch (e) {
34
+ throw new DrizzleQueryError(queryString, params, e);
35
+ }
36
+ }
37
+ if ((this.queryMetadata.type === "insert" || this.queryMetadata.type === "update" || this.queryMetadata.type === "delete") && this.queryMetadata.tables.length > 0) {
38
+ try {
39
+ const [res] = await Promise.all([
40
+ query(),
41
+ this.cache.onMutate({ tables: this.queryMetadata.tables })
42
+ ]);
43
+ return res;
44
+ } catch (e) {
45
+ throw new DrizzleQueryError(queryString, params, e);
46
+ }
47
+ }
48
+ if (!this.cacheConfig) {
49
+ try {
50
+ return await query();
51
+ } catch (e) {
52
+ throw new DrizzleQueryError(queryString, params, e);
53
+ }
54
+ }
55
+ if (this.queryMetadata.type === "select") {
56
+ const fromCache = await this.cache.get(
57
+ this.cacheConfig.tag ?? (await hashQuery(queryString, params)),
58
+ this.queryMetadata.tables,
59
+ this.cacheConfig.tag !== void 0,
60
+ this.cacheConfig.autoInvalidate
61
+ );
62
+ if (fromCache === void 0) {
63
+ let result;
64
+ try {
65
+ result = await query();
66
+ } catch (e) {
67
+ throw new DrizzleQueryError(queryString, params, e);
68
+ }
69
+ await this.cache.put(
70
+ this.cacheConfig.tag ?? (await hashQuery(queryString, params)),
71
+ result,
72
+ // make sure we send tables that were used in a query only if user wants to invalidate it on each write
73
+ this.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],
74
+ this.cacheConfig.tag !== void 0,
75
+ this.cacheConfig.config
76
+ );
77
+ return result;
78
+ }
79
+ return fromCache;
80
+ }
81
+ try {
82
+ return await query();
83
+ } catch (e) {
84
+ throw new DrizzleQueryError(queryString, params, e);
85
+ }
8
86
  }
9
87
  authToken;
10
88
  getQuery() {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/gel-core/session.ts"],"sourcesContent":["import { entityKind } from '~/entity.ts';\nimport { TransactionRollbackError } from '~/errors.ts';\nimport type { TablesRelationalConfig } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/index.ts';\nimport { tracer } from '~/tracing.ts';\nimport type { NeonAuthToken } from '~/utils.ts';\nimport { GelDatabase } from './db.ts';\nimport type { GelDialect } from './dialect.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\texecute: unknown;\n\tall: unknown;\n\tvalues: unknown;\n}\n\nexport abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tconstructor(protected query: Query) {}\n\n\tprotected authToken?: NeonAuthToken;\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tmapResult(response: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn response;\n\t}\n\n\tstatic readonly [entityKind]: string = 'GelPreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tabstract execute(placeholderValues?: Record<string, unknown>): Promise<T['execute']>;\n\n\t/** @internal */\n\tabstract all(placeholderValues?: Record<string, unknown>): Promise<T['all']>;\n\n\t/** @internal */\n\tabstract isResponseInArrayMode(): boolean;\n}\n\nexport abstract class GelSession<\n\tTQueryResult extends GelQueryResultHKT = any, // TO\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = Record<string, never>,\n> {\n\tstatic readonly [entityKind]: string = 'GelSession';\n\n\tconstructor(protected dialect: GelDialect) {}\n\n\tabstract prepareQuery<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[][], mapColumnValue?: (value: unknown) => unknown) => T['execute'],\n\t): GelPreparedQuery<T>;\n\n\texecute<T>(query: SQL): Promise<T> {\n\t\treturn tracer.startActiveSpan('drizzle.operation', () => {\n\t\t\tconst prepared = tracer.startActiveSpan('drizzle.prepareQuery', () => {\n\t\t\t\treturn this.prepareQuery<PreparedQueryConfig & { execute: T }>(\n\t\t\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\t\t\tundefined,\n\t\t\t\t\tundefined,\n\t\t\t\t\tfalse,\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn prepared.execute(undefined);\n\t\t});\n\t}\n\n\tall<T = unknown>(query: SQL): Promise<T[]> {\n\t\treturn this.prepareQuery<PreparedQueryConfig & { all: T[] }>(\n\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tfalse,\n\t\t).all();\n\t}\n\n\tasync count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<[{ count: string }]>(sql);\n\n\t\treturn Number(\n\t\t\tres[0]['count'],\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport abstract class GelTransaction<\n\tTQueryResult extends GelQueryResultHKT,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = Record<string, never>,\n> extends GelDatabase<TQueryResult, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'GelTransaction';\n\n\tconstructor(\n\t\tdialect: GelDialect,\n\t\tsession: GelSession<any, any, any>,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t) {\n\t\tsuper(dialect, session, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n\n\tabstract override transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport interface GelQueryResultHKT {\n\treadonly $brand: 'GelQueryResultHKT';\n\treadonly row: unknown;\n\treadonly type: unknown;\n}\n\nexport type GelQueryResultKind<TKind extends GelQueryResultHKT, TRow> = (TKind & {\n\treadonly row: TRow;\n})['type'];\n"],"mappings":"AAAA,SAAS,kBAAkB;AAC3B,SAAS,gCAAgC;AAIzC,SAAS,cAAc;AAEvB,SAAS,mBAAmB;AAUrB,MAAe,iBAAyE;AAAA,EAC9F,YAAsB,OAAc;AAAd;AAAA,EAAe;AAAA,EAE3B;AAAA,EAEV,WAAkB;AACjB,WAAO,KAAK;AAAA,EACb;AAAA,EAEA,UAAU,UAAmB,cAAiC;AAC7D,WAAO;AAAA,EACR;AAAA,EAEA,QAAiB,UAAU,IAAY;AAAA;AAAA,EAGvC;AASD;AAEO,MAAe,WAIpB;AAAA,EAGD,YAAsB,SAAqB;AAArB;AAAA,EAAsB;AAAA,EAF5C,QAAiB,UAAU,IAAY;AAAA,EAYvC,QAAW,OAAwB;AAClC,WAAO,OAAO,gBAAgB,qBAAqB,MAAM;AACxD,YAAM,WAAW,OAAO,gBAAgB,wBAAwB,MAAM;AACrE,eAAO,KAAK;AAAA,UACX,KAAK,QAAQ,WAAW,KAAK;AAAA,UAC7B;AAAA,UACA;AAAA,UACA;AAAA,QACD;AAAA,MACD,CAAC;AAED,aAAO,SAAS,QAAQ,MAAS;AAAA,IAClC,CAAC;AAAA,EACF;AAAA,EAEA,IAAiB,OAA0B;AAC1C,WAAO,KAAK;AAAA,MACX,KAAK,QAAQ,WAAW,KAAK;AAAA,MAC7B;AAAA,MACA;AAAA,MACA;AAAA,IACD,EAAE,IAAI;AAAA,EACP;AAAA,EAEA,MAAM,MAAM,KAA2B;AACtC,UAAM,MAAM,MAAM,KAAK,QAA6B,GAAG;AAEvD,WAAO;AAAA,MACN,IAAI,CAAC,EAAE,OAAO;AAAA,IACf;AAAA,EACD;AAKD;AAEO,MAAe,uBAIZ,YAAgD;AAAA,EAGzD,YACC,SACA,SACU,QAKT;AACD,UAAM,SAAS,SAAS,MAAM;AANpB;AAAA,EAOX;AAAA,EAZA,QAA0B,UAAU,IAAY;AAAA,EAchD,WAAkB;AACjB,UAAM,IAAI,yBAAyB;AAAA,EACpC;AAKD;","names":[]}
1
+ {"version":3,"sources":["../../src/gel-core/session.ts"],"sourcesContent":["import { type Cache, NoopCache } from '~/cache/core/cache.ts';\nimport type { WithCacheConfig } from '~/cache/core/types.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport { TransactionRollbackError } from '~/errors.ts';\nimport { DrizzleQueryError } from '~/errors/index.ts';\nimport type { TablesRelationalConfig } from '~/relations.ts';\nimport type { PreparedQuery } from '~/session.ts';\nimport type { Query, SQL } from '~/sql/index.ts';\nimport { tracer } from '~/tracing.ts';\nimport { hashQuery, type NeonAuthToken } from '~/utils.ts';\nimport { GelDatabase } from './db.ts';\nimport type { GelDialect } from './dialect.ts';\nimport type { SelectedFieldsOrdered } from './query-builders/select.types.ts';\n\nexport interface PreparedQueryConfig {\n\texecute: unknown;\n\tall: unknown;\n\tvalues: unknown;\n}\n\nexport abstract class GelPreparedQuery<T extends PreparedQueryConfig> implements PreparedQuery {\n\tconstructor(\n\t\tprotected query: Query,\n\t\tprivate cache?: Cache,\n\t\t// per query related metadata\n\t\tprivate queryMetadata?: {\n\t\t\ttype: 'select' | 'update' | 'delete' | 'insert';\n\t\t\ttables: string[];\n\t\t} | undefined,\n\t\t// config that was passed through $withCache\n\t\tprivate cacheConfig?: WithCacheConfig,\n\t) {\n\t\t// it means that no $withCache options were passed and it should be just enabled\n\t\tif (cache && cache.strategy() === 'all' && cacheConfig === undefined) {\n\t\t\tthis.cacheConfig = { enable: true, autoInvalidate: true };\n\t\t}\n\t\tif (!this.cacheConfig?.enable) {\n\t\t\tthis.cacheConfig = undefined;\n\t\t}\n\t}\n\n\t/** @internal */\n\tprotected async queryWithCache<T>(\n\t\tqueryString: string,\n\t\tparams: any[],\n\t\tquery: () => Promise<T>,\n\t): Promise<T> {\n\t\tif (this.cache === undefined || is(this.cache, NoopCache) || this.queryMetadata === undefined) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any mutations, if globally is false\n\t\tif (this.cacheConfig && !this.cacheConfig.enable) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// For mutate queries, we should query the database, wait for a response, and then perform invalidation\n\t\tif (\n\t\t\t(\n\t\t\t\tthis.queryMetadata.type === 'insert' || this.queryMetadata.type === 'update'\n\t\t\t\t|| this.queryMetadata.type === 'delete'\n\t\t\t) && this.queryMetadata.tables.length > 0\n\t\t) {\n\t\t\ttry {\n\t\t\t\tconst [res] = await Promise.all([\n\t\t\t\t\tquery(),\n\t\t\t\t\tthis.cache.onMutate({ tables: this.queryMetadata.tables }),\n\t\t\t\t]);\n\t\t\t\treturn res;\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\t// don't do any reads if globally disabled\n\t\tif (!this.cacheConfig) {\n\t\t\ttry {\n\t\t\t\treturn await query();\n\t\t\t} catch (e) {\n\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t}\n\t\t}\n\n\t\tif (this.queryMetadata.type === 'select') {\n\t\t\tconst fromCache = await this.cache.get(\n\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\tthis.queryMetadata.tables,\n\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\tthis.cacheConfig.autoInvalidate,\n\t\t\t);\n\t\t\tif (fromCache === undefined) {\n\t\t\t\tlet result;\n\t\t\t\ttry {\n\t\t\t\t\tresult = await query();\n\t\t\t\t} catch (e) {\n\t\t\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t\t\t}\n\n\t\t\t\t// put actual key\n\t\t\t\tawait this.cache.put(\n\t\t\t\t\tthis.cacheConfig.tag ?? await hashQuery(queryString, params),\n\t\t\t\t\tresult,\n\t\t\t\t\t// make sure we send tables that were used in a query only if user wants to invalidate it on each write\n\t\t\t\t\tthis.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n\t\t\t\t\tthis.cacheConfig.tag !== undefined,\n\t\t\t\t\tthis.cacheConfig.config,\n\t\t\t\t);\n\t\t\t\t// put flag if we should invalidate or not\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\treturn fromCache as unknown as T;\n\t\t}\n\t\ttry {\n\t\t\treturn await query();\n\t\t} catch (e) {\n\t\t\tthrow new DrizzleQueryError(queryString, params, e as Error);\n\t\t}\n\t}\n\n\tprotected authToken?: NeonAuthToken;\n\n\tgetQuery(): Query {\n\t\treturn this.query;\n\t}\n\n\tmapResult(response: unknown, _isFromBatch?: boolean): unknown {\n\t\treturn response;\n\t}\n\n\tstatic readonly [entityKind]: string = 'GelPreparedQuery';\n\n\t/** @internal */\n\tjoinsNotNullableMap?: Record<string, boolean>;\n\n\tabstract execute(placeholderValues?: Record<string, unknown>): Promise<T['execute']>;\n\n\t/** @internal */\n\tabstract all(placeholderValues?: Record<string, unknown>): Promise<T['all']>;\n\n\t/** @internal */\n\tabstract isResponseInArrayMode(): boolean;\n}\n\nexport abstract class GelSession<\n\tTQueryResult extends GelQueryResultHKT = any, // TO\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = Record<string, never>,\n> {\n\tstatic readonly [entityKind]: string = 'GelSession';\n\n\tconstructor(protected dialect: GelDialect) {}\n\n\tabstract prepareQuery<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[][], mapColumnValue?: (value: unknown) => 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): GelPreparedQuery<T>;\n\n\texecute<T>(query: SQL): Promise<T> {\n\t\treturn tracer.startActiveSpan('drizzle.operation', () => {\n\t\t\tconst prepared = tracer.startActiveSpan('drizzle.prepareQuery', () => {\n\t\t\t\treturn this.prepareQuery<PreparedQueryConfig & { execute: T }>(\n\t\t\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\t\t\tundefined,\n\t\t\t\t\tundefined,\n\t\t\t\t\tfalse,\n\t\t\t\t);\n\t\t\t});\n\n\t\t\treturn prepared.execute(undefined);\n\t\t});\n\t}\n\n\tall<T = unknown>(query: SQL): Promise<T[]> {\n\t\treturn this.prepareQuery<PreparedQueryConfig & { all: T[] }>(\n\t\t\tthis.dialect.sqlToQuery(query),\n\t\t\tundefined,\n\t\t\tundefined,\n\t\t\tfalse,\n\t\t).all();\n\t}\n\n\tasync count(sql: SQL): Promise<number> {\n\t\tconst res = await this.execute<[{ count: string }]>(sql);\n\n\t\treturn Number(\n\t\t\tres[0]['count'],\n\t\t);\n\t}\n\n\tabstract transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport abstract class GelTransaction<\n\tTQueryResult extends GelQueryResultHKT,\n\tTFullSchema extends Record<string, unknown> = Record<string, never>,\n\tTSchema extends TablesRelationalConfig = Record<string, never>,\n> extends GelDatabase<TQueryResult, TFullSchema, TSchema> {\n\tstatic override readonly [entityKind]: string = 'GelTransaction';\n\n\tconstructor(\n\t\tdialect: GelDialect,\n\t\tsession: GelSession<any, any, any>,\n\t\tprotected schema: {\n\t\t\tfullSchema: Record<string, unknown>;\n\t\t\tschema: TSchema;\n\t\t\ttableNamesMap: Record<string, string>;\n\t\t} | undefined,\n\t) {\n\t\tsuper(dialect, session, schema);\n\t}\n\n\trollback(): never {\n\t\tthrow new TransactionRollbackError();\n\t}\n\n\tabstract override transaction<T>(\n\t\ttransaction: (tx: GelTransaction<TQueryResult, TFullSchema, TSchema>) => Promise<T>,\n\t): Promise<T>;\n}\n\nexport interface GelQueryResultHKT {\n\treadonly $brand: 'GelQueryResultHKT';\n\treadonly row: unknown;\n\treadonly type: unknown;\n}\n\nexport type GelQueryResultKind<TKind extends GelQueryResultHKT, TRow> = (TKind & {\n\treadonly row: TRow;\n})['type'];\n"],"mappings":"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","names":[]}
@@ -18,12 +18,15 @@ var __copyProps = (to, from, except, desc) => {
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
19
  var utils_exports = {};
20
20
  __export(utils_exports, {
21
+ extractUsedTable: () => extractUsedTable,
21
22
  getMaterializedViewConfig: () => getMaterializedViewConfig,
22
23
  getTableConfig: () => getTableConfig,
23
24
  getViewConfig: () => getViewConfig
24
25
  });
25
26
  module.exports = __toCommonJS(utils_exports);
26
27
  var import_entity = require("../entity.cjs");
28
+ var import_sql = require("../sql/sql.cjs");
29
+ var import_subquery = require("../subquery.cjs");
27
30
  var import_table = require("../table.cjs");
28
31
  var import_view_common = require("../view-common.cjs");
29
32
  var import_checks = require("./checks.cjs");
@@ -79,6 +82,18 @@ function getTableConfig(table) {
79
82
  enableRLS
80
83
  };
81
84
  }
85
+ function extractUsedTable(table) {
86
+ if ((0, import_entity.is)(table, import_table2.GelTable)) {
87
+ return [`${table[import_table.Table.Symbol.BaseName]}`];
88
+ }
89
+ if ((0, import_entity.is)(table, import_subquery.Subquery)) {
90
+ return table._.usedTables ?? [];
91
+ }
92
+ if ((0, import_entity.is)(table, import_sql.SQL)) {
93
+ return table.usedTables ?? [];
94
+ }
95
+ return [];
96
+ }
82
97
  function getViewConfig(view) {
83
98
  return {
84
99
  ...view[import_view_common.ViewBaseConfig],
@@ -93,6 +108,7 @@ function getMaterializedViewConfig(view) {
93
108
  }
94
109
  // Annotate the CommonJS export names for ESM import in node:
95
110
  0 && (module.exports = {
111
+ extractUsedTable,
96
112
  getMaterializedViewConfig,
97
113
  getTableConfig,
98
114
  getViewConfig
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/gel-core/utils.ts"],"sourcesContent":["import { is } from '~/entity.ts';\nimport { Table } from '~/table.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { type Check, CheckBuilder } from './checks.ts';\nimport type { AnyGelColumn } from './columns/index.ts';\nimport { type ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { Index } from './indexes.ts';\nimport { IndexBuilder } from './indexes.ts';\nimport { GelPolicy } from './policies.ts';\nimport { type PrimaryKey, PrimaryKeyBuilder } from './primary-keys.ts';\nimport { GelTable } from './table.ts';\nimport { type UniqueConstraint, UniqueConstraintBuilder } from './unique-constraint.ts';\nimport { GelViewConfig } from './view-common.ts';\nimport { type GelMaterializedView, GelMaterializedViewConfig, type GelView } from './view.ts';\n\nexport function getTableConfig<TTable extends GelTable>(table: TTable) {\n\tconst columns = Object.values(table[Table.Symbol.Columns]);\n\tconst indexes: Index[] = [];\n\tconst checks: Check[] = [];\n\tconst primaryKeys: PrimaryKey[] = [];\n\tconst foreignKeys: ForeignKey[] = Object.values(table[GelTable.Symbol.InlineForeignKeys]);\n\tconst uniqueConstraints: UniqueConstraint[] = [];\n\tconst name = table[Table.Symbol.Name];\n\tconst schema = table[Table.Symbol.Schema];\n\tconst policies: GelPolicy[] = [];\n\tconst enableRLS: boolean = table[GelTable.Symbol.EnableRLS];\n\n\tconst extraConfigBuilder = table[GelTable.Symbol.ExtraConfigBuilder];\n\n\tif (extraConfigBuilder !== undefined) {\n\t\tconst extraConfig = extraConfigBuilder(table[Table.Symbol.ExtraConfigColumns]);\n\t\tconst extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) as any[] : Object.values(extraConfig);\n\t\tfor (const builder of extraValues) {\n\t\t\tif (is(builder, IndexBuilder)) {\n\t\t\t\tindexes.push(builder.build(table));\n\t\t\t} else if (is(builder, CheckBuilder)) {\n\t\t\t\tchecks.push(builder.build(table));\n\t\t\t} else if (is(builder, UniqueConstraintBuilder)) {\n\t\t\t\tuniqueConstraints.push(builder.build(table));\n\t\t\t} else if (is(builder, PrimaryKeyBuilder)) {\n\t\t\t\tprimaryKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, ForeignKeyBuilder)) {\n\t\t\t\tforeignKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, GelPolicy)) {\n\t\t\t\tpolicies.push(builder);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn {\n\t\tcolumns,\n\t\tindexes,\n\t\tforeignKeys,\n\t\tchecks,\n\t\tprimaryKeys,\n\t\tuniqueConstraints,\n\t\tname,\n\t\tschema,\n\t\tpolicies,\n\t\tenableRLS,\n\t};\n}\n\nexport function getViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: GelView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t...view[GelViewConfig],\n\t};\n}\n\nexport function getMaterializedViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: GelMaterializedView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t...view[GelMaterializedViewConfig],\n\t};\n}\n\nexport type ColumnsWithTable<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyGelColumn<{ tableName: TTableName }>[],\n> = { [Key in keyof TColumns]: AnyGelColumn<{ tableName: TForeignTableName }> };\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAmB;AACnB,mBAAsB;AACtB,yBAA+B;AAC/B,oBAAyC;AAEzC,0BAAmD;AAEnD,qBAA6B;AAC7B,sBAA0B;AAC1B,0BAAmD;AACnD,IAAAA,gBAAyB;AACzB,+BAA+D;AAC/D,IAAAC,sBAA8B;AAC9B,kBAAkF;AAE3E,SAAS,eAAwC,OAAe;AACtE,QAAM,UAAU,OAAO,OAAO,MAAM,mBAAM,OAAO,OAAO,CAAC;AACzD,QAAM,UAAmB,CAAC;AAC1B,QAAM,SAAkB,CAAC;AACzB,QAAM,cAA4B,CAAC;AACnC,QAAM,cAA4B,OAAO,OAAO,MAAM,uBAAS,OAAO,iBAAiB,CAAC;AACxF,QAAM,oBAAwC,CAAC;AAC/C,QAAM,OAAO,MAAM,mBAAM,OAAO,IAAI;AACpC,QAAM,SAAS,MAAM,mBAAM,OAAO,MAAM;AACxC,QAAM,WAAwB,CAAC;AAC/B,QAAM,YAAqB,MAAM,uBAAS,OAAO,SAAS;AAE1D,QAAM,qBAAqB,MAAM,uBAAS,OAAO,kBAAkB;AAEnE,MAAI,uBAAuB,QAAW;AACrC,UAAM,cAAc,mBAAmB,MAAM,mBAAM,OAAO,kBAAkB,CAAC;AAC7E,UAAM,cAAc,MAAM,QAAQ,WAAW,IAAI,YAAY,KAAK,CAAC,IAAa,OAAO,OAAO,WAAW;AACzG,eAAW,WAAW,aAAa;AAClC,cAAI,kBAAG,SAAS,2BAAY,GAAG;AAC9B,gBAAQ,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MAClC,eAAW,kBAAG,SAAS,0BAAY,GAAG;AACrC,eAAO,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACjC,eAAW,kBAAG,SAAS,gDAAuB,GAAG;AAChD,0BAAkB,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MAC5C,eAAW,kBAAG,SAAS,qCAAiB,GAAG;AAC1C,oBAAY,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACtC,eAAW,kBAAG,SAAS,qCAAiB,GAAG;AAC1C,oBAAY,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACtC,eAAW,kBAAG,SAAS,yBAAS,GAAG;AAClC,iBAAS,KAAK,OAAO;AAAA,MACtB;AAAA,IACD;AAAA,EACD;AAEA,SAAO;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AACD;AAEO,SAAS,cAGd,MAAiC;AAClC,SAAO;AAAA,IACN,GAAG,KAAK,iCAAc;AAAA,IACtB,GAAG,KAAK,iCAAa;AAAA,EACtB;AACD;AAEO,SAAS,0BAGd,MAA6C;AAC9C,SAAO;AAAA,IACN,GAAG,KAAK,iCAAc;AAAA,IACtB,GAAG,KAAK,qCAAyB;AAAA,EAClC;AACD;","names":["import_table","import_view_common"]}
1
+ {"version":3,"sources":["../../src/gel-core/utils.ts"],"sourcesContent":["import { is } from '~/entity.ts';\nimport { SQL } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { Table } from '~/table.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { type Check, CheckBuilder } from './checks.ts';\nimport type { AnyGelColumn } from './columns/index.ts';\nimport { type ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { Index } from './indexes.ts';\nimport { IndexBuilder } from './indexes.ts';\nimport { GelPolicy } from './policies.ts';\nimport { type PrimaryKey, PrimaryKeyBuilder } from './primary-keys.ts';\nimport { GelTable } from './table.ts';\nimport { type UniqueConstraint, UniqueConstraintBuilder } from './unique-constraint.ts';\nimport type { GelViewBase } from './view-base.ts';\nimport { GelViewConfig } from './view-common.ts';\nimport { type GelMaterializedView, GelMaterializedViewConfig, type GelView } from './view.ts';\n\nexport function getTableConfig<TTable extends GelTable>(table: TTable) {\n\tconst columns = Object.values(table[Table.Symbol.Columns]);\n\tconst indexes: Index[] = [];\n\tconst checks: Check[] = [];\n\tconst primaryKeys: PrimaryKey[] = [];\n\tconst foreignKeys: ForeignKey[] = Object.values(table[GelTable.Symbol.InlineForeignKeys]);\n\tconst uniqueConstraints: UniqueConstraint[] = [];\n\tconst name = table[Table.Symbol.Name];\n\tconst schema = table[Table.Symbol.Schema];\n\tconst policies: GelPolicy[] = [];\n\tconst enableRLS: boolean = table[GelTable.Symbol.EnableRLS];\n\n\tconst extraConfigBuilder = table[GelTable.Symbol.ExtraConfigBuilder];\n\n\tif (extraConfigBuilder !== undefined) {\n\t\tconst extraConfig = extraConfigBuilder(table[Table.Symbol.ExtraConfigColumns]);\n\t\tconst extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) as any[] : Object.values(extraConfig);\n\t\tfor (const builder of extraValues) {\n\t\t\tif (is(builder, IndexBuilder)) {\n\t\t\t\tindexes.push(builder.build(table));\n\t\t\t} else if (is(builder, CheckBuilder)) {\n\t\t\t\tchecks.push(builder.build(table));\n\t\t\t} else if (is(builder, UniqueConstraintBuilder)) {\n\t\t\t\tuniqueConstraints.push(builder.build(table));\n\t\t\t} else if (is(builder, PrimaryKeyBuilder)) {\n\t\t\t\tprimaryKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, ForeignKeyBuilder)) {\n\t\t\t\tforeignKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, GelPolicy)) {\n\t\t\t\tpolicies.push(builder);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn {\n\t\tcolumns,\n\t\tindexes,\n\t\tforeignKeys,\n\t\tchecks,\n\t\tprimaryKeys,\n\t\tuniqueConstraints,\n\t\tname,\n\t\tschema,\n\t\tpolicies,\n\t\tenableRLS,\n\t};\n}\n\nexport function extractUsedTable(table: GelTable | Subquery | GelViewBase | SQL): string[] {\n\tif (is(table, GelTable)) {\n\t\treturn [`${table[Table.Symbol.BaseName]}`];\n\t}\n\tif (is(table, Subquery)) {\n\t\treturn table._.usedTables ?? [];\n\t}\n\tif (is(table, SQL)) {\n\t\treturn table.usedTables ?? [];\n\t}\n\treturn [];\n}\n\nexport function getViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: GelView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t...view[GelViewConfig],\n\t};\n}\n\nexport function getMaterializedViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: GelMaterializedView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t...view[GelMaterializedViewConfig],\n\t};\n}\n\nexport type ColumnsWithTable<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyGelColumn<{ tableName: TTableName }>[],\n> = { [Key in keyof TColumns]: AnyGelColumn<{ tableName: TForeignTableName }> };\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAmB;AACnB,iBAAoB;AACpB,sBAAyB;AACzB,mBAAsB;AACtB,yBAA+B;AAC/B,oBAAyC;AAEzC,0BAAmD;AAEnD,qBAA6B;AAC7B,sBAA0B;AAC1B,0BAAmD;AACnD,IAAAA,gBAAyB;AACzB,+BAA+D;AAE/D,IAAAC,sBAA8B;AAC9B,kBAAkF;AAE3E,SAAS,eAAwC,OAAe;AACtE,QAAM,UAAU,OAAO,OAAO,MAAM,mBAAM,OAAO,OAAO,CAAC;AACzD,QAAM,UAAmB,CAAC;AAC1B,QAAM,SAAkB,CAAC;AACzB,QAAM,cAA4B,CAAC;AACnC,QAAM,cAA4B,OAAO,OAAO,MAAM,uBAAS,OAAO,iBAAiB,CAAC;AACxF,QAAM,oBAAwC,CAAC;AAC/C,QAAM,OAAO,MAAM,mBAAM,OAAO,IAAI;AACpC,QAAM,SAAS,MAAM,mBAAM,OAAO,MAAM;AACxC,QAAM,WAAwB,CAAC;AAC/B,QAAM,YAAqB,MAAM,uBAAS,OAAO,SAAS;AAE1D,QAAM,qBAAqB,MAAM,uBAAS,OAAO,kBAAkB;AAEnE,MAAI,uBAAuB,QAAW;AACrC,UAAM,cAAc,mBAAmB,MAAM,mBAAM,OAAO,kBAAkB,CAAC;AAC7E,UAAM,cAAc,MAAM,QAAQ,WAAW,IAAI,YAAY,KAAK,CAAC,IAAa,OAAO,OAAO,WAAW;AACzG,eAAW,WAAW,aAAa;AAClC,cAAI,kBAAG,SAAS,2BAAY,GAAG;AAC9B,gBAAQ,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MAClC,eAAW,kBAAG,SAAS,0BAAY,GAAG;AACrC,eAAO,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACjC,eAAW,kBAAG,SAAS,gDAAuB,GAAG;AAChD,0BAAkB,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MAC5C,eAAW,kBAAG,SAAS,qCAAiB,GAAG;AAC1C,oBAAY,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACtC,eAAW,kBAAG,SAAS,qCAAiB,GAAG;AAC1C,oBAAY,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACtC,eAAW,kBAAG,SAAS,yBAAS,GAAG;AAClC,iBAAS,KAAK,OAAO;AAAA,MACtB;AAAA,IACD;AAAA,EACD;AAEA,SAAO;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AACD;AAEO,SAAS,iBAAiB,OAA0D;AAC1F,UAAI,kBAAG,OAAO,sBAAQ,GAAG;AACxB,WAAO,CAAC,GAAG,MAAM,mBAAM,OAAO,QAAQ,CAAC,EAAE;AAAA,EAC1C;AACA,UAAI,kBAAG,OAAO,wBAAQ,GAAG;AACxB,WAAO,MAAM,EAAE,cAAc,CAAC;AAAA,EAC/B;AACA,UAAI,kBAAG,OAAO,cAAG,GAAG;AACnB,WAAO,MAAM,cAAc,CAAC;AAAA,EAC7B;AACA,SAAO,CAAC;AACT;AAEO,SAAS,cAGd,MAAiC;AAClC,SAAO;AAAA,IACN,GAAG,KAAK,iCAAc;AAAA,IACtB,GAAG,KAAK,iCAAa;AAAA,EACtB;AACD;AAEO,SAAS,0BAGd,MAA6C;AAC9C,SAAO;AAAA,IACN,GAAG,KAAK,iCAAc;AAAA,IACtB,GAAG,KAAK,qCAAyB;AAAA,EAClC;AACD;","names":["import_table","import_view_common"]}
@@ -1,3 +1,5 @@
1
+ import { SQL } from "../sql/sql.cjs";
2
+ import { Subquery } from "../subquery.cjs";
1
3
  import { type Check } from "./checks.cjs";
2
4
  import type { AnyGelColumn } from "./columns/index.cjs";
3
5
  import { type ForeignKey } from "./foreign-keys.cjs";
@@ -6,6 +8,7 @@ import { GelPolicy } from "./policies.cjs";
6
8
  import { type PrimaryKey } from "./primary-keys.cjs";
7
9
  import { GelTable } from "./table.cjs";
8
10
  import { type UniqueConstraint } from "./unique-constraint.cjs";
11
+ import type { GelViewBase } from "./view-base.cjs";
9
12
  import { type GelMaterializedView, type GelView } from "./view.cjs";
10
13
  export declare function getTableConfig<TTable extends GelTable>(table: TTable): {
11
14
  columns: import("./index.ts").GelColumn<import("../column.ts").ColumnBaseConfig<import("../column-builder.ts").ColumnDataType, string>, {}, {}>[];
@@ -19,14 +22,15 @@ export declare function getTableConfig<TTable extends GelTable>(table: TTable):
19
22
  policies: GelPolicy[];
20
23
  enableRLS: boolean;
21
24
  };
25
+ export declare function extractUsedTable(table: GelTable | Subquery | GelViewBase | SQL): string[];
22
26
  export declare function getViewConfig<TName extends string = string, TExisting extends boolean = boolean>(view: GelView<TName, TExisting>): {
23
27
  with?: import("./view.ts").ViewWithConfig;
24
28
  name: TName;
25
29
  originalName: TName;
26
30
  schema: string | undefined;
27
- selectedFields: import("../index.ts").ColumnsSelection;
31
+ selectedFields: import("../sql/sql.ts").ColumnsSelection;
28
32
  isExisting: TExisting;
29
- query: TExisting extends true ? undefined : import("../index.ts").SQL<unknown>;
33
+ query: TExisting extends true ? undefined : SQL<unknown>;
30
34
  isAlias: boolean;
31
35
  };
32
36
  export declare function getMaterializedViewConfig<TName extends string = string, TExisting extends boolean = boolean>(view: GelMaterializedView<TName, TExisting>): {
@@ -37,9 +41,9 @@ export declare function getMaterializedViewConfig<TName extends string = string,
37
41
  name: TName;
38
42
  originalName: TName;
39
43
  schema: string | undefined;
40
- selectedFields: import("../index.ts").ColumnsSelection;
44
+ selectedFields: import("../sql/sql.ts").ColumnsSelection;
41
45
  isExisting: TExisting;
42
- query: TExisting extends true ? undefined : import("../index.ts").SQL<unknown>;
46
+ query: TExisting extends true ? undefined : SQL<unknown>;
43
47
  isAlias: boolean;
44
48
  };
45
49
  export type ColumnsWithTable<TTableName extends string, TForeignTableName extends string, TColumns extends AnyGelColumn<{
@@ -1,3 +1,5 @@
1
+ import { SQL } from "../sql/sql.js";
2
+ import { Subquery } from "../subquery.js";
1
3
  import { type Check } from "./checks.js";
2
4
  import type { AnyGelColumn } from "./columns/index.js";
3
5
  import { type ForeignKey } from "./foreign-keys.js";
@@ -6,6 +8,7 @@ import { GelPolicy } from "./policies.js";
6
8
  import { type PrimaryKey } from "./primary-keys.js";
7
9
  import { GelTable } from "./table.js";
8
10
  import { type UniqueConstraint } from "./unique-constraint.js";
11
+ import type { GelViewBase } from "./view-base.js";
9
12
  import { type GelMaterializedView, type GelView } from "./view.js";
10
13
  export declare function getTableConfig<TTable extends GelTable>(table: TTable): {
11
14
  columns: import("./index.js").GelColumn<import("../column.js").ColumnBaseConfig<import("../column-builder.js").ColumnDataType, string>, {}, {}>[];
@@ -19,14 +22,15 @@ export declare function getTableConfig<TTable extends GelTable>(table: TTable):
19
22
  policies: GelPolicy[];
20
23
  enableRLS: boolean;
21
24
  };
25
+ export declare function extractUsedTable(table: GelTable | Subquery | GelViewBase | SQL): string[];
22
26
  export declare function getViewConfig<TName extends string = string, TExisting extends boolean = boolean>(view: GelView<TName, TExisting>): {
23
27
  with?: import("./view.js").ViewWithConfig;
24
28
  name: TName;
25
29
  originalName: TName;
26
30
  schema: string | undefined;
27
- selectedFields: import("../index.js").ColumnsSelection;
31
+ selectedFields: import("../sql/sql.js").ColumnsSelection;
28
32
  isExisting: TExisting;
29
- query: TExisting extends true ? undefined : import("../index.js").SQL<unknown>;
33
+ query: TExisting extends true ? undefined : SQL<unknown>;
30
34
  isAlias: boolean;
31
35
  };
32
36
  export declare function getMaterializedViewConfig<TName extends string = string, TExisting extends boolean = boolean>(view: GelMaterializedView<TName, TExisting>): {
@@ -37,9 +41,9 @@ export declare function getMaterializedViewConfig<TName extends string = string,
37
41
  name: TName;
38
42
  originalName: TName;
39
43
  schema: string | undefined;
40
- selectedFields: import("../index.js").ColumnsSelection;
44
+ selectedFields: import("../sql/sql.js").ColumnsSelection;
41
45
  isExisting: TExisting;
42
- query: TExisting extends true ? undefined : import("../index.js").SQL<unknown>;
46
+ query: TExisting extends true ? undefined : SQL<unknown>;
43
47
  isAlias: boolean;
44
48
  };
45
49
  export type ColumnsWithTable<TTableName extends string, TForeignTableName extends string, TColumns extends AnyGelColumn<{
package/gel-core/utils.js CHANGED
@@ -1,4 +1,6 @@
1
1
  import { is } from "../entity.js";
2
+ import { SQL } from "../sql/sql.js";
3
+ import { Subquery } from "../subquery.js";
2
4
  import { Table } from "../table.js";
3
5
  import { ViewBaseConfig } from "../view-common.js";
4
6
  import { CheckBuilder } from "./checks.js";
@@ -54,6 +56,18 @@ function getTableConfig(table) {
54
56
  enableRLS
55
57
  };
56
58
  }
59
+ function extractUsedTable(table) {
60
+ if (is(table, GelTable)) {
61
+ return [`${table[Table.Symbol.BaseName]}`];
62
+ }
63
+ if (is(table, Subquery)) {
64
+ return table._.usedTables ?? [];
65
+ }
66
+ if (is(table, SQL)) {
67
+ return table.usedTables ?? [];
68
+ }
69
+ return [];
70
+ }
57
71
  function getViewConfig(view) {
58
72
  return {
59
73
  ...view[ViewBaseConfig],
@@ -67,6 +81,7 @@ function getMaterializedViewConfig(view) {
67
81
  };
68
82
  }
69
83
  export {
84
+ extractUsedTable,
70
85
  getMaterializedViewConfig,
71
86
  getTableConfig,
72
87
  getViewConfig
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/gel-core/utils.ts"],"sourcesContent":["import { is } from '~/entity.ts';\nimport { Table } from '~/table.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { type Check, CheckBuilder } from './checks.ts';\nimport type { AnyGelColumn } from './columns/index.ts';\nimport { type ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { Index } from './indexes.ts';\nimport { IndexBuilder } from './indexes.ts';\nimport { GelPolicy } from './policies.ts';\nimport { type PrimaryKey, PrimaryKeyBuilder } from './primary-keys.ts';\nimport { GelTable } from './table.ts';\nimport { type UniqueConstraint, UniqueConstraintBuilder } from './unique-constraint.ts';\nimport { GelViewConfig } from './view-common.ts';\nimport { type GelMaterializedView, GelMaterializedViewConfig, type GelView } from './view.ts';\n\nexport function getTableConfig<TTable extends GelTable>(table: TTable) {\n\tconst columns = Object.values(table[Table.Symbol.Columns]);\n\tconst indexes: Index[] = [];\n\tconst checks: Check[] = [];\n\tconst primaryKeys: PrimaryKey[] = [];\n\tconst foreignKeys: ForeignKey[] = Object.values(table[GelTable.Symbol.InlineForeignKeys]);\n\tconst uniqueConstraints: UniqueConstraint[] = [];\n\tconst name = table[Table.Symbol.Name];\n\tconst schema = table[Table.Symbol.Schema];\n\tconst policies: GelPolicy[] = [];\n\tconst enableRLS: boolean = table[GelTable.Symbol.EnableRLS];\n\n\tconst extraConfigBuilder = table[GelTable.Symbol.ExtraConfigBuilder];\n\n\tif (extraConfigBuilder !== undefined) {\n\t\tconst extraConfig = extraConfigBuilder(table[Table.Symbol.ExtraConfigColumns]);\n\t\tconst extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) as any[] : Object.values(extraConfig);\n\t\tfor (const builder of extraValues) {\n\t\t\tif (is(builder, IndexBuilder)) {\n\t\t\t\tindexes.push(builder.build(table));\n\t\t\t} else if (is(builder, CheckBuilder)) {\n\t\t\t\tchecks.push(builder.build(table));\n\t\t\t} else if (is(builder, UniqueConstraintBuilder)) {\n\t\t\t\tuniqueConstraints.push(builder.build(table));\n\t\t\t} else if (is(builder, PrimaryKeyBuilder)) {\n\t\t\t\tprimaryKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, ForeignKeyBuilder)) {\n\t\t\t\tforeignKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, GelPolicy)) {\n\t\t\t\tpolicies.push(builder);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn {\n\t\tcolumns,\n\t\tindexes,\n\t\tforeignKeys,\n\t\tchecks,\n\t\tprimaryKeys,\n\t\tuniqueConstraints,\n\t\tname,\n\t\tschema,\n\t\tpolicies,\n\t\tenableRLS,\n\t};\n}\n\nexport function getViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: GelView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t...view[GelViewConfig],\n\t};\n}\n\nexport function getMaterializedViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: GelMaterializedView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t...view[GelMaterializedViewConfig],\n\t};\n}\n\nexport type ColumnsWithTable<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyGelColumn<{ tableName: TTableName }>[],\n> = { [Key in keyof TColumns]: AnyGelColumn<{ tableName: TForeignTableName }> };\n"],"mappings":"AAAA,SAAS,UAAU;AACnB,SAAS,aAAa;AACtB,SAAS,sBAAsB;AAC/B,SAAqB,oBAAoB;AAEzC,SAA0B,yBAAyB;AAEnD,SAAS,oBAAoB;AAC7B,SAAS,iBAAiB;AAC1B,SAA0B,yBAAyB;AACnD,SAAS,gBAAgB;AACzB,SAAgC,+BAA+B;AAC/D,SAAS,qBAAqB;AAC9B,SAAmC,iCAA+C;AAE3E,SAAS,eAAwC,OAAe;AACtE,QAAM,UAAU,OAAO,OAAO,MAAM,MAAM,OAAO,OAAO,CAAC;AACzD,QAAM,UAAmB,CAAC;AAC1B,QAAM,SAAkB,CAAC;AACzB,QAAM,cAA4B,CAAC;AACnC,QAAM,cAA4B,OAAO,OAAO,MAAM,SAAS,OAAO,iBAAiB,CAAC;AACxF,QAAM,oBAAwC,CAAC;AAC/C,QAAM,OAAO,MAAM,MAAM,OAAO,IAAI;AACpC,QAAM,SAAS,MAAM,MAAM,OAAO,MAAM;AACxC,QAAM,WAAwB,CAAC;AAC/B,QAAM,YAAqB,MAAM,SAAS,OAAO,SAAS;AAE1D,QAAM,qBAAqB,MAAM,SAAS,OAAO,kBAAkB;AAEnE,MAAI,uBAAuB,QAAW;AACrC,UAAM,cAAc,mBAAmB,MAAM,MAAM,OAAO,kBAAkB,CAAC;AAC7E,UAAM,cAAc,MAAM,QAAQ,WAAW,IAAI,YAAY,KAAK,CAAC,IAAa,OAAO,OAAO,WAAW;AACzG,eAAW,WAAW,aAAa;AAClC,UAAI,GAAG,SAAS,YAAY,GAAG;AAC9B,gBAAQ,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MAClC,WAAW,GAAG,SAAS,YAAY,GAAG;AACrC,eAAO,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACjC,WAAW,GAAG,SAAS,uBAAuB,GAAG;AAChD,0BAAkB,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MAC5C,WAAW,GAAG,SAAS,iBAAiB,GAAG;AAC1C,oBAAY,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACtC,WAAW,GAAG,SAAS,iBAAiB,GAAG;AAC1C,oBAAY,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACtC,WAAW,GAAG,SAAS,SAAS,GAAG;AAClC,iBAAS,KAAK,OAAO;AAAA,MACtB;AAAA,IACD;AAAA,EACD;AAEA,SAAO;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AACD;AAEO,SAAS,cAGd,MAAiC;AAClC,SAAO;AAAA,IACN,GAAG,KAAK,cAAc;AAAA,IACtB,GAAG,KAAK,aAAa;AAAA,EACtB;AACD;AAEO,SAAS,0BAGd,MAA6C;AAC9C,SAAO;AAAA,IACN,GAAG,KAAK,cAAc;AAAA,IACtB,GAAG,KAAK,yBAAyB;AAAA,EAClC;AACD;","names":[]}
1
+ {"version":3,"sources":["../../src/gel-core/utils.ts"],"sourcesContent":["import { is } from '~/entity.ts';\nimport { SQL } from '~/sql/sql.ts';\nimport { Subquery } from '~/subquery.ts';\nimport { Table } from '~/table.ts';\nimport { ViewBaseConfig } from '~/view-common.ts';\nimport { type Check, CheckBuilder } from './checks.ts';\nimport type { AnyGelColumn } from './columns/index.ts';\nimport { type ForeignKey, ForeignKeyBuilder } from './foreign-keys.ts';\nimport type { Index } from './indexes.ts';\nimport { IndexBuilder } from './indexes.ts';\nimport { GelPolicy } from './policies.ts';\nimport { type PrimaryKey, PrimaryKeyBuilder } from './primary-keys.ts';\nimport { GelTable } from './table.ts';\nimport { type UniqueConstraint, UniqueConstraintBuilder } from './unique-constraint.ts';\nimport type { GelViewBase } from './view-base.ts';\nimport { GelViewConfig } from './view-common.ts';\nimport { type GelMaterializedView, GelMaterializedViewConfig, type GelView } from './view.ts';\n\nexport function getTableConfig<TTable extends GelTable>(table: TTable) {\n\tconst columns = Object.values(table[Table.Symbol.Columns]);\n\tconst indexes: Index[] = [];\n\tconst checks: Check[] = [];\n\tconst primaryKeys: PrimaryKey[] = [];\n\tconst foreignKeys: ForeignKey[] = Object.values(table[GelTable.Symbol.InlineForeignKeys]);\n\tconst uniqueConstraints: UniqueConstraint[] = [];\n\tconst name = table[Table.Symbol.Name];\n\tconst schema = table[Table.Symbol.Schema];\n\tconst policies: GelPolicy[] = [];\n\tconst enableRLS: boolean = table[GelTable.Symbol.EnableRLS];\n\n\tconst extraConfigBuilder = table[GelTable.Symbol.ExtraConfigBuilder];\n\n\tif (extraConfigBuilder !== undefined) {\n\t\tconst extraConfig = extraConfigBuilder(table[Table.Symbol.ExtraConfigColumns]);\n\t\tconst extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) as any[] : Object.values(extraConfig);\n\t\tfor (const builder of extraValues) {\n\t\t\tif (is(builder, IndexBuilder)) {\n\t\t\t\tindexes.push(builder.build(table));\n\t\t\t} else if (is(builder, CheckBuilder)) {\n\t\t\t\tchecks.push(builder.build(table));\n\t\t\t} else if (is(builder, UniqueConstraintBuilder)) {\n\t\t\t\tuniqueConstraints.push(builder.build(table));\n\t\t\t} else if (is(builder, PrimaryKeyBuilder)) {\n\t\t\t\tprimaryKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, ForeignKeyBuilder)) {\n\t\t\t\tforeignKeys.push(builder.build(table));\n\t\t\t} else if (is(builder, GelPolicy)) {\n\t\t\t\tpolicies.push(builder);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn {\n\t\tcolumns,\n\t\tindexes,\n\t\tforeignKeys,\n\t\tchecks,\n\t\tprimaryKeys,\n\t\tuniqueConstraints,\n\t\tname,\n\t\tschema,\n\t\tpolicies,\n\t\tenableRLS,\n\t};\n}\n\nexport function extractUsedTable(table: GelTable | Subquery | GelViewBase | SQL): string[] {\n\tif (is(table, GelTable)) {\n\t\treturn [`${table[Table.Symbol.BaseName]}`];\n\t}\n\tif (is(table, Subquery)) {\n\t\treturn table._.usedTables ?? [];\n\t}\n\tif (is(table, SQL)) {\n\t\treturn table.usedTables ?? [];\n\t}\n\treturn [];\n}\n\nexport function getViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: GelView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t...view[GelViewConfig],\n\t};\n}\n\nexport function getMaterializedViewConfig<\n\tTName extends string = string,\n\tTExisting extends boolean = boolean,\n>(view: GelMaterializedView<TName, TExisting>) {\n\treturn {\n\t\t...view[ViewBaseConfig],\n\t\t...view[GelMaterializedViewConfig],\n\t};\n}\n\nexport type ColumnsWithTable<\n\tTTableName extends string,\n\tTForeignTableName extends string,\n\tTColumns extends AnyGelColumn<{ tableName: TTableName }>[],\n> = { [Key in keyof TColumns]: AnyGelColumn<{ tableName: TForeignTableName }> };\n"],"mappings":"AAAA,SAAS,UAAU;AACnB,SAAS,WAAW;AACpB,SAAS,gBAAgB;AACzB,SAAS,aAAa;AACtB,SAAS,sBAAsB;AAC/B,SAAqB,oBAAoB;AAEzC,SAA0B,yBAAyB;AAEnD,SAAS,oBAAoB;AAC7B,SAAS,iBAAiB;AAC1B,SAA0B,yBAAyB;AACnD,SAAS,gBAAgB;AACzB,SAAgC,+BAA+B;AAE/D,SAAS,qBAAqB;AAC9B,SAAmC,iCAA+C;AAE3E,SAAS,eAAwC,OAAe;AACtE,QAAM,UAAU,OAAO,OAAO,MAAM,MAAM,OAAO,OAAO,CAAC;AACzD,QAAM,UAAmB,CAAC;AAC1B,QAAM,SAAkB,CAAC;AACzB,QAAM,cAA4B,CAAC;AACnC,QAAM,cAA4B,OAAO,OAAO,MAAM,SAAS,OAAO,iBAAiB,CAAC;AACxF,QAAM,oBAAwC,CAAC;AAC/C,QAAM,OAAO,MAAM,MAAM,OAAO,IAAI;AACpC,QAAM,SAAS,MAAM,MAAM,OAAO,MAAM;AACxC,QAAM,WAAwB,CAAC;AAC/B,QAAM,YAAqB,MAAM,SAAS,OAAO,SAAS;AAE1D,QAAM,qBAAqB,MAAM,SAAS,OAAO,kBAAkB;AAEnE,MAAI,uBAAuB,QAAW;AACrC,UAAM,cAAc,mBAAmB,MAAM,MAAM,OAAO,kBAAkB,CAAC;AAC7E,UAAM,cAAc,MAAM,QAAQ,WAAW,IAAI,YAAY,KAAK,CAAC,IAAa,OAAO,OAAO,WAAW;AACzG,eAAW,WAAW,aAAa;AAClC,UAAI,GAAG,SAAS,YAAY,GAAG;AAC9B,gBAAQ,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MAClC,WAAW,GAAG,SAAS,YAAY,GAAG;AACrC,eAAO,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACjC,WAAW,GAAG,SAAS,uBAAuB,GAAG;AAChD,0BAAkB,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MAC5C,WAAW,GAAG,SAAS,iBAAiB,GAAG;AAC1C,oBAAY,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACtC,WAAW,GAAG,SAAS,iBAAiB,GAAG;AAC1C,oBAAY,KAAK,QAAQ,MAAM,KAAK,CAAC;AAAA,MACtC,WAAW,GAAG,SAAS,SAAS,GAAG;AAClC,iBAAS,KAAK,OAAO;AAAA,MACtB;AAAA,IACD;AAAA,EACD;AAEA,SAAO;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACD;AACD;AAEO,SAAS,iBAAiB,OAA0D;AAC1F,MAAI,GAAG,OAAO,QAAQ,GAAG;AACxB,WAAO,CAAC,GAAG,MAAM,MAAM,OAAO,QAAQ,CAAC,EAAE;AAAA,EAC1C;AACA,MAAI,GAAG,OAAO,QAAQ,GAAG;AACxB,WAAO,MAAM,EAAE,cAAc,CAAC;AAAA,EAC/B;AACA,MAAI,GAAG,OAAO,GAAG,GAAG;AACnB,WAAO,MAAM,cAAc,CAAC;AAAA,EAC7B;AACA,SAAO,CAAC;AACT;AAEO,SAAS,cAGd,MAAiC;AAClC,SAAO;AAAA,IACN,GAAG,KAAK,cAAc;AAAA,IACtB,GAAG,KAAK,aAAa;AAAA,EACtB;AACD;AAEO,SAAS,0BAGd,MAA6C;AAC9C,SAAO;AAAA,IACN,GAAG,KAAK,cAAc;AAAA,IACtB,GAAG,KAAK,yBAAyB;AAAA,EAClC;AACD;","names":[]}
@@ -54,9 +54,13 @@ function construct(client, config = {}) {
54
54
  tableNamesMap: tablesConfig.tableNamesMap
55
55
  };
56
56
  }
57
- const session = new import_session.LibSQLSession(client, dialect, schema, { logger }, void 0);
57
+ const session = new import_session.LibSQLSession(client, dialect, schema, { logger, cache: config.cache }, void 0);
58
58
  const db = new LibSQLDatabase("async", dialect, session, schema);
59
59
  db.$client = client;
60
+ db.$cache = config.cache;
61
+ if (db.$cache) {
62
+ db.$cache["invalidate"] = config.cache?.onMutate;
63
+ }
60
64
  return db;
61
65
  }
62
66
  // Annotate the CommonJS export names for ESM import in node:
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/libsql/driver-core.ts"],"sourcesContent":["import type { Client, ResultSet } from '@libsql/client';\nimport type { BatchItem, BatchResponse } from '~/batch.ts';\nimport { entityKind } from '~/entity.ts';\nimport { DefaultLogger } from '~/logger.ts';\nimport {\n\tcreateTableRelationsHelpers,\n\textractTablesRelationalConfig,\n\ttype ExtractTablesWithRelations,\n\ttype RelationalSchemaConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport { BaseSQLiteDatabase } from '~/sqlite-core/db.ts';\nimport { SQLiteAsyncDialect } from '~/sqlite-core/dialect.ts';\nimport type { DrizzleConfig } from '~/utils.ts';\nimport { LibSQLSession } from './session.ts';\n\nexport class LibSQLDatabase<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n> extends BaseSQLiteDatabase<'async', ResultSet, TSchema> {\n\tstatic override readonly [entityKind]: string = 'LibSQLDatabase';\n\n\t/** @internal */\n\tdeclare readonly session: LibSQLSession<TSchema, ExtractTablesWithRelations<TSchema>>;\n\n\tasync batch<U extends BatchItem<'sqlite'>, T extends Readonly<[U, ...U[]]>>(\n\t\tbatch: T,\n\t): Promise<BatchResponse<T>> {\n\t\treturn this.session.batch(batch) as Promise<BatchResponse<T>>;\n\t}\n}\n\n/** @internal */\nexport function construct<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n>(client: Client, config: DrizzleConfig<TSchema> = {}): LibSQLDatabase<TSchema> & {\n\t$client: Client;\n} {\n\tconst dialect = new SQLiteAsyncDialect({ 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 session = new LibSQLSession(client, dialect, schema, { logger }, undefined);\n\tconst db = new LibSQLDatabase('async', dialect, session, schema) as LibSQLDatabase<TSchema>;\n\t(<any> db).$client = client;\n\n\treturn db as any;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,oBAA2B;AAC3B,oBAA8B;AAC9B,uBAMO;AACP,gBAAmC;AACnC,qBAAmC;AAEnC,qBAA8B;AAEvB,MAAM,uBAEH,6BAAgD;AAAA,EACzD,QAA0B,wBAAU,IAAY;AAAA,EAKhD,MAAM,MACL,OAC4B;AAC5B,WAAO,KAAK,QAAQ,MAAM,KAAK;AAAA,EAChC;AACD;AAGO,SAAS,UAEd,QAAgB,SAAiC,CAAC,GAElD;AACD,QAAM,UAAU,IAAI,kCAAmB,EAAE,QAAQ,OAAO,OAAO,CAAC;AAChE,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;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,UAAU,IAAI,6BAAc,QAAQ,SAAS,QAAQ,EAAE,OAAO,GAAG,MAAS;AAChF,QAAM,KAAK,IAAI,eAAe,SAAS,SAAS,SAAS,MAAM;AAC/D,EAAO,GAAI,UAAU;AAErB,SAAO;AACR;","names":[]}
1
+ {"version":3,"sources":["../../src/libsql/driver-core.ts"],"sourcesContent":["import type { Client, ResultSet } from '@libsql/client';\nimport type { BatchItem, BatchResponse } from '~/batch.ts';\nimport { entityKind } from '~/entity.ts';\nimport { DefaultLogger } from '~/logger.ts';\nimport {\n\tcreateTableRelationsHelpers,\n\textractTablesRelationalConfig,\n\ttype ExtractTablesWithRelations,\n\ttype RelationalSchemaConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport { BaseSQLiteDatabase } from '~/sqlite-core/db.ts';\nimport { SQLiteAsyncDialect } from '~/sqlite-core/dialect.ts';\nimport type { DrizzleConfig } from '~/utils.ts';\nimport { LibSQLSession } from './session.ts';\n\nexport class LibSQLDatabase<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n> extends BaseSQLiteDatabase<'async', ResultSet, TSchema> {\n\tstatic override readonly [entityKind]: string = 'LibSQLDatabase';\n\n\t/** @internal */\n\tdeclare readonly session: LibSQLSession<TSchema, ExtractTablesWithRelations<TSchema>>;\n\n\tasync batch<U extends BatchItem<'sqlite'>, T extends Readonly<[U, ...U[]]>>(\n\t\tbatch: T,\n\t): Promise<BatchResponse<T>> {\n\t\treturn this.session.batch(batch) as Promise<BatchResponse<T>>;\n\t}\n}\n\n/** @internal */\nexport function construct<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n>(client: Client, config: DrizzleConfig<TSchema> = {}): LibSQLDatabase<TSchema> & {\n\t$client: Client;\n} {\n\tconst dialect = new SQLiteAsyncDialect({ 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 session = new LibSQLSession(client, dialect, schema, { logger, cache: config.cache }, undefined);\n\tconst db = new LibSQLDatabase('async', dialect, session, schema) as LibSQLDatabase<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\treturn db as any;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,oBAA2B;AAC3B,oBAA8B;AAC9B,uBAMO;AACP,gBAAmC;AACnC,qBAAmC;AAEnC,qBAA8B;AAEvB,MAAM,uBAEH,6BAAgD;AAAA,EACzD,QAA0B,wBAAU,IAAY;AAAA,EAKhD,MAAM,MACL,OAC4B;AAC5B,WAAO,KAAK,QAAQ,MAAM,KAAK;AAAA,EAChC;AACD;AAGO,SAAS,UAEd,QAAgB,SAAiC,CAAC,GAElD;AACD,QAAM,UAAU,IAAI,kCAAmB,EAAE,QAAQ,OAAO,OAAO,CAAC;AAChE,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;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,UAAU,IAAI,6BAAc,QAAQ,SAAS,QAAQ,EAAE,QAAQ,OAAO,OAAO,MAAM,GAAG,MAAS;AACrG,QAAM,KAAK,IAAI,eAAe,SAAS,SAAS,SAAS,MAAM;AAC/D,EAAO,GAAI,UAAU;AACrB,EAAO,GAAI,SAAS,OAAO;AAC3B,MAAW,GAAI,QAAQ;AACtB,IAAO,GAAI,OAAO,YAAY,IAAI,OAAO,OAAO;AAAA,EACjD;AACA,SAAO;AACR;","names":[]}
@@ -33,9 +33,13 @@ function construct(client, config = {}) {
33
33
  tableNamesMap: tablesConfig.tableNamesMap
34
34
  };
35
35
  }
36
- const session = new LibSQLSession(client, dialect, schema, { logger }, void 0);
36
+ const session = new LibSQLSession(client, dialect, schema, { logger, cache: config.cache }, void 0);
37
37
  const db = new LibSQLDatabase("async", dialect, session, schema);
38
38
  db.$client = client;
39
+ db.$cache = config.cache;
40
+ if (db.$cache) {
41
+ db.$cache["invalidate"] = config.cache?.onMutate;
42
+ }
39
43
  return db;
40
44
  }
41
45
  export {