drizzle-orm 0.43.1-d1468f0 → 0.43.1-e3d1c4f

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 (866) hide show
  1. package/aws-data-api/pg/driver.cjs +7 -10
  2. package/aws-data-api/pg/driver.cjs.map +1 -1
  3. package/aws-data-api/pg/driver.d.cts +4 -4
  4. package/aws-data-api/pg/driver.d.ts +4 -4
  5. package/aws-data-api/pg/driver.js +7 -10
  6. package/aws-data-api/pg/driver.js.map +1 -1
  7. package/aws-data-api/pg/session.cjs +26 -20
  8. package/aws-data-api/pg/session.cjs.map +1 -1
  9. package/aws-data-api/pg/session.d.cts +6 -16
  10. package/aws-data-api/pg/session.d.ts +6 -16
  11. package/aws-data-api/pg/session.js +26 -20
  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.d.cts +4 -3
  15. package/better-sqlite3/driver.d.ts +4 -3
  16. package/better-sqlite3/driver.js.map +1 -1
  17. package/better-sqlite3/session.cjs +7 -13
  18. package/better-sqlite3/session.cjs.map +1 -1
  19. package/better-sqlite3/session.d.cts +6 -16
  20. package/better-sqlite3/session.d.ts +6 -16
  21. package/better-sqlite3/session.js +7 -13
  22. package/better-sqlite3/session.js.map +1 -1
  23. package/bun-sql/driver.cjs +3 -6
  24. package/bun-sql/driver.cjs.map +1 -1
  25. package/bun-sql/driver.d.cts +4 -3
  26. package/bun-sql/driver.d.ts +4 -3
  27. package/bun-sql/driver.js +3 -6
  28. package/bun-sql/driver.js.map +1 -1
  29. package/bun-sql/session.cjs +26 -29
  30. package/bun-sql/session.cjs.map +1 -1
  31. package/bun-sql/session.d.cts +6 -15
  32. package/bun-sql/session.d.ts +6 -15
  33. package/bun-sql/session.js +26 -29
  34. package/bun-sql/session.js.map +1 -1
  35. package/bun-sqlite/driver.cjs.map +1 -1
  36. package/bun-sqlite/driver.d.cts +4 -3
  37. package/bun-sqlite/driver.d.ts +4 -3
  38. package/bun-sqlite/driver.js.map +1 -1
  39. package/bun-sqlite/session.cjs +5 -5
  40. package/bun-sqlite/session.cjs.map +1 -1
  41. package/bun-sqlite/session.d.cts +5 -5
  42. package/bun-sqlite/session.d.ts +5 -5
  43. package/bun-sqlite/session.js +5 -5
  44. package/bun-sqlite/session.js.map +1 -1
  45. package/column-builder.cjs.map +1 -1
  46. package/column-builder.d.cts +7 -2
  47. package/column-builder.d.ts +7 -2
  48. package/column-builder.js.map +1 -1
  49. package/column.cjs +2 -0
  50. package/column.cjs.map +1 -1
  51. package/column.d.cts +6 -0
  52. package/column.d.ts +6 -0
  53. package/column.js +2 -0
  54. package/column.js.map +1 -1
  55. package/d1/driver.cjs +3 -6
  56. package/d1/driver.cjs.map +1 -1
  57. package/d1/driver.d.cts +2 -1
  58. package/d1/driver.d.ts +2 -1
  59. package/d1/driver.js +3 -6
  60. package/d1/driver.js.map +1 -1
  61. package/d1/session.cjs +24 -29
  62. package/d1/session.cjs.map +1 -1
  63. package/d1/session.d.cts +8 -17
  64. package/d1/session.d.ts +8 -17
  65. package/d1/session.js +24 -29
  66. package/d1/session.js.map +1 -1
  67. package/durable-sqlite/driver.cjs.map +1 -1
  68. package/durable-sqlite/driver.d.cts +2 -1
  69. package/durable-sqlite/driver.d.ts +2 -1
  70. package/durable-sqlite/driver.js.map +1 -1
  71. package/durable-sqlite/session.cjs +6 -6
  72. package/durable-sqlite/session.cjs.map +1 -1
  73. package/durable-sqlite/session.d.cts +5 -5
  74. package/durable-sqlite/session.d.ts +5 -5
  75. package/durable-sqlite/session.js +6 -6
  76. package/durable-sqlite/session.js.map +1 -1
  77. package/expo-sqlite/driver.cjs.map +1 -1
  78. package/expo-sqlite/driver.d.cts +2 -1
  79. package/expo-sqlite/driver.d.ts +2 -1
  80. package/expo-sqlite/driver.js.map +1 -1
  81. package/expo-sqlite/session.cjs +5 -5
  82. package/expo-sqlite/session.cjs.map +1 -1
  83. package/expo-sqlite/session.d.cts +5 -5
  84. package/expo-sqlite/session.d.ts +5 -5
  85. package/expo-sqlite/session.js +5 -5
  86. package/expo-sqlite/session.js.map +1 -1
  87. package/{cache/core/cache.cjs → extension-core/gel/index.cjs} +9 -23
  88. package/extension-core/gel/index.cjs.map +1 -0
  89. package/extension-core/gel/index.d.cts +67 -0
  90. package/extension-core/gel/index.d.ts +67 -0
  91. package/extension-core/gel/index.js +9 -0
  92. package/extension-core/gel/index.js.map +1 -0
  93. package/extension-core/index.cjs +42 -0
  94. package/extension-core/index.cjs.map +1 -0
  95. package/extension-core/index.d.cts +9 -0
  96. package/extension-core/index.d.ts +9 -0
  97. package/extension-core/index.js +15 -0
  98. package/extension-core/index.js.map +1 -0
  99. package/{errors → extension-core/mysql}/index.cjs +9 -16
  100. package/extension-core/mysql/index.cjs.map +1 -0
  101. package/extension-core/mysql/index.d.cts +69 -0
  102. package/extension-core/mysql/index.d.ts +69 -0
  103. package/extension-core/mysql/index.js +9 -0
  104. package/extension-core/mysql/index.js.map +1 -0
  105. package/extension-core/pg/index.cjs +33 -0
  106. package/extension-core/pg/index.cjs.map +1 -0
  107. package/extension-core/pg/index.d.cts +67 -0
  108. package/extension-core/pg/index.d.ts +67 -0
  109. package/extension-core/pg/index.js +9 -0
  110. package/extension-core/pg/index.js.map +1 -0
  111. package/extension-core/singlestore/index.cjs +33 -0
  112. package/extension-core/singlestore/index.cjs.map +1 -0
  113. package/extension-core/singlestore/index.d.cts +67 -0
  114. package/extension-core/singlestore/index.d.ts +67 -0
  115. package/extension-core/singlestore/index.js +9 -0
  116. package/extension-core/singlestore/index.js.map +1 -0
  117. package/extension-core/sqlite/index.cjs +33 -0
  118. package/extension-core/sqlite/index.cjs.map +1 -0
  119. package/extension-core/sqlite/index.d.cts +68 -0
  120. package/extension-core/sqlite/index.d.ts +68 -0
  121. package/extension-core/sqlite/index.js +9 -0
  122. package/extension-core/sqlite/index.js.map +1 -0
  123. package/extensions/hook/gel/index.cjs +47 -0
  124. package/extensions/hook/gel/index.cjs.map +1 -0
  125. package/extensions/hook/gel/index.d.cts +11 -0
  126. package/extensions/hook/gel/index.d.ts +11 -0
  127. package/extensions/hook/gel/index.js +22 -0
  128. package/extensions/hook/gel/index.js.map +1 -0
  129. package/extensions/hook/mysql/index.cjs +47 -0
  130. package/extensions/hook/mysql/index.cjs.map +1 -0
  131. package/extensions/hook/mysql/index.d.cts +11 -0
  132. package/extensions/hook/mysql/index.d.ts +11 -0
  133. package/extensions/hook/mysql/index.js +22 -0
  134. package/extensions/hook/mysql/index.js.map +1 -0
  135. package/extensions/hook/pg/index.cjs +47 -0
  136. package/extensions/hook/pg/index.cjs.map +1 -0
  137. package/extensions/hook/pg/index.d.cts +11 -0
  138. package/extensions/hook/pg/index.d.ts +11 -0
  139. package/extensions/hook/pg/index.js +22 -0
  140. package/extensions/hook/pg/index.js.map +1 -0
  141. package/extensions/hook/singlestore/index.cjs +47 -0
  142. package/extensions/hook/singlestore/index.cjs.map +1 -0
  143. package/extensions/hook/singlestore/index.d.cts +11 -0
  144. package/extensions/hook/singlestore/index.d.ts +11 -0
  145. package/extensions/hook/singlestore/index.js +22 -0
  146. package/extensions/hook/singlestore/index.js.map +1 -0
  147. package/extensions/hook/sqlite/index.cjs +47 -0
  148. package/extensions/hook/sqlite/index.cjs.map +1 -0
  149. package/extensions/hook/sqlite/index.d.cts +11 -0
  150. package/extensions/hook/sqlite/index.d.ts +11 -0
  151. package/extensions/hook/sqlite/index.js +22 -0
  152. package/extensions/hook/sqlite/index.js.map +1 -0
  153. package/extensions/s3-file/common.cjs +321 -0
  154. package/extensions/s3-file/common.cjs.map +1 -0
  155. package/extensions/s3-file/common.d.cts +88 -0
  156. package/extensions/s3-file/common.d.ts +88 -0
  157. package/extensions/s3-file/common.js +288 -0
  158. package/extensions/s3-file/common.js.map +1 -0
  159. package/extensions/s3-file/gel/column.cjs +124 -0
  160. package/extensions/s3-file/gel/column.cjs.map +1 -0
  161. package/extensions/s3-file/gel/column.d.cts +105 -0
  162. package/extensions/s3-file/gel/column.d.ts +105 -0
  163. package/extensions/s3-file/gel/column.js +103 -0
  164. package/extensions/s3-file/gel/column.js.map +1 -0
  165. package/extensions/s3-file/gel/extension.cjs +271 -0
  166. package/extensions/s3-file/gel/extension.cjs.map +1 -0
  167. package/extensions/s3-file/gel/extension.d.cts +18 -0
  168. package/extensions/s3-file/gel/extension.d.ts +18 -0
  169. package/extensions/s3-file/gel/extension.js +257 -0
  170. package/extensions/s3-file/gel/extension.js.map +1 -0
  171. package/{cache/upstash → extensions/s3-file/gel}/index.cjs +6 -4
  172. package/extensions/s3-file/gel/index.cjs.map +1 -0
  173. package/extensions/s3-file/gel/index.d.cts +2 -0
  174. package/extensions/s3-file/gel/index.d.ts +2 -0
  175. package/extensions/s3-file/gel/index.js +3 -0
  176. package/extensions/s3-file/gel/index.js.map +1 -0
  177. package/{cache/core → extensions/s3-file}/index.cjs +4 -4
  178. package/extensions/s3-file/index.cjs.map +1 -0
  179. package/extensions/s3-file/index.d.cts +1 -0
  180. package/extensions/s3-file/index.d.ts +1 -0
  181. package/extensions/s3-file/index.js +2 -0
  182. package/extensions/s3-file/index.js.map +1 -0
  183. package/extensions/s3-file/mysql/column.cjs +121 -0
  184. package/extensions/s3-file/mysql/column.cjs.map +1 -0
  185. package/extensions/s3-file/mysql/column.d.cts +63 -0
  186. package/extensions/s3-file/mysql/column.d.ts +63 -0
  187. package/extensions/s3-file/mysql/column.js +97 -0
  188. package/extensions/s3-file/mysql/column.js.map +1 -0
  189. package/extensions/s3-file/mysql/extension.cjs +250 -0
  190. package/extensions/s3-file/mysql/extension.cjs.map +1 -0
  191. package/extensions/s3-file/mysql/extension.d.cts +18 -0
  192. package/extensions/s3-file/mysql/extension.d.ts +18 -0
  193. package/extensions/s3-file/mysql/extension.js +236 -0
  194. package/extensions/s3-file/mysql/extension.js.map +1 -0
  195. package/extensions/s3-file/mysql/index.cjs +25 -0
  196. package/extensions/s3-file/mysql/index.cjs.map +1 -0
  197. package/extensions/s3-file/mysql/index.d.cts +2 -0
  198. package/extensions/s3-file/mysql/index.d.ts +2 -0
  199. package/extensions/s3-file/mysql/index.js +3 -0
  200. package/extensions/s3-file/mysql/index.js.map +1 -0
  201. package/extensions/s3-file/pg/column.cjs +124 -0
  202. package/extensions/s3-file/pg/column.cjs.map +1 -0
  203. package/extensions/s3-file/pg/column.d.cts +105 -0
  204. package/extensions/s3-file/pg/column.d.ts +105 -0
  205. package/extensions/s3-file/pg/column.js +103 -0
  206. package/extensions/s3-file/pg/column.js.map +1 -0
  207. package/extensions/s3-file/pg/extension.cjs +272 -0
  208. package/extensions/s3-file/pg/extension.cjs.map +1 -0
  209. package/extensions/s3-file/pg/extension.d.cts +18 -0
  210. package/extensions/s3-file/pg/extension.d.ts +18 -0
  211. package/extensions/s3-file/pg/extension.js +258 -0
  212. package/extensions/s3-file/pg/extension.js.map +1 -0
  213. package/{cache/core/types.cjs → extensions/s3-file/pg/index.cjs} +11 -3
  214. package/extensions/s3-file/pg/index.cjs.map +1 -0
  215. package/extensions/s3-file/pg/index.d.cts +2 -0
  216. package/extensions/s3-file/pg/index.d.ts +2 -0
  217. package/extensions/s3-file/pg/index.js +3 -0
  218. package/extensions/s3-file/pg/index.js.map +1 -0
  219. package/extensions/s3-file/singlestore/column.cjs +121 -0
  220. package/extensions/s3-file/singlestore/column.cjs.map +1 -0
  221. package/extensions/s3-file/singlestore/column.d.cts +63 -0
  222. package/extensions/s3-file/singlestore/column.d.ts +63 -0
  223. package/extensions/s3-file/singlestore/column.js +97 -0
  224. package/extensions/s3-file/singlestore/column.js.map +1 -0
  225. package/extensions/s3-file/singlestore/extension.cjs +247 -0
  226. package/extensions/s3-file/singlestore/extension.cjs.map +1 -0
  227. package/extensions/s3-file/singlestore/extension.d.cts +18 -0
  228. package/extensions/s3-file/singlestore/extension.d.ts +18 -0
  229. package/extensions/s3-file/singlestore/extension.js +233 -0
  230. package/extensions/s3-file/singlestore/extension.js.map +1 -0
  231. package/extensions/s3-file/singlestore/index.cjs +25 -0
  232. package/extensions/s3-file/singlestore/index.cjs.map +1 -0
  233. package/extensions/s3-file/singlestore/index.d.cts +2 -0
  234. package/extensions/s3-file/singlestore/index.d.ts +2 -0
  235. package/extensions/s3-file/singlestore/index.js +3 -0
  236. package/extensions/s3-file/singlestore/index.js.map +1 -0
  237. package/extensions/s3-file/sqlite/column.cjs +121 -0
  238. package/extensions/s3-file/sqlite/column.cjs.map +1 -0
  239. package/extensions/s3-file/sqlite/column.d.cts +63 -0
  240. package/extensions/s3-file/sqlite/column.d.ts +63 -0
  241. package/extensions/s3-file/sqlite/column.js +97 -0
  242. package/extensions/s3-file/sqlite/column.js.map +1 -0
  243. package/extensions/s3-file/sqlite/extension.cjs +250 -0
  244. package/extensions/s3-file/sqlite/extension.cjs.map +1 -0
  245. package/extensions/s3-file/sqlite/extension.d.cts +18 -0
  246. package/extensions/s3-file/sqlite/extension.d.ts +18 -0
  247. package/extensions/s3-file/sqlite/extension.js +236 -0
  248. package/extensions/s3-file/sqlite/extension.js.map +1 -0
  249. package/extensions/s3-file/sqlite/index.cjs +25 -0
  250. package/extensions/s3-file/sqlite/index.cjs.map +1 -0
  251. package/extensions/s3-file/sqlite/index.d.cts +2 -0
  252. package/extensions/s3-file/sqlite/index.d.ts +2 -0
  253. package/extensions/s3-file/sqlite/index.js +3 -0
  254. package/extensions/s3-file/sqlite/index.js.map +1 -0
  255. package/gel/driver.cjs +6 -11
  256. package/gel/driver.cjs.map +1 -1
  257. package/gel/driver.d.cts +6 -6
  258. package/gel/driver.d.ts +6 -6
  259. package/gel/driver.js +6 -11
  260. package/gel/driver.js.map +1 -1
  261. package/gel/session.cjs +19 -31
  262. package/gel/session.cjs.map +1 -1
  263. package/gel/session.d.cts +5 -14
  264. package/gel/session.d.ts +5 -14
  265. package/gel/session.js +19 -31
  266. package/gel/session.js.map +1 -1
  267. package/gel-core/columns/common.cjs +8 -0
  268. package/gel-core/columns/common.cjs.map +1 -1
  269. package/gel-core/columns/common.d.cts +2 -0
  270. package/gel-core/columns/common.d.ts +2 -0
  271. package/gel-core/columns/common.js +8 -0
  272. package/gel-core/columns/common.js.map +1 -1
  273. package/gel-core/db.cjs +5 -6
  274. package/gel-core/db.cjs.map +1 -1
  275. package/gel-core/db.d.cts +3 -5
  276. package/gel-core/db.d.ts +3 -5
  277. package/gel-core/db.js +5 -6
  278. package/gel-core/db.js.map +1 -1
  279. package/gel-core/dialect.cjs +25 -19
  280. package/gel-core/dialect.cjs.map +1 -1
  281. package/gel-core/dialect.d.cts +7 -6
  282. package/gel-core/dialect.d.ts +7 -6
  283. package/gel-core/dialect.js +26 -20
  284. package/gel-core/dialect.js.map +1 -1
  285. package/gel-core/query-builders/delete.cjs +6 -5
  286. package/gel-core/query-builders/delete.cjs.map +1 -1
  287. package/gel-core/query-builders/delete.js +6 -5
  288. package/gel-core/query-builders/delete.js.map +1 -1
  289. package/gel-core/query-builders/insert.cjs +31 -9
  290. package/gel-core/query-builders/insert.cjs.map +1 -1
  291. package/gel-core/query-builders/insert.js +33 -11
  292. package/gel-core/query-builders/insert.js.map +1 -1
  293. package/gel-core/query-builders/query.cjs +12 -1
  294. package/gel-core/query-builders/query.cjs.map +1 -1
  295. package/gel-core/query-builders/query.js +12 -1
  296. package/gel-core/query-builders/query.js.map +1 -1
  297. package/gel-core/query-builders/select.cjs +12 -30
  298. package/gel-core/query-builders/select.cjs.map +1 -1
  299. package/gel-core/query-builders/select.d.cts +0 -9
  300. package/gel-core/query-builders/select.d.ts +0 -9
  301. package/gel-core/query-builders/select.js +12 -30
  302. package/gel-core/query-builders/select.js.map +1 -1
  303. package/gel-core/query-builders/update.cjs +7 -6
  304. package/gel-core/query-builders/update.cjs.map +1 -1
  305. package/gel-core/query-builders/update.js +7 -6
  306. package/gel-core/query-builders/update.js.map +1 -1
  307. package/gel-core/session.cjs +48 -82
  308. package/gel-core/session.cjs.map +1 -1
  309. package/gel-core/session.d.cts +12 -17
  310. package/gel-core/session.d.ts +12 -17
  311. package/gel-core/session.js +49 -83
  312. package/gel-core/session.js.map +1 -1
  313. package/gel-core/utils.cjs +0 -16
  314. package/gel-core/utils.cjs.map +1 -1
  315. package/gel-core/utils.d.cts +4 -8
  316. package/gel-core/utils.d.ts +4 -8
  317. package/gel-core/utils.js +0 -15
  318. package/gel-core/utils.js.map +1 -1
  319. package/libsql/driver-core.cjs +3 -6
  320. package/libsql/driver-core.cjs.map +1 -1
  321. package/libsql/driver-core.js +3 -6
  322. package/libsql/driver-core.js.map +1 -1
  323. package/libsql/driver.cjs +4 -1
  324. package/libsql/driver.cjs.map +1 -1
  325. package/libsql/driver.d.cts +4 -3
  326. package/libsql/driver.d.ts +4 -3
  327. package/libsql/driver.js +4 -1
  328. package/libsql/driver.js.map +1 -1
  329. package/libsql/http/index.cjs +4 -1
  330. package/libsql/http/index.cjs.map +1 -1
  331. package/libsql/http/index.d.cts +4 -3
  332. package/libsql/http/index.d.ts +4 -3
  333. package/libsql/http/index.js +4 -1
  334. package/libsql/http/index.js.map +1 -1
  335. package/libsql/node/index.cjs +4 -1
  336. package/libsql/node/index.cjs.map +1 -1
  337. package/libsql/node/index.d.cts +4 -3
  338. package/libsql/node/index.d.ts +4 -3
  339. package/libsql/node/index.js +4 -1
  340. package/libsql/node/index.js.map +1 -1
  341. package/libsql/session.cjs +37 -34
  342. package/libsql/session.cjs.map +1 -1
  343. package/libsql/session.d.cts +9 -18
  344. package/libsql/session.d.ts +9 -18
  345. package/libsql/session.js +37 -34
  346. package/libsql/session.js.map +1 -1
  347. package/libsql/sqlite3/index.cjs +4 -1
  348. package/libsql/sqlite3/index.cjs.map +1 -1
  349. package/libsql/sqlite3/index.d.cts +4 -3
  350. package/libsql/sqlite3/index.d.ts +4 -3
  351. package/libsql/sqlite3/index.js +4 -1
  352. package/libsql/sqlite3/index.js.map +1 -1
  353. package/libsql/wasm/index.cjs +4 -1
  354. package/libsql/wasm/index.cjs.map +1 -1
  355. package/libsql/wasm/index.d.cts +4 -3
  356. package/libsql/wasm/index.d.ts +4 -3
  357. package/libsql/wasm/index.js +4 -1
  358. package/libsql/wasm/index.js.map +1 -1
  359. package/libsql/web/index.cjs +4 -1
  360. package/libsql/web/index.cjs.map +1 -1
  361. package/libsql/web/index.d.cts +4 -3
  362. package/libsql/web/index.d.ts +4 -3
  363. package/libsql/web/index.js +4 -1
  364. package/libsql/web/index.js.map +1 -1
  365. package/libsql/ws/index.cjs +4 -1
  366. package/libsql/ws/index.cjs.map +1 -1
  367. package/libsql/ws/index.d.cts +4 -3
  368. package/libsql/ws/index.d.ts +4 -3
  369. package/libsql/ws/index.js +4 -1
  370. package/libsql/ws/index.js.map +1 -1
  371. package/mysql-core/db.cjs +5 -6
  372. package/mysql-core/db.cjs.map +1 -1
  373. package/mysql-core/db.d.cts +3 -5
  374. package/mysql-core/db.d.ts +3 -5
  375. package/mysql-core/db.js +5 -6
  376. package/mysql-core/db.js.map +1 -1
  377. package/mysql-core/dialect.cjs +30 -23
  378. package/mysql-core/dialect.cjs.map +1 -1
  379. package/mysql-core/dialect.d.cts +8 -7
  380. package/mysql-core/dialect.d.ts +8 -7
  381. package/mysql-core/dialect.js +31 -24
  382. package/mysql-core/dialect.js.map +1 -1
  383. package/mysql-core/query-builders/delete.cjs +5 -7
  384. package/mysql-core/query-builders/delete.cjs.map +1 -1
  385. package/mysql-core/query-builders/delete.js +5 -7
  386. package/mysql-core/query-builders/delete.js.map +1 -1
  387. package/mysql-core/query-builders/insert.cjs +30 -13
  388. package/mysql-core/query-builders/insert.cjs.map +1 -1
  389. package/mysql-core/query-builders/insert.d.cts +0 -2
  390. package/mysql-core/query-builders/insert.d.ts +0 -2
  391. package/mysql-core/query-builders/insert.js +32 -15
  392. package/mysql-core/query-builders/insert.js.map +1 -1
  393. package/mysql-core/query-builders/query.cjs +14 -2
  394. package/mysql-core/query-builders/query.cjs.map +1 -1
  395. package/mysql-core/query-builders/query.js +14 -2
  396. package/mysql-core/query-builders/query.js.map +1 -1
  397. package/mysql-core/query-builders/select.cjs +14 -30
  398. package/mysql-core/query-builders/select.cjs.map +1 -1
  399. package/mysql-core/query-builders/select.d.cts +0 -9
  400. package/mysql-core/query-builders/select.d.ts +0 -9
  401. package/mysql-core/query-builders/select.js +15 -31
  402. package/mysql-core/query-builders/select.js.map +1 -1
  403. package/mysql-core/query-builders/update.cjs +13 -11
  404. package/mysql-core/query-builders/update.cjs.map +1 -1
  405. package/mysql-core/query-builders/update.d.cts +0 -2
  406. package/mysql-core/query-builders/update.d.ts +0 -2
  407. package/mysql-core/query-builders/update.js +13 -11
  408. package/mysql-core/query-builders/update.js.map +1 -1
  409. package/mysql-core/session.cjs +42 -80
  410. package/mysql-core/session.cjs.map +1 -1
  411. package/mysql-core/session.d.cts +14 -18
  412. package/mysql-core/session.d.ts +14 -18
  413. package/mysql-core/session.js +43 -81
  414. package/mysql-core/session.js.map +1 -1
  415. package/mysql-core/utils.cjs +0 -16
  416. package/mysql-core/utils.cjs.map +1 -1
  417. package/mysql-core/utils.d.cts +2 -6
  418. package/mysql-core/utils.d.ts +2 -6
  419. package/mysql-core/utils.js +0 -15
  420. package/mysql-core/utils.js.map +1 -1
  421. package/mysql-proxy/driver.cjs +3 -2
  422. package/mysql-proxy/driver.cjs.map +1 -1
  423. package/mysql-proxy/driver.d.cts +2 -1
  424. package/mysql-proxy/driver.d.ts +2 -1
  425. package/mysql-proxy/driver.js +3 -2
  426. package/mysql-proxy/driver.js.map +1 -1
  427. package/mysql-proxy/session.cjs +10 -20
  428. package/mysql-proxy/session.cjs.map +1 -1
  429. package/mysql-proxy/session.d.cts +5 -16
  430. package/mysql-proxy/session.d.ts +5 -16
  431. package/mysql-proxy/session.js +10 -20
  432. package/mysql-proxy/session.js.map +1 -1
  433. package/mysql2/driver.cjs +6 -12
  434. package/mysql2/driver.cjs.map +1 -1
  435. package/mysql2/driver.d.cts +4 -4
  436. package/mysql2/driver.d.ts +4 -4
  437. package/mysql2/driver.js +6 -12
  438. package/mysql2/driver.js.map +1 -1
  439. package/mysql2/session.cjs +16 -22
  440. package/mysql2/session.cjs.map +1 -1
  441. package/mysql2/session.d.cts +5 -15
  442. package/mysql2/session.d.ts +5 -15
  443. package/mysql2/session.js +16 -22
  444. package/mysql2/session.js.map +1 -1
  445. package/neon-http/driver.cjs +5 -10
  446. package/neon-http/driver.cjs.map +1 -1
  447. package/neon-http/driver.d.cts +6 -6
  448. package/neon-http/driver.d.ts +6 -6
  449. package/neon-http/driver.js +5 -10
  450. package/neon-http/driver.js.map +1 -1
  451. package/neon-http/session.cjs +20 -28
  452. package/neon-http/session.cjs.map +1 -1
  453. package/neon-http/session.d.cts +5 -14
  454. package/neon-http/session.d.ts +5 -14
  455. package/neon-http/session.js +20 -28
  456. package/neon-http/session.js.map +1 -1
  457. package/neon-serverless/driver.cjs +6 -11
  458. package/neon-serverless/driver.cjs.map +1 -1
  459. package/neon-serverless/driver.d.cts +6 -6
  460. package/neon-serverless/driver.d.ts +6 -6
  461. package/neon-serverless/driver.js +6 -11
  462. package/neon-serverless/driver.js.map +1 -1
  463. package/neon-serverless/session.cjs +27 -27
  464. package/neon-serverless/session.cjs.map +1 -1
  465. package/neon-serverless/session.d.cts +5 -14
  466. package/neon-serverless/session.d.ts +5 -14
  467. package/neon-serverless/session.js +27 -27
  468. package/neon-serverless/session.js.map +1 -1
  469. package/node-postgres/driver.cjs +6 -11
  470. package/node-postgres/driver.cjs.map +1 -1
  471. package/node-postgres/driver.d.cts +6 -6
  472. package/node-postgres/driver.d.ts +6 -6
  473. package/node-postgres/driver.js +6 -11
  474. package/node-postgres/driver.js.map +1 -1
  475. package/node-postgres/session.cjs +21 -25
  476. package/node-postgres/session.cjs.map +1 -1
  477. package/node-postgres/session.d.cts +5 -15
  478. package/node-postgres/session.d.ts +5 -15
  479. package/node-postgres/session.js +21 -25
  480. package/node-postgres/session.js.map +1 -1
  481. package/op-sqlite/driver.cjs +1 -5
  482. package/op-sqlite/driver.cjs.map +1 -1
  483. package/op-sqlite/driver.d.cts +2 -1
  484. package/op-sqlite/driver.d.ts +2 -1
  485. package/op-sqlite/driver.js +1 -5
  486. package/op-sqlite/driver.js.map +1 -1
  487. package/op-sqlite/session.cjs +11 -25
  488. package/op-sqlite/session.cjs.map +1 -1
  489. package/op-sqlite/session.d.cts +6 -16
  490. package/op-sqlite/session.d.ts +6 -16
  491. package/op-sqlite/session.js +11 -25
  492. package/op-sqlite/session.js.map +1 -1
  493. package/package.json +331 -50
  494. package/pg-core/columns/common.cjs +2 -0
  495. package/pg-core/columns/common.cjs.map +1 -1
  496. package/pg-core/columns/common.js +2 -0
  497. package/pg-core/columns/common.js.map +1 -1
  498. package/pg-core/db.cjs +5 -6
  499. package/pg-core/db.cjs.map +1 -1
  500. package/pg-core/db.d.cts +3 -5
  501. package/pg-core/db.d.ts +3 -5
  502. package/pg-core/db.js +5 -6
  503. package/pg-core/db.js.map +1 -1
  504. package/pg-core/dialect.cjs +26 -19
  505. package/pg-core/dialect.cjs.map +1 -1
  506. package/pg-core/dialect.d.cts +7 -6
  507. package/pg-core/dialect.d.ts +7 -6
  508. package/pg-core/dialect.js +27 -20
  509. package/pg-core/dialect.js.map +1 -1
  510. package/pg-core/query-builders/delete.cjs +7 -7
  511. package/pg-core/query-builders/delete.cjs.map +1 -1
  512. package/pg-core/query-builders/delete.d.cts +0 -2
  513. package/pg-core/query-builders/delete.d.ts +0 -2
  514. package/pg-core/query-builders/delete.js +7 -7
  515. package/pg-core/query-builders/delete.js.map +1 -1
  516. package/pg-core/query-builders/insert.cjs +37 -11
  517. package/pg-core/query-builders/insert.cjs.map +1 -1
  518. package/pg-core/query-builders/insert.d.cts +0 -2
  519. package/pg-core/query-builders/insert.d.ts +0 -2
  520. package/pg-core/query-builders/insert.js +39 -13
  521. package/pg-core/query-builders/insert.js.map +1 -1
  522. package/pg-core/query-builders/query.cjs +12 -1
  523. package/pg-core/query-builders/query.cjs.map +1 -1
  524. package/pg-core/query-builders/query.js +12 -1
  525. package/pg-core/query-builders/query.js.map +1 -1
  526. package/pg-core/query-builders/select.cjs +14 -33
  527. package/pg-core/query-builders/select.cjs.map +1 -1
  528. package/pg-core/query-builders/select.d.cts +6 -15
  529. package/pg-core/query-builders/select.d.ts +6 -15
  530. package/pg-core/query-builders/select.js +14 -33
  531. package/pg-core/query-builders/select.js.map +1 -1
  532. package/pg-core/query-builders/update.cjs +8 -8
  533. package/pg-core/query-builders/update.cjs.map +1 -1
  534. package/pg-core/query-builders/update.d.cts +1 -3
  535. package/pg-core/query-builders/update.d.ts +1 -3
  536. package/pg-core/query-builders/update.js +9 -13
  537. package/pg-core/query-builders/update.js.map +1 -1
  538. package/pg-core/session.cjs +45 -78
  539. package/pg-core/session.cjs.map +1 -1
  540. package/pg-core/session.d.cts +12 -17
  541. package/pg-core/session.d.ts +12 -17
  542. package/pg-core/session.js +46 -79
  543. package/pg-core/session.js.map +1 -1
  544. package/pg-core/utils.cjs +0 -16
  545. package/pg-core/utils.cjs.map +1 -1
  546. package/pg-core/utils.d.cts +4 -8
  547. package/pg-core/utils.d.ts +4 -8
  548. package/pg-core/utils.js +1 -16
  549. package/pg-core/utils.js.map +1 -1
  550. package/pg-proxy/driver.cjs +3 -7
  551. package/pg-proxy/driver.cjs.map +1 -1
  552. package/pg-proxy/driver.d.cts +2 -1
  553. package/pg-proxy/driver.d.ts +2 -1
  554. package/pg-proxy/driver.js +3 -7
  555. package/pg-proxy/driver.js.map +1 -1
  556. package/pg-proxy/session.cjs +10 -18
  557. package/pg-proxy/session.cjs.map +1 -1
  558. package/pg-proxy/session.d.cts +5 -14
  559. package/pg-proxy/session.d.ts +5 -14
  560. package/pg-proxy/session.js +10 -18
  561. package/pg-proxy/session.js.map +1 -1
  562. package/pglite/driver.cjs +6 -11
  563. package/pglite/driver.cjs.map +1 -1
  564. package/pglite/driver.d.cts +6 -6
  565. package/pglite/driver.d.ts +6 -6
  566. package/pglite/driver.js +6 -11
  567. package/pglite/driver.js.map +1 -1
  568. package/pglite/session.cjs +23 -25
  569. package/pglite/session.cjs.map +1 -1
  570. package/pglite/session.d.cts +5 -14
  571. package/pglite/session.d.ts +5 -14
  572. package/pglite/session.js +23 -25
  573. package/pglite/session.js.map +1 -1
  574. package/planetscale-serverless/driver.cjs +3 -6
  575. package/planetscale-serverless/driver.cjs.map +1 -1
  576. package/planetscale-serverless/driver.d.cts +4 -4
  577. package/planetscale-serverless/driver.d.ts +4 -4
  578. package/planetscale-serverless/driver.js +3 -6
  579. package/planetscale-serverless/driver.js.map +1 -1
  580. package/planetscale-serverless/session.cjs +25 -25
  581. package/planetscale-serverless/session.cjs.map +1 -1
  582. package/planetscale-serverless/session.d.cts +6 -17
  583. package/planetscale-serverless/session.d.ts +6 -17
  584. package/planetscale-serverless/session.js +25 -25
  585. package/planetscale-serverless/session.js.map +1 -1
  586. package/postgres-js/driver.cjs +3 -6
  587. package/postgres-js/driver.cjs.map +1 -1
  588. package/postgres-js/driver.d.cts +4 -3
  589. package/postgres-js/driver.d.ts +4 -3
  590. package/postgres-js/driver.js +3 -6
  591. package/postgres-js/driver.js.map +1 -1
  592. package/postgres-js/session.cjs +30 -31
  593. package/postgres-js/session.cjs.map +1 -1
  594. package/postgres-js/session.d.cts +6 -15
  595. package/postgres-js/session.d.ts +6 -15
  596. package/postgres-js/session.js +30 -31
  597. package/postgres-js/session.js.map +1 -1
  598. package/prisma/mysql/driver.cjs +3 -3
  599. package/prisma/mysql/driver.cjs.map +1 -1
  600. package/prisma/mysql/driver.d.cts +3 -2
  601. package/prisma/mysql/driver.d.ts +3 -2
  602. package/prisma/mysql/driver.js +3 -3
  603. package/prisma/mysql/driver.js.map +1 -1
  604. package/prisma/mysql/session.cjs +10 -11
  605. package/prisma/mysql/session.cjs.map +1 -1
  606. package/prisma/mysql/session.d.cts +7 -6
  607. package/prisma/mysql/session.d.ts +7 -6
  608. package/prisma/mysql/session.js +10 -11
  609. package/prisma/mysql/session.js.map +1 -1
  610. package/prisma/pg/driver.cjs +3 -3
  611. package/prisma/pg/driver.cjs.map +1 -1
  612. package/prisma/pg/driver.d.cts +2 -1
  613. package/prisma/pg/driver.d.ts +2 -1
  614. package/prisma/pg/driver.js +3 -3
  615. package/prisma/pg/driver.js.map +1 -1
  616. package/prisma/pg/session.cjs +7 -7
  617. package/prisma/pg/session.cjs.map +1 -1
  618. package/prisma/pg/session.d.cts +6 -5
  619. package/prisma/pg/session.d.ts +6 -5
  620. package/prisma/pg/session.js +7 -7
  621. package/prisma/pg/session.js.map +1 -1
  622. package/prisma/sqlite/driver.cjs +7 -1
  623. package/prisma/sqlite/driver.cjs.map +1 -1
  624. package/prisma/sqlite/driver.d.cts +2 -1
  625. package/prisma/sqlite/driver.d.ts +2 -1
  626. package/prisma/sqlite/driver.js +7 -1
  627. package/prisma/sqlite/driver.js.map +1 -1
  628. package/prisma/sqlite/session.cjs +6 -6
  629. package/prisma/sqlite/session.cjs.map +1 -1
  630. package/prisma/sqlite/session.d.cts +6 -5
  631. package/prisma/sqlite/session.d.ts +6 -5
  632. package/prisma/sqlite/session.js +6 -6
  633. package/prisma/sqlite/session.js.map +1 -1
  634. package/query-builders/query-builder.cjs.map +1 -1
  635. package/query-builders/query-builder.d.cts +1 -2
  636. package/query-builders/query-builder.d.ts +1 -2
  637. package/query-builders/query-builder.js.map +1 -1
  638. package/singlestore/driver.cjs +28 -29
  639. package/singlestore/driver.cjs.map +1 -1
  640. package/singlestore/driver.d.cts +4 -4
  641. package/singlestore/driver.d.ts +4 -4
  642. package/singlestore/driver.js +28 -29
  643. package/singlestore/driver.js.map +1 -1
  644. package/singlestore/session.cjs +16 -22
  645. package/singlestore/session.cjs.map +1 -1
  646. package/singlestore/session.d.cts +5 -15
  647. package/singlestore/session.d.ts +5 -15
  648. package/singlestore/session.js +16 -22
  649. package/singlestore/session.js.map +1 -1
  650. package/singlestore-core/db.cjs +5 -6
  651. package/singlestore-core/db.cjs.map +1 -1
  652. package/singlestore-core/db.d.cts +3 -5
  653. package/singlestore-core/db.d.ts +3 -5
  654. package/singlestore-core/db.js +5 -6
  655. package/singlestore-core/db.js.map +1 -1
  656. package/singlestore-core/dialect.cjs +25 -18
  657. package/singlestore-core/dialect.cjs.map +1 -1
  658. package/singlestore-core/dialect.d.cts +7 -6
  659. package/singlestore-core/dialect.d.ts +7 -6
  660. package/singlestore-core/dialect.js +26 -19
  661. package/singlestore-core/dialect.js.map +1 -1
  662. package/singlestore-core/query-builders/delete.cjs +5 -7
  663. package/singlestore-core/query-builders/delete.cjs.map +1 -1
  664. package/singlestore-core/query-builders/delete.js +5 -7
  665. package/singlestore-core/query-builders/delete.js.map +1 -1
  666. package/singlestore-core/query-builders/insert.cjs +30 -11
  667. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  668. package/singlestore-core/query-builders/insert.js +32 -13
  669. package/singlestore-core/query-builders/insert.js.map +1 -1
  670. package/singlestore-core/query-builders/query.cjs +12 -1
  671. package/singlestore-core/query-builders/query.cjs.map +1 -1
  672. package/singlestore-core/query-builders/query.js +12 -1
  673. package/singlestore-core/query-builders/query.js.map +1 -1
  674. package/singlestore-core/query-builders/select.cjs +14 -31
  675. package/singlestore-core/query-builders/select.cjs.map +1 -1
  676. package/singlestore-core/query-builders/select.d.cts +0 -9
  677. package/singlestore-core/query-builders/select.d.ts +0 -9
  678. package/singlestore-core/query-builders/select.js +14 -31
  679. package/singlestore-core/query-builders/select.js.map +1 -1
  680. package/singlestore-core/query-builders/update.cjs +6 -8
  681. package/singlestore-core/query-builders/update.cjs.map +1 -1
  682. package/singlestore-core/query-builders/update.js +6 -8
  683. package/singlestore-core/query-builders/update.js.map +1 -1
  684. package/singlestore-core/session.cjs +42 -80
  685. package/singlestore-core/session.cjs.map +1 -1
  686. package/singlestore-core/session.d.cts +14 -17
  687. package/singlestore-core/session.d.ts +14 -17
  688. package/singlestore-core/session.js +43 -81
  689. package/singlestore-core/session.js.map +1 -1
  690. package/singlestore-core/utils.cjs +0 -16
  691. package/singlestore-core/utils.cjs.map +1 -1
  692. package/singlestore-core/utils.d.cts +0 -3
  693. package/singlestore-core/utils.d.ts +0 -3
  694. package/singlestore-core/utils.js +0 -15
  695. package/singlestore-core/utils.js.map +1 -1
  696. package/singlestore-proxy/driver.cjs +3 -2
  697. package/singlestore-proxy/driver.cjs.map +1 -1
  698. package/singlestore-proxy/driver.d.cts +2 -1
  699. package/singlestore-proxy/driver.d.ts +2 -1
  700. package/singlestore-proxy/driver.js +3 -2
  701. package/singlestore-proxy/driver.js.map +1 -1
  702. package/singlestore-proxy/session.cjs +8 -8
  703. package/singlestore-proxy/session.cjs.map +1 -1
  704. package/singlestore-proxy/session.d.cts +5 -6
  705. package/singlestore-proxy/session.d.ts +5 -6
  706. package/singlestore-proxy/session.js +8 -8
  707. package/singlestore-proxy/session.js.map +1 -1
  708. package/sql/sql.cjs +24 -12
  709. package/sql/sql.cjs.map +1 -1
  710. package/sql/sql.d.cts +12 -0
  711. package/sql/sql.d.ts +12 -0
  712. package/sql/sql.js +23 -12
  713. package/sql/sql.js.map +1 -1
  714. package/sql-js/driver.cjs.map +1 -1
  715. package/sql-js/driver.d.cts +2 -1
  716. package/sql-js/driver.d.ts +2 -1
  717. package/sql-js/driver.js.map +1 -1
  718. package/sql-js/session.cjs +4 -4
  719. package/sql-js/session.cjs.map +1 -1
  720. package/sql-js/session.d.cts +4 -4
  721. package/sql-js/session.d.ts +4 -4
  722. package/sql-js/session.js +4 -4
  723. package/sql-js/session.js.map +1 -1
  724. package/sqlite-core/db.cjs +5 -6
  725. package/sqlite-core/db.cjs.map +1 -1
  726. package/sqlite-core/db.d.cts +3 -5
  727. package/sqlite-core/db.d.ts +3 -5
  728. package/sqlite-core/db.js +5 -6
  729. package/sqlite-core/db.js.map +1 -1
  730. package/sqlite-core/dialect.cjs +30 -19
  731. package/sqlite-core/dialect.cjs.map +1 -1
  732. package/sqlite-core/dialect.d.cts +7 -6
  733. package/sqlite-core/dialect.d.ts +7 -6
  734. package/sqlite-core/dialect.js +31 -20
  735. package/sqlite-core/dialect.js.map +1 -1
  736. package/sqlite-core/query-builders/delete.cjs +5 -5
  737. package/sqlite-core/query-builders/delete.cjs.map +1 -1
  738. package/sqlite-core/query-builders/delete.js +5 -5
  739. package/sqlite-core/query-builders/delete.js.map +1 -1
  740. package/sqlite-core/query-builders/insert.cjs +25 -8
  741. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  742. package/sqlite-core/query-builders/insert.js +32 -10
  743. package/sqlite-core/query-builders/insert.js.map +1 -1
  744. package/sqlite-core/query-builders/query.cjs +12 -1
  745. package/sqlite-core/query-builders/query.cjs.map +1 -1
  746. package/sqlite-core/query-builders/query.js +12 -1
  747. package/sqlite-core/query-builders/query.js.map +1 -1
  748. package/sqlite-core/query-builders/select.cjs +15 -34
  749. package/sqlite-core/query-builders/select.cjs.map +1 -1
  750. package/sqlite-core/query-builders/select.d.cts +0 -9
  751. package/sqlite-core/query-builders/select.d.ts +0 -9
  752. package/sqlite-core/query-builders/select.js +15 -34
  753. package/sqlite-core/query-builders/select.js.map +1 -1
  754. package/sqlite-core/query-builders/update.cjs +6 -6
  755. package/sqlite-core/query-builders/update.cjs.map +1 -1
  756. package/sqlite-core/query-builders/update.js +6 -6
  757. package/sqlite-core/query-builders/update.js.map +1 -1
  758. package/sqlite-core/session.cjs +78 -90
  759. package/sqlite-core/session.cjs.map +1 -1
  760. package/sqlite-core/session.d.cts +20 -24
  761. package/sqlite-core/session.d.ts +20 -24
  762. package/sqlite-core/session.js +79 -91
  763. package/sqlite-core/session.js.map +1 -1
  764. package/sqlite-core/utils.cjs +0 -16
  765. package/sqlite-core/utils.cjs.map +1 -1
  766. package/sqlite-core/utils.d.cts +2 -6
  767. package/sqlite-core/utils.d.ts +2 -6
  768. package/sqlite-core/utils.js +0 -15
  769. package/sqlite-core/utils.js.map +1 -1
  770. package/sqlite-proxy/driver.cjs +4 -10
  771. package/sqlite-proxy/driver.cjs.map +1 -1
  772. package/sqlite-proxy/driver.d.cts +3 -2
  773. package/sqlite-proxy/driver.d.ts +3 -2
  774. package/sqlite-proxy/driver.js +4 -10
  775. package/sqlite-proxy/driver.js.map +1 -1
  776. package/sqlite-proxy/session.cjs +24 -29
  777. package/sqlite-proxy/session.cjs.map +1 -1
  778. package/sqlite-proxy/session.d.cts +8 -17
  779. package/sqlite-proxy/session.d.ts +8 -17
  780. package/sqlite-proxy/session.js +24 -29
  781. package/sqlite-proxy/session.js.map +1 -1
  782. package/subquery.cjs +3 -4
  783. package/subquery.cjs.map +1 -1
  784. package/subquery.d.cts +1 -2
  785. package/subquery.d.ts +1 -2
  786. package/subquery.js +3 -4
  787. package/subquery.js.map +1 -1
  788. package/tidb-serverless/driver.cjs +9 -6
  789. package/tidb-serverless/driver.cjs.map +1 -1
  790. package/tidb-serverless/driver.d.cts +4 -4
  791. package/tidb-serverless/driver.d.ts +4 -4
  792. package/tidb-serverless/driver.js +9 -6
  793. package/tidb-serverless/driver.js.map +1 -1
  794. package/tidb-serverless/session.cjs +25 -25
  795. package/tidb-serverless/session.cjs.map +1 -1
  796. package/tidb-serverless/session.d.cts +6 -17
  797. package/tidb-serverless/session.d.ts +6 -17
  798. package/tidb-serverless/session.js +25 -25
  799. package/tidb-serverless/session.js.map +1 -1
  800. package/tracing.cjs.map +1 -1
  801. package/tracing.js.map +1 -1
  802. package/utils.cjs +34 -24
  803. package/utils.cjs.map +1 -1
  804. package/utils.d.cts +5 -4
  805. package/utils.d.ts +5 -4
  806. package/utils.js +35 -15
  807. package/utils.js.map +1 -1
  808. package/vercel-postgres/driver.cjs +10 -12
  809. package/vercel-postgres/driver.cjs.map +1 -1
  810. package/vercel-postgres/driver.d.cts +6 -6
  811. package/vercel-postgres/driver.d.ts +6 -6
  812. package/vercel-postgres/driver.js +10 -12
  813. package/vercel-postgres/driver.js.map +1 -1
  814. package/vercel-postgres/session.cjs +22 -27
  815. package/vercel-postgres/session.cjs.map +1 -1
  816. package/vercel-postgres/session.d.cts +5 -14
  817. package/vercel-postgres/session.d.ts +5 -14
  818. package/vercel-postgres/session.js +22 -27
  819. package/vercel-postgres/session.js.map +1 -1
  820. package/version.cjs +1 -1
  821. package/version.d.cts +1 -1
  822. package/version.d.ts +1 -1
  823. package/version.js +1 -1
  824. package/xata-http/driver.cjs +8 -10
  825. package/xata-http/driver.cjs.map +1 -1
  826. package/xata-http/driver.d.cts +4 -4
  827. package/xata-http/driver.d.ts +4 -4
  828. package/xata-http/driver.js +8 -10
  829. package/xata-http/driver.js.map +1 -1
  830. package/xata-http/session.cjs +12 -24
  831. package/xata-http/session.cjs.map +1 -1
  832. package/xata-http/session.d.cts +5 -14
  833. package/xata-http/session.d.ts +5 -14
  834. package/xata-http/session.js +12 -24
  835. package/xata-http/session.js.map +1 -1
  836. package/cache/core/cache.cjs.map +0 -1
  837. package/cache/core/cache.d.cts +0 -35
  838. package/cache/core/cache.d.ts +0 -35
  839. package/cache/core/cache.js +0 -22
  840. package/cache/core/cache.js.map +0 -1
  841. package/cache/core/index.cjs.map +0 -1
  842. package/cache/core/index.d.cts +0 -1
  843. package/cache/core/index.d.ts +0 -1
  844. package/cache/core/index.js +0 -2
  845. package/cache/core/index.js.map +0 -1
  846. package/cache/core/types.cjs.map +0 -1
  847. package/cache/core/types.d.cts +0 -33
  848. package/cache/core/types.d.ts +0 -33
  849. package/cache/core/types.js +0 -1
  850. package/cache/core/types.js.map +0 -1
  851. package/cache/upstash/cache.cjs +0 -191
  852. package/cache/upstash/cache.cjs.map +0 -1
  853. package/cache/upstash/cache.d.cts +0 -59
  854. package/cache/upstash/cache.d.ts +0 -59
  855. package/cache/upstash/cache.js +0 -166
  856. package/cache/upstash/cache.js.map +0 -1
  857. package/cache/upstash/index.cjs.map +0 -1
  858. package/cache/upstash/index.d.cts +0 -1
  859. package/cache/upstash/index.d.ts +0 -1
  860. package/cache/upstash/index.js +0 -2
  861. package/cache/upstash/index.js.map +0 -1
  862. package/errors/index.cjs.map +0 -1
  863. package/errors/index.d.cts +0 -6
  864. package/errors/index.d.ts +0 -6
  865. package/errors/index.js +0 -16
  866. package/errors/index.js.map +0 -1
@@ -0,0 +1,97 @@
1
+ import { entityKind } from "../../../entity.js";
2
+ import { extensionColumnConfig, requiredExtension } from "../../../extension-core/index.js";
3
+ import { SingleStoreColumn, SingleStoreColumnBuilder } from "../../../singlestore-core/index.js";
4
+ import { getColumnNameAndConfig } from "../../../utils.js";
5
+ import {
6
+ objectIdToText
7
+ } from "../common.js";
8
+ import { DrizzleSingleStoreS3Extension } from "./extension.js";
9
+ class SingleStoreS3FileBuilder extends SingleStoreColumnBuilder {
10
+ static [entityKind] = "SingleStoreS3FileBuilder";
11
+ [extensionColumnConfig];
12
+ constructor(name, config) {
13
+ super(name, "custom", "SingleStoreS3File");
14
+ this[extensionColumnConfig] = {
15
+ fileMode: config.mode,
16
+ fetchMode: "file"
17
+ };
18
+ }
19
+ /**
20
+ * Allows to set default to an existing file
21
+ *
22
+ * @example
23
+ * ```
24
+ * fileColumn: s3File().default(sql`${bucket}:${key}`)
25
+ * ```
26
+ *
27
+ * @returns
28
+ */
29
+ default(value) {
30
+ return super.default(value);
31
+ }
32
+ generatedAlwaysAs(as) {
33
+ return super.generatedAlwaysAs(as);
34
+ }
35
+ /** @internal */
36
+ build(table) {
37
+ return new SingleStoreS3File(
38
+ table,
39
+ this.config,
40
+ this[extensionColumnConfig]
41
+ );
42
+ }
43
+ }
44
+ class SingleStoreS3File extends SingleStoreColumn {
45
+ static [entityKind] = "SingleStoreS3File";
46
+ [requiredExtension] = DrizzleSingleStoreS3Extension;
47
+ [extensionColumnConfig];
48
+ constructor(table, config, extensionConfig) {
49
+ super(table, config);
50
+ this[extensionColumnConfig] = extensionConfig ?? {
51
+ fileMode: "buffer",
52
+ fetchMode: "file"
53
+ };
54
+ }
55
+ mapToDriverValue(value) {
56
+ if (typeof value === "string")
57
+ return value;
58
+ return objectIdToText(value);
59
+ }
60
+ data() {
61
+ return new SingleStoreS3File(
62
+ this.table,
63
+ this.config,
64
+ { fileMode: this[extensionColumnConfig].fileMode, fetchMode: "data" }
65
+ );
66
+ }
67
+ // meta(): Omit<SingleStoreS3File<Omit<T, 'data'> & { data: DrizzleS3ObjectMeta }>, 'data' | 'meta' | 'presigned'> {
68
+ // return new SingleStoreS3File(
69
+ // this.table,
70
+ // this.config as ColumnRuntimeConfig<
71
+ // DrizzleS3ObjectMeta,
72
+ // Omit<T, 'data'> & { data: DrizzleS3ObjectMeta }
73
+ // >,
74
+ // { fileMode: this[extensionColumnConfig].fileMode, fetchMode: 'meta' },
75
+ // );
76
+ // }
77
+ presigned(options) {
78
+ return new SingleStoreS3File(
79
+ this.table,
80
+ this.config,
81
+ { fileMode: this[extensionColumnConfig].fileMode, fetchMode: "presigned", options }
82
+ );
83
+ }
84
+ getSQLType() {
85
+ return "text";
86
+ }
87
+ }
88
+ function s3File(a, b) {
89
+ const { name, config } = getColumnNameAndConfig(a, b);
90
+ return new SingleStoreS3FileBuilder(name, config);
91
+ }
92
+ export {
93
+ SingleStoreS3File,
94
+ SingleStoreS3FileBuilder,
95
+ s3File
96
+ };
97
+ //# sourceMappingURL=column.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/extensions/s3-file/singlestore/column.ts"],"sourcesContent":["import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderRuntimeConfig,\n\tHasDefault,\n\tHasGenerated,\n\tMakeColumnConfig,\n} from '~/column-builder.ts';\nimport type { ColumnBaseConfig, ColumnRuntimeConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport { extensionColumnConfig, requiredExtension } from '~/extension-core/index.ts';\nimport { SingleStoreColumn, SingleStoreColumnBuilder } from '~/singlestore-core/index.ts';\nimport type { AnySingleStoreTable, SingleStoreTable } from '~/singlestore-core/table.ts';\nimport type { SQL } from '~/sql/index.ts';\nimport { type Assume, getColumnNameAndConfig } from '~/utils.ts';\nimport {\n\ttype DrizzleS3FetchMode,\n\ttype DrizzleS3FileMode,\n\ttype DrizzleS3FileModeToData,\n\ttype DrizzleS3ObjectFile,\n\ttype DrizzleS3ObjectIdentification,\n\tobjectIdToText,\n\ttype RequestPresigningArguments,\n} from '../common.ts';\nimport { DrizzleSingleStoreS3Extension } from './extension.ts';\n\nexport type SingleStoreS3FileBuilderInitial<TName extends string, TMode extends DrizzleS3FileMode> =\n\tSingleStoreS3FileBuilder<{\n\t\tname: TName;\n\t\tdataType: 'custom';\n\t\tcolumnType: 'SingleStoreS3File';\n\t\tdata: DrizzleS3ObjectFile<DrizzleS3FileModeToData[TMode]>;\n\t\tenumValues: undefined;\n\t\tdriverParam: string;\n\t}>;\n\nexport class SingleStoreS3FileBuilder<\n\tT extends ColumnBuilderBaseConfig<'custom', 'SingleStoreS3File'>,\n\tTRuntimeConfig extends object = {},\n\tTTypeConfig extends object = {},\n> extends SingleStoreColumnBuilder<T, TRuntimeConfig, TTypeConfig> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreS3FileBuilder';\n\treadonly [extensionColumnConfig]: SingleStoreS3FileExtensionColumnConfig;\n\n\tconstructor(\n\t\tname: T['name'],\n\t\tconfig: SingleStoreS3FileConfig,\n\t) {\n\t\tsuper(name, 'custom', 'SingleStoreS3File');\n\t\tthis[extensionColumnConfig] = {\n\t\t\tfileMode: config.mode,\n\t\t\tfetchMode: 'file',\n\t\t};\n\t}\n\n\t/**\n\t * Allows to set default to an existing file\n\t *\n\t * @example\n\t * ```\n\t * fileColumn: s3File().default(sql`${bucket}:${key}`)\n\t * ```\n\t *\n\t * @returns\n\t */\n\toverride default(value: SQL<unknown>): HasDefault<this> {\n\t\treturn super.default(value);\n\t}\n\n\toverride generatedAlwaysAs(as: SQL<unknown> | (() => SQL)): HasGenerated<this, { type: 'always' }> {\n\t\treturn super.generatedAlwaysAs(as);\n\t}\n\n\t/** @internal */\n\toverride build<TTableName extends string>(\n\t\ttable: AnySingleStoreTable<{ name: TTableName }>,\n\t): SingleStoreS3File<MakeColumnConfig<T, TTableName>> {\n\t\treturn new SingleStoreS3File<MakeColumnConfig<T, TTableName>>(\n\t\t\ttable,\n\t\t\tthis.config as ColumnBuilderRuntimeConfig<any, any>,\n\t\t\tthis[extensionColumnConfig],\n\t\t);\n\t}\n}\n\nexport type SingleStoreS3FileExtensionColumnConfig = {\n\tfetchMode: DrizzleS3FetchMode;\n\tfileMode: DrizzleS3FileMode;\n\toptions?: RequestPresigningArguments;\n};\n\nexport class SingleStoreS3File<\n\tT extends ColumnBaseConfig<'custom', 'SingleStoreS3File'> = ColumnBaseConfig<'custom', 'SingleStoreS3File'>,\n> extends SingleStoreColumn<T, { enumValues: T['enumValues'] }> {\n\tstatic override readonly [entityKind]: string = 'SingleStoreS3File';\n\toverride [requiredExtension] = DrizzleSingleStoreS3Extension;\n\t[extensionColumnConfig]: SingleStoreS3FileExtensionColumnConfig;\n\n\tconstructor(\n\t\ttable: SingleStoreTable,\n\t\tconfig: ColumnBuilderRuntimeConfig<T['data'], T>,\n\t\textensionConfig?: SingleStoreS3FileExtensionColumnConfig,\n\t) {\n\t\tsuper(table, config);\n\n\t\tthis[extensionColumnConfig] = extensionConfig ?? {\n\t\t\tfileMode: 'buffer',\n\t\t\tfetchMode: 'file',\n\t\t};\n\t}\n\n\toverride mapToDriverValue(value: unknown): string {\n\t\tif (typeof value === 'string') return value;\n\n\t\treturn objectIdToText(value as DrizzleS3ObjectIdentification);\n\t}\n\n\tdata(): SingleStoreColumn<Omit<T, 'data'> & { data: Assume<T['data'], DrizzleS3ObjectFile>['data'] }> {\n\t\treturn new SingleStoreS3File(\n\t\t\tthis.table,\n\t\t\tthis.config as ColumnRuntimeConfig<\n\t\t\t\tDrizzleS3ObjectFile['data'],\n\t\t\t\tOmit<T, 'data'> & { data: Assume<T['data'], DrizzleS3ObjectFile>['data'] }\n\t\t\t>,\n\t\t\t{ fileMode: this[extensionColumnConfig].fileMode, fetchMode: 'data' },\n\t\t);\n\t}\n\n\t// meta(): Omit<SingleStoreS3File<Omit<T, 'data'> & { data: DrizzleS3ObjectMeta }>, 'data' | 'meta' | 'presigned'> {\n\t// \treturn new SingleStoreS3File(\n\t// \t\tthis.table,\n\t// \t\tthis.config as ColumnRuntimeConfig<\n\t// \t\t\tDrizzleS3ObjectMeta,\n\t// \t\t\tOmit<T, 'data'> & { data: DrizzleS3ObjectMeta }\n\t// \t\t>,\n\t// \t\t{ fileMode: this[extensionColumnConfig].fileMode, fetchMode: 'meta' },\n\t// \t);\n\t// }\n\n\tpresigned(options?: RequestPresigningArguments): SingleStoreColumn<Omit<T, 'data'> & { data: string }> {\n\t\treturn new SingleStoreS3File(\n\t\t\tthis.table,\n\t\t\tthis.config as ColumnRuntimeConfig<\n\t\t\t\tstring,\n\t\t\t\tOmit<T, 'data'> & { data: string }\n\t\t\t>,\n\t\t\t{ fileMode: this[extensionColumnConfig].fileMode, fetchMode: 'presigned', options },\n\t\t);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn 'text';\n\t}\n}\n\nexport interface SingleStoreS3FileConfig<\n\tTMode extends DrizzleS3FileMode = DrizzleS3FileMode,\n> {\n\tmode: TMode;\n}\n\nexport function s3File<TName extends string, TMode extends DrizzleS3FileMode>(\n\tconfig: SingleStoreS3FileConfig<TMode>,\n): SingleStoreS3FileBuilderInitial<TName, TMode>;\nexport function s3File<TName extends string, TMode extends DrizzleS3FileMode>(\n\tname: TName,\n\tconfig: SingleStoreS3FileConfig<TMode>,\n): SingleStoreS3FileBuilderInitial<TName, TMode>;\nexport function s3File(a: string | SingleStoreS3FileConfig, b?: SingleStoreS3FileConfig): any {\n\tconst { name, config } = getColumnNameAndConfig<SingleStoreS3FileConfig>(a, b);\n\treturn new SingleStoreS3FileBuilder(name, config);\n}\n"],"mappings":"AAQA,SAAS,kBAAkB;AAC3B,SAAS,uBAAuB,yBAAyB;AACzD,SAAS,mBAAmB,gCAAgC;AAG5D,SAAsB,8BAA8B;AACpD;AAAA,EAMC;AAAA,OAEM;AACP,SAAS,qCAAqC;AAYvC,MAAM,iCAIH,yBAAyD;AAAA,EAClE,QAA0B,UAAU,IAAY;AAAA,EAChD,CAAU,qBAAqB;AAAA,EAE/B,YACC,MACA,QACC;AACD,UAAM,MAAM,UAAU,mBAAmB;AACzC,SAAK,qBAAqB,IAAI;AAAA,MAC7B,UAAU,OAAO;AAAA,MACjB,WAAW;AAAA,IACZ;AAAA,EACD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYS,QAAQ,OAAuC;AACvD,WAAO,MAAM,QAAQ,KAAK;AAAA,EAC3B;AAAA,EAES,kBAAkB,IAAwE;AAClG,WAAO,MAAM,kBAAkB,EAAE;AAAA,EAClC;AAAA;AAAA,EAGS,MACR,OACqD;AACrD,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,MACL,KAAK,qBAAqB;AAAA,IAC3B;AAAA,EACD;AACD;AAQO,MAAM,0BAEH,kBAAsD;AAAA,EAC/D,QAA0B,UAAU,IAAY;AAAA,EAChD,CAAU,iBAAiB,IAAI;AAAA,EAC/B,CAAC,qBAAqB;AAAA,EAEtB,YACC,OACA,QACA,iBACC;AACD,UAAM,OAAO,MAAM;AAEnB,SAAK,qBAAqB,IAAI,mBAAmB;AAAA,MAChD,UAAU;AAAA,MACV,WAAW;AAAA,IACZ;AAAA,EACD;AAAA,EAES,iBAAiB,OAAwB;AACjD,QAAI,OAAO,UAAU;AAAU,aAAO;AAEtC,WAAO,eAAe,KAAsC;AAAA,EAC7D;AAAA,EAEA,OAAsG;AACrG,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MAIL,EAAE,UAAU,KAAK,qBAAqB,EAAE,UAAU,WAAW,OAAO;AAAA,IACrE;AAAA,EACD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaA,UAAU,SAA6F;AACtG,WAAO,IAAI;AAAA,MACV,KAAK;AAAA,MACL,KAAK;AAAA,MAIL,EAAE,UAAU,KAAK,qBAAqB,EAAE,UAAU,WAAW,aAAa,QAAQ;AAAA,IACnF;AAAA,EACD;AAAA,EAEA,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAeO,SAAS,OAAO,GAAqC,GAAkC;AAC7F,QAAM,EAAE,MAAM,OAAO,IAAI,uBAAgD,GAAG,CAAC;AAC7E,SAAO,IAAI,yBAAyB,MAAM,MAAM;AACjD;","names":[]}
@@ -0,0 +1,247 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var extension_exports = {};
20
+ __export(extension_exports, {
21
+ DrizzleSingleStoreS3Extension: () => DrizzleSingleStoreS3Extension,
22
+ s3FileExt: () => s3FileExt
23
+ });
24
+ module.exports = __toCommonJS(extension_exports);
25
+ var import_client_s3 = require("@aws-sdk/client-s3");
26
+ var import_entity = require("../../../entity.cjs");
27
+ var import_errors = require("../../../errors.cjs");
28
+ var import_extension_core = require("../../../extension-core/index.cjs");
29
+ var import_singlestore = require("../../../extension-core/singlestore/index.cjs");
30
+ var import_relations = require("../../../relations.cjs");
31
+ var import_singlestore_core = require("../../../singlestore-core/index.cjs");
32
+ var import_sql = require("../../../sql/index.cjs");
33
+ var import_utils = require("../../../utils.cjs");
34
+ var import_common = require("../common.cjs");
35
+ class DrizzleSingleStoreS3Extension extends import_singlestore.DrizzleSingleStoreExtension {
36
+ static [import_entity.entityKind] = "DrizzleSingleStoreS3Extension";
37
+ static [import_extension_core.extensionName] = "Drizzle SingleStore S3 Extension";
38
+ s3;
39
+ constructor(client) {
40
+ super();
41
+ this.s3 = typeof client === "object" && (client instanceof import_client_s3.S3Client || client.constructor.name !== "Object") ? client : new import_client_s3.S3Client(client);
42
+ }
43
+ buildOutputMappingInstructions(selection) {
44
+ const paths = [];
45
+ for (const f of selection) {
46
+ if (!(0, import_entity.is)(f.field, import_singlestore_core.SingleStoreColumn) || !f.field[import_extension_core.requiredExtension] || !(0, import_entity.is)(this, f.field[import_extension_core.requiredExtension]))
47
+ continue;
48
+ const column = f.field;
49
+ const { fetchMode, fileMode, options } = column[import_extension_core.extensionColumnConfig];
50
+ paths.push({
51
+ path: f.path.map((p) => `[${JSON.stringify(p)}]`),
52
+ fetchMode,
53
+ fileMode,
54
+ options
55
+ });
56
+ }
57
+ return paths;
58
+ }
59
+ buildRqbOutputMappingInstructions(schema, table, selection, parent, prefix = []) {
60
+ const p = parent ?? {
61
+ path: [],
62
+ subinstructions: []
63
+ };
64
+ for (const s of selection) {
65
+ if ((0, import_entity.is)(s.field, import_singlestore_core.SingleStoreColumn)) {
66
+ if (!s.field[import_extension_core.requiredExtension] || !(0, import_entity.is)(this, s.field[import_extension_core.requiredExtension]))
67
+ continue;
68
+ const extCol = s.field;
69
+ (p.subinstructions ??= []).push({
70
+ path: [...prefix, `[${JSON.stringify(s.tsKey)}]`],
71
+ fileMode: extCol[import_extension_core.extensionColumnConfig].fileMode,
72
+ fetchMode: extCol[import_extension_core.extensionColumnConfig].fetchMode,
73
+ options: extCol[import_extension_core.extensionColumnConfig].options
74
+ });
75
+ continue;
76
+ }
77
+ if (s.selection) {
78
+ const relation = schema[s.relationTableTsKey];
79
+ if ((0, import_entity.is)(table.relations[s.tsKey], import_relations.One)) {
80
+ this.buildRqbOutputMappingInstructions(schema, relation, s.selection, p, [
81
+ ...prefix,
82
+ `[${JSON.stringify(s.tsKey)}]`
83
+ ]);
84
+ continue;
85
+ }
86
+ const nestedSubs = this.buildRqbOutputMappingInstructions(schema, relation, s.selection);
87
+ if (!nestedSubs.length)
88
+ continue;
89
+ (p.subinstructions ??= []).push({
90
+ path: [...prefix, `[${JSON.stringify(s.tsKey)}]`],
91
+ subinstructions: nestedSubs
92
+ });
93
+ }
94
+ }
95
+ return p.subinstructions;
96
+ }
97
+ buildParamMappingInstructions(params) {
98
+ const indexes = [];
99
+ const placeholders = [];
100
+ let i = 0;
101
+ for (const item of params) {
102
+ if (!(0, import_entity.is)(item, import_sql.ExtensionParam) || !(0, import_entity.is)(this, item.extension)) {
103
+ ++i;
104
+ continue;
105
+ }
106
+ if ((0, import_entity.is)(item.value, import_sql.Placeholder)) {
107
+ placeholders.push({
108
+ key: item.value.name,
109
+ mode: item.encoder[import_extension_core.extensionColumnConfig].fileMode
110
+ });
111
+ ++i;
112
+ continue;
113
+ }
114
+ indexes.push({
115
+ index: i++,
116
+ mode: item.encoder[import_extension_core.extensionColumnConfig].fileMode
117
+ });
118
+ }
119
+ return {
120
+ placeholders,
121
+ indexes
122
+ };
123
+ }
124
+ async hookBefore(context) {
125
+ if (!context?.params?.length)
126
+ return;
127
+ let indexes = [];
128
+ let placeholders = [];
129
+ const errors = [];
130
+ switch (context.query) {
131
+ case "select":
132
+ case "delete": {
133
+ break;
134
+ }
135
+ case "update":
136
+ case "insert": {
137
+ const instr = this.buildParamMappingInstructions(context.params);
138
+ indexes = instr.indexes;
139
+ placeholders = instr.placeholders;
140
+ break;
141
+ }
142
+ }
143
+ await (0, import_common.mapParams)(this.s3, context.params, indexes, errors);
144
+ if (errors.length) {
145
+ throw new import_errors.DrizzleError({
146
+ message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file upload.
147
+ Log "(e as DrizzleError).cause" for details.`,
148
+ cause: errors
149
+ });
150
+ }
151
+ if (!context.metadata?.encoder) {
152
+ context.metadata = context.metadata ?? {};
153
+ context.metadata.encoder = (0, import_common.buildEncoder)(placeholders);
154
+ }
155
+ await context.metadata.encoder(this.s3, context.placeholders, errors, import_common.uploadFile, import_common.objectIdToText);
156
+ if (errors.length) {
157
+ throw new import_errors.DrizzleError({
158
+ message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file upload.
159
+ Log "(e as DrizzleError).cause" for details.`,
160
+ cause: errors
161
+ });
162
+ }
163
+ return;
164
+ }
165
+ async hookAfter(context) {
166
+ const errors = [];
167
+ const data = context.data;
168
+ switch (context.query) {
169
+ case "select": {
170
+ if (!data.length)
171
+ return;
172
+ if (!context.metadata?.decoder) {
173
+ const fields = context.fieldsOrdered ?? context.config.fieldsFlat ?? (0, import_utils.orderSelectedFields)(context.config.fields);
174
+ const instructions = this.buildOutputMappingInstructions(fields);
175
+ const decoder = (0, import_common.buildDecoder)(instructions);
176
+ context.metadata = context.metadata ?? {};
177
+ context.metadata.decoder = decoder;
178
+ }
179
+ break;
180
+ }
181
+ case "_query": {
182
+ if (context.mode === "first" && !data || context.mode === "many" && !data.length)
183
+ return;
184
+ if (!context.metadata?.decoder) {
185
+ const instructions = this.buildRqbOutputMappingInstructions(
186
+ context.tablesConfig,
187
+ context.tableConfig,
188
+ context.config.selection
189
+ );
190
+ const decoder = (0, import_common.buildDecoder)(instructions, context.mode);
191
+ context.metadata = context.metadata ?? {};
192
+ context.metadata.decoder = decoder;
193
+ }
194
+ break;
195
+ }
196
+ case "update":
197
+ case "delete":
198
+ case "insert": {
199
+ if (!data.length)
200
+ return;
201
+ if (!context.metadata?.decoder) {
202
+ if (!context.config.returning) {
203
+ const decoder2 = (0, import_common.buildDecoder)([]);
204
+ context.metadata = context.metadata ?? {};
205
+ context.metadata.decoder = decoder2;
206
+ break;
207
+ }
208
+ const fields = context.config.returning;
209
+ const instructions = this.buildOutputMappingInstructions(fields);
210
+ const decoder = (0, import_common.buildDecoder)(instructions);
211
+ context.metadata = context.metadata ?? {};
212
+ context.metadata.decoder = decoder;
213
+ }
214
+ break;
215
+ }
216
+ }
217
+ await context.metadata.decoder(
218
+ this.s3,
219
+ data,
220
+ errors,
221
+ import_common.downloadFile,
222
+ // downloadFileMeta,
223
+ import_common.presignDownload,
224
+ import_common.textToObjectId
225
+ );
226
+ if (errors.length) {
227
+ throw new import_errors.DrizzleError({
228
+ message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file download.
229
+ Log "(e as DrizzleError).cause" for details.`,
230
+ cause: errors
231
+ });
232
+ }
233
+ return;
234
+ }
235
+ async hook(context) {
236
+ return context.stage === "before" ? await this.hookBefore(context) : await this.hookAfter(context);
237
+ }
238
+ }
239
+ function s3FileExt(client) {
240
+ return new DrizzleSingleStoreS3Extension(client);
241
+ }
242
+ // Annotate the CommonJS export names for ESM import in node:
243
+ 0 && (module.exports = {
244
+ DrizzleSingleStoreS3Extension,
245
+ s3FileExt
246
+ });
247
+ //# sourceMappingURL=extension.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/extensions/s3-file/singlestore/extension.ts"],"sourcesContent":["import { S3Client, type S3ClientConfig } from '@aws-sdk/client-s3';\nimport { entityKind, is } from '~/entity.ts';\nimport { DrizzleError } from '~/errors.ts';\nimport { extensionColumnConfig, extensionName, requiredExtension } from '~/extension-core/index.ts';\nimport { DrizzleSingleStoreExtension, type DrizzleSingleStoreHookContext } from '~/extension-core/singlestore/index.ts';\nimport type { SelectedFieldsOrdered } from '~/operations.ts';\nimport {\n\ttype BuildRelationalQueryResult,\n\tOne,\n\ttype TableRelationalConfig,\n\ttype TablesRelationalConfig,\n} from '~/relations.ts';\nimport { SingleStoreColumn } from '~/singlestore-core/index.ts';\nimport { ExtensionParam, Placeholder } from '~/sql/index.ts';\nimport { orderSelectedFields } from '~/utils.ts';\nimport {\n\tbuildDecoder,\n\tbuildEncoder,\n\tdownloadFile,\n\t// downloadFileMeta,\n\tmapParams,\n\tobjectIdToText,\n\tpresignDownload,\n\ttextToObjectId,\n\tuploadFile,\n} from '../common.ts';\nimport type {\n\tDrizzleS3FileInputMappingInstruction,\n\tDrizzleS3FileOutputMappingInstruction,\n\tDrizzleS3FileOutputMappingInstructionIterableNode,\n\tDrizzleS3FilePlaceholderMappingInstruction,\n\tS3ExtMeta,\n} from '../common.ts';\nimport type { SingleStoreS3File } from './column.ts';\n\nexport class DrizzleSingleStoreS3Extension extends DrizzleSingleStoreExtension<S3ExtMeta> {\n\tstatic override readonly [entityKind]: string = 'DrizzleSingleStoreS3Extension';\n\n\tstatic override readonly [extensionName] = 'Drizzle SingleStore S3 Extension';\n\n\tprivate s3: S3Client;\n\n\tconstructor(client: S3Client | S3ClientConfig) {\n\t\tsuper();\n\n\t\t// eslint-disable-next-line no-instanceof/no-instanceof\n\t\tthis.s3 = typeof client === 'object' && (client instanceof S3Client || client.constructor.name !== 'Object')\n\t\t\t? client as S3Client\n\t\t\t: new S3Client(client);\n\t}\n\n\tprivate buildOutputMappingInstructions(selection: SelectedFieldsOrdered<SingleStoreColumn>) {\n\t\tconst paths: DrizzleS3FileOutputMappingInstruction[] = [];\n\n\t\tfor (const f of selection) {\n\t\t\tif (\n\t\t\t\t!is(f.field, SingleStoreColumn) || !(<SingleStoreColumn> f.field)[requiredExtension]\n\t\t\t\t|| !is(this, f.field[requiredExtension]!)\n\t\t\t) continue;\n\n\t\t\tconst column = f.field as SingleStoreS3File;\n\n\t\t\tconst { fetchMode, fileMode, options } = column[extensionColumnConfig];\n\n\t\t\tpaths.push({\n\t\t\t\tpath: f.path.map((p) => `[${JSON.stringify(p)}]`),\n\t\t\t\tfetchMode: fetchMode,\n\t\t\t\tfileMode: fileMode,\n\t\t\t\toptions: options,\n\t\t\t});\n\t\t}\n\n\t\treturn paths;\n\t}\n\n\tprivate buildRqbOutputMappingInstructions(\n\t\tschema: TablesRelationalConfig,\n\t\ttable: TableRelationalConfig,\n\t\tselection: BuildRelationalQueryResult['selection'],\n\t\tparent?: DrizzleS3FileOutputMappingInstructionIterableNode,\n\t\tprefix: string[] = [],\n\t) {\n\t\tconst p: DrizzleS3FileOutputMappingInstructionIterableNode = parent ?? {\n\t\t\tpath: [],\n\t\t\tsubinstructions: [],\n\t\t};\n\n\t\tfor (const s of selection) {\n\t\t\tif (is(s.field, SingleStoreColumn)) {\n\t\t\t\tif (!s.field[requiredExtension] || !is(this, s.field[requiredExtension])) continue;\n\n\t\t\t\tconst extCol = s.field as SingleStoreS3File;\n\n\t\t\t\t(p.subinstructions ??= []).push({\n\t\t\t\t\tpath: [...prefix, `[${JSON.stringify(s.tsKey)}]`],\n\t\t\t\t\tfileMode: extCol[extensionColumnConfig].fileMode,\n\t\t\t\t\tfetchMode: extCol[extensionColumnConfig].fetchMode,\n\t\t\t\t\toptions: extCol[extensionColumnConfig].options,\n\t\t\t\t});\n\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (s.selection) {\n\t\t\t\tconst relation = schema[s.relationTableTsKey!]!;\n\n\t\t\t\tif (is(table.relations[s.tsKey]!, One)) {\n\t\t\t\t\tthis.buildRqbOutputMappingInstructions(schema, relation, s.selection, p, [\n\t\t\t\t\t\t...prefix,\n\t\t\t\t\t\t`[${JSON.stringify(s.tsKey)}]`,\n\t\t\t\t\t]);\n\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst nestedSubs = this.buildRqbOutputMappingInstructions(schema, relation, s.selection);\n\t\t\t\tif (!nestedSubs.length) continue;\n\n\t\t\t\t(p.subinstructions ??= []).push({\n\t\t\t\t\tpath: [...prefix, `[${JSON.stringify(s.tsKey)}]`],\n\t\t\t\t\tsubinstructions: nestedSubs,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\treturn p.subinstructions;\n\t}\n\n\tprivate buildParamMappingInstructions(params: unknown[]) {\n\t\tconst indexes: DrizzleS3FileInputMappingInstruction[] = [];\n\t\tconst placeholders: DrizzleS3FilePlaceholderMappingInstruction[] = [];\n\t\tlet i = 0;\n\t\tfor (const item of params) {\n\t\t\tif (!is(item, ExtensionParam) || !is(this, item.extension)) {\n\t\t\t\t++i;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (is(item.value, Placeholder)) {\n\t\t\t\tplaceholders.push({\n\t\t\t\t\tkey: item.value.name,\n\t\t\t\t\tmode: (item.encoder as SingleStoreS3File)[extensionColumnConfig].fileMode,\n\t\t\t\t});\n\t\t\t\t++i;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tindexes.push({\n\t\t\t\tindex: i++,\n\t\t\t\tmode: (item.encoder as SingleStoreS3File)[extensionColumnConfig].fileMode,\n\t\t\t});\n\t\t}\n\n\t\treturn {\n\t\t\tplaceholders,\n\t\t\tindexes,\n\t\t};\n\t}\n\n\tprivate async hookBefore(context: DrizzleSingleStoreHookContext<S3ExtMeta> & { stage: 'before' }) {\n\t\tif (!context?.params?.length) return;\n\n\t\tlet indexes: DrizzleS3FileInputMappingInstruction[] = [];\n\t\tlet placeholders: DrizzleS3FilePlaceholderMappingInstruction[] = [];\n\t\tconst errors: unknown[] = [];\n\n\t\tswitch (context.query) {\n\t\t\tcase 'select':\n\t\t\tcase 'delete': {\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase 'update':\n\t\t\tcase 'insert': {\n\t\t\t\tconst instr = this.buildParamMappingInstructions(context.params as Record<string, unknown>[]);\n\n\t\t\t\tindexes = instr.indexes;\n\t\t\t\tplaceholders = instr.placeholders;\n\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tawait mapParams(this.s3, context.params, indexes, errors);\n\n\t\tif (errors.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `Error${\n\t\t\t\t\terrors.length > 1 ? 's' : ''\n\t\t\t\t} occured during S3 file upload.\\nLog \"(e as DrizzleError).cause\" for details.`,\n\t\t\t\tcause: errors,\n\t\t\t});\n\t\t}\n\n\t\tif (!context.metadata?.encoder) {\n\t\t\tcontext.metadata = context.metadata ?? {};\n\n\t\t\tcontext.metadata.encoder = buildEncoder(placeholders);\n\t\t}\n\n\t\tawait context.metadata.encoder(this.s3, context.placeholders, errors, uploadFile, objectIdToText);\n\n\t\tif (errors.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `Error${\n\t\t\t\t\terrors.length > 1 ? 's' : ''\n\t\t\t\t} occured during S3 file upload.\\nLog \"(e as DrizzleError).cause\" for details.`,\n\t\t\t\tcause: errors,\n\t\t\t});\n\t\t}\n\n\t\treturn;\n\t}\n\n\tprivate async hookAfter(context: DrizzleSingleStoreHookContext<S3ExtMeta> & { stage: 'after' }) {\n\t\tconst errors: unknown[] = [];\n\t\tconst data = context.data as Record<string, unknown>[];\n\n\t\tswitch (context.query) {\n\t\t\tcase 'select': {\n\t\t\t\tif (!data.length) return;\n\n\t\t\t\tif (!context.metadata?.decoder) {\n\t\t\t\t\tconst fields = context.fieldsOrdered ?? context.config.fieldsFlat\n\t\t\t\t\t\t?? orderSelectedFields<SingleStoreColumn>(context.config.fields);\n\n\t\t\t\t\tconst instructions = this.buildOutputMappingInstructions(fields);\n\n\t\t\t\t\tconst decoder = buildDecoder(instructions);\n\n\t\t\t\t\tcontext.metadata = context.metadata ?? {};\n\t\t\t\t\tcontext.metadata.decoder = decoder;\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase '_query': {\n\t\t\t\tif ((context.mode === 'first' && !data) || (context.mode === 'many' && !data.length)) return;\n\n\t\t\t\tif (!context.metadata?.decoder) {\n\t\t\t\t\tconst instructions = this.buildRqbOutputMappingInstructions(\n\t\t\t\t\t\tcontext.tablesConfig,\n\t\t\t\t\t\tcontext.tableConfig,\n\t\t\t\t\t\tcontext.config.selection,\n\t\t\t\t\t);\n\n\t\t\t\t\tconst decoder = buildDecoder(instructions, context.mode);\n\n\t\t\t\t\tcontext.metadata = context.metadata ?? {};\n\t\t\t\t\tcontext.metadata.decoder = decoder;\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tcase 'update':\n\t\t\tcase 'delete':\n\t\t\tcase 'insert': {\n\t\t\t\tif (!data.length) return;\n\n\t\t\t\tif (!context.metadata?.decoder) {\n\t\t\t\t\tif (!(context.config.returning)) {\n\t\t\t\t\t\tconst decoder = buildDecoder([]);\n\n\t\t\t\t\t\tcontext.metadata = context.metadata ?? {};\n\t\t\t\t\t\tcontext.metadata.decoder = decoder;\n\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst fields = context.config.returning;\n\t\t\t\t\tconst instructions = this.buildOutputMappingInstructions(fields);\n\n\t\t\t\t\tconst decoder = buildDecoder(instructions);\n\n\t\t\t\t\tcontext.metadata = context.metadata ?? {};\n\t\t\t\t\tcontext.metadata.decoder = decoder;\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tawait context.metadata.decoder(\n\t\t\tthis.s3,\n\t\t\tdata,\n\t\t\terrors,\n\t\t\tdownloadFile,\n\t\t\t// downloadFileMeta,\n\t\t\tpresignDownload,\n\t\t\ttextToObjectId,\n\t\t);\n\n\t\tif (errors.length) {\n\t\t\tthrow new DrizzleError({\n\t\t\t\tmessage: `Error${\n\t\t\t\t\terrors.length > 1 ? 's' : ''\n\t\t\t\t} occured during S3 file download.\\nLog \"(e as DrizzleError).cause\" for details.`,\n\t\t\t\tcause: errors,\n\t\t\t});\n\t\t}\n\n\t\treturn;\n\t}\n\n\toverride async hook(context: DrizzleSingleStoreHookContext<S3ExtMeta>) {\n\t\treturn context.stage === 'before' ? await this.hookBefore(context) : await this.hookAfter(context);\n\t}\n}\n\nexport function s3FileExt(client: S3Client | S3ClientConfig): DrizzleSingleStoreS3Extension {\n\treturn new DrizzleSingleStoreS3Extension(client);\n}\n"],"mappings":"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","names":["decoder"]}
@@ -0,0 +1,18 @@
1
+ import { S3Client, type S3ClientConfig } from '@aws-sdk/client-s3';
2
+ import { entityKind } from "../../../entity.cjs";
3
+ import { extensionName } from "../../../extension-core/index.cjs";
4
+ import { DrizzleSingleStoreExtension, type DrizzleSingleStoreHookContext } from "../../../extension-core/singlestore/index.cjs";
5
+ import type { S3ExtMeta } from "../common.cjs";
6
+ export declare class DrizzleSingleStoreS3Extension extends DrizzleSingleStoreExtension<S3ExtMeta> {
7
+ static readonly [entityKind]: string;
8
+ static readonly [extensionName] = "Drizzle SingleStore S3 Extension";
9
+ private s3;
10
+ constructor(client: S3Client | S3ClientConfig);
11
+ private buildOutputMappingInstructions;
12
+ private buildRqbOutputMappingInstructions;
13
+ private buildParamMappingInstructions;
14
+ private hookBefore;
15
+ private hookAfter;
16
+ hook(context: DrizzleSingleStoreHookContext<S3ExtMeta>): Promise<void>;
17
+ }
18
+ export declare function s3FileExt(client: S3Client | S3ClientConfig): DrizzleSingleStoreS3Extension;
@@ -0,0 +1,18 @@
1
+ import { S3Client, type S3ClientConfig } from '@aws-sdk/client-s3';
2
+ import { entityKind } from "../../../entity.js";
3
+ import { extensionName } from "../../../extension-core/index.js";
4
+ import { DrizzleSingleStoreExtension, type DrizzleSingleStoreHookContext } from "../../../extension-core/singlestore/index.js";
5
+ import type { S3ExtMeta } from "../common.js";
6
+ export declare class DrizzleSingleStoreS3Extension extends DrizzleSingleStoreExtension<S3ExtMeta> {
7
+ static readonly [entityKind]: string;
8
+ static readonly [extensionName] = "Drizzle SingleStore S3 Extension";
9
+ private s3;
10
+ constructor(client: S3Client | S3ClientConfig);
11
+ private buildOutputMappingInstructions;
12
+ private buildRqbOutputMappingInstructions;
13
+ private buildParamMappingInstructions;
14
+ private hookBefore;
15
+ private hookAfter;
16
+ hook(context: DrizzleSingleStoreHookContext<S3ExtMeta>): Promise<void>;
17
+ }
18
+ export declare function s3FileExt(client: S3Client | S3ClientConfig): DrizzleSingleStoreS3Extension;
@@ -0,0 +1,233 @@
1
+ import { S3Client } from "@aws-sdk/client-s3";
2
+ import { entityKind, is } from "../../../entity.js";
3
+ import { DrizzleError } from "../../../errors.js";
4
+ import { extensionColumnConfig, extensionName, requiredExtension } from "../../../extension-core/index.js";
5
+ import { DrizzleSingleStoreExtension } from "../../../extension-core/singlestore/index.js";
6
+ import {
7
+ One
8
+ } from "../../../relations.js";
9
+ import { SingleStoreColumn } from "../../../singlestore-core/index.js";
10
+ import { ExtensionParam, Placeholder } from "../../../sql/index.js";
11
+ import { orderSelectedFields } from "../../../utils.js";
12
+ import {
13
+ buildDecoder,
14
+ buildEncoder,
15
+ downloadFile,
16
+ mapParams,
17
+ objectIdToText,
18
+ presignDownload,
19
+ textToObjectId,
20
+ uploadFile
21
+ } from "../common.js";
22
+ class DrizzleSingleStoreS3Extension extends DrizzleSingleStoreExtension {
23
+ static [entityKind] = "DrizzleSingleStoreS3Extension";
24
+ static [extensionName] = "Drizzle SingleStore S3 Extension";
25
+ s3;
26
+ constructor(client) {
27
+ super();
28
+ this.s3 = typeof client === "object" && (client instanceof S3Client || client.constructor.name !== "Object") ? client : new S3Client(client);
29
+ }
30
+ buildOutputMappingInstructions(selection) {
31
+ const paths = [];
32
+ for (const f of selection) {
33
+ if (!is(f.field, SingleStoreColumn) || !f.field[requiredExtension] || !is(this, f.field[requiredExtension]))
34
+ continue;
35
+ const column = f.field;
36
+ const { fetchMode, fileMode, options } = column[extensionColumnConfig];
37
+ paths.push({
38
+ path: f.path.map((p) => `[${JSON.stringify(p)}]`),
39
+ fetchMode,
40
+ fileMode,
41
+ options
42
+ });
43
+ }
44
+ return paths;
45
+ }
46
+ buildRqbOutputMappingInstructions(schema, table, selection, parent, prefix = []) {
47
+ const p = parent ?? {
48
+ path: [],
49
+ subinstructions: []
50
+ };
51
+ for (const s of selection) {
52
+ if (is(s.field, SingleStoreColumn)) {
53
+ if (!s.field[requiredExtension] || !is(this, s.field[requiredExtension]))
54
+ continue;
55
+ const extCol = s.field;
56
+ (p.subinstructions ??= []).push({
57
+ path: [...prefix, `[${JSON.stringify(s.tsKey)}]`],
58
+ fileMode: extCol[extensionColumnConfig].fileMode,
59
+ fetchMode: extCol[extensionColumnConfig].fetchMode,
60
+ options: extCol[extensionColumnConfig].options
61
+ });
62
+ continue;
63
+ }
64
+ if (s.selection) {
65
+ const relation = schema[s.relationTableTsKey];
66
+ if (is(table.relations[s.tsKey], One)) {
67
+ this.buildRqbOutputMappingInstructions(schema, relation, s.selection, p, [
68
+ ...prefix,
69
+ `[${JSON.stringify(s.tsKey)}]`
70
+ ]);
71
+ continue;
72
+ }
73
+ const nestedSubs = this.buildRqbOutputMappingInstructions(schema, relation, s.selection);
74
+ if (!nestedSubs.length)
75
+ continue;
76
+ (p.subinstructions ??= []).push({
77
+ path: [...prefix, `[${JSON.stringify(s.tsKey)}]`],
78
+ subinstructions: nestedSubs
79
+ });
80
+ }
81
+ }
82
+ return p.subinstructions;
83
+ }
84
+ buildParamMappingInstructions(params) {
85
+ const indexes = [];
86
+ const placeholders = [];
87
+ let i = 0;
88
+ for (const item of params) {
89
+ if (!is(item, ExtensionParam) || !is(this, item.extension)) {
90
+ ++i;
91
+ continue;
92
+ }
93
+ if (is(item.value, Placeholder)) {
94
+ placeholders.push({
95
+ key: item.value.name,
96
+ mode: item.encoder[extensionColumnConfig].fileMode
97
+ });
98
+ ++i;
99
+ continue;
100
+ }
101
+ indexes.push({
102
+ index: i++,
103
+ mode: item.encoder[extensionColumnConfig].fileMode
104
+ });
105
+ }
106
+ return {
107
+ placeholders,
108
+ indexes
109
+ };
110
+ }
111
+ async hookBefore(context) {
112
+ if (!context?.params?.length)
113
+ return;
114
+ let indexes = [];
115
+ let placeholders = [];
116
+ const errors = [];
117
+ switch (context.query) {
118
+ case "select":
119
+ case "delete": {
120
+ break;
121
+ }
122
+ case "update":
123
+ case "insert": {
124
+ const instr = this.buildParamMappingInstructions(context.params);
125
+ indexes = instr.indexes;
126
+ placeholders = instr.placeholders;
127
+ break;
128
+ }
129
+ }
130
+ await mapParams(this.s3, context.params, indexes, errors);
131
+ if (errors.length) {
132
+ throw new DrizzleError({
133
+ message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file upload.
134
+ Log "(e as DrizzleError).cause" for details.`,
135
+ cause: errors
136
+ });
137
+ }
138
+ if (!context.metadata?.encoder) {
139
+ context.metadata = context.metadata ?? {};
140
+ context.metadata.encoder = buildEncoder(placeholders);
141
+ }
142
+ await context.metadata.encoder(this.s3, context.placeholders, errors, uploadFile, objectIdToText);
143
+ if (errors.length) {
144
+ throw new DrizzleError({
145
+ message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file upload.
146
+ Log "(e as DrizzleError).cause" for details.`,
147
+ cause: errors
148
+ });
149
+ }
150
+ return;
151
+ }
152
+ async hookAfter(context) {
153
+ const errors = [];
154
+ const data = context.data;
155
+ switch (context.query) {
156
+ case "select": {
157
+ if (!data.length)
158
+ return;
159
+ if (!context.metadata?.decoder) {
160
+ const fields = context.fieldsOrdered ?? context.config.fieldsFlat ?? orderSelectedFields(context.config.fields);
161
+ const instructions = this.buildOutputMappingInstructions(fields);
162
+ const decoder = buildDecoder(instructions);
163
+ context.metadata = context.metadata ?? {};
164
+ context.metadata.decoder = decoder;
165
+ }
166
+ break;
167
+ }
168
+ case "_query": {
169
+ if (context.mode === "first" && !data || context.mode === "many" && !data.length)
170
+ return;
171
+ if (!context.metadata?.decoder) {
172
+ const instructions = this.buildRqbOutputMappingInstructions(
173
+ context.tablesConfig,
174
+ context.tableConfig,
175
+ context.config.selection
176
+ );
177
+ const decoder = buildDecoder(instructions, context.mode);
178
+ context.metadata = context.metadata ?? {};
179
+ context.metadata.decoder = decoder;
180
+ }
181
+ break;
182
+ }
183
+ case "update":
184
+ case "delete":
185
+ case "insert": {
186
+ if (!data.length)
187
+ return;
188
+ if (!context.metadata?.decoder) {
189
+ if (!context.config.returning) {
190
+ const decoder2 = buildDecoder([]);
191
+ context.metadata = context.metadata ?? {};
192
+ context.metadata.decoder = decoder2;
193
+ break;
194
+ }
195
+ const fields = context.config.returning;
196
+ const instructions = this.buildOutputMappingInstructions(fields);
197
+ const decoder = buildDecoder(instructions);
198
+ context.metadata = context.metadata ?? {};
199
+ context.metadata.decoder = decoder;
200
+ }
201
+ break;
202
+ }
203
+ }
204
+ await context.metadata.decoder(
205
+ this.s3,
206
+ data,
207
+ errors,
208
+ downloadFile,
209
+ // downloadFileMeta,
210
+ presignDownload,
211
+ textToObjectId
212
+ );
213
+ if (errors.length) {
214
+ throw new DrizzleError({
215
+ message: `Error${errors.length > 1 ? "s" : ""} occured during S3 file download.
216
+ Log "(e as DrizzleError).cause" for details.`,
217
+ cause: errors
218
+ });
219
+ }
220
+ return;
221
+ }
222
+ async hook(context) {
223
+ return context.stage === "before" ? await this.hookBefore(context) : await this.hookAfter(context);
224
+ }
225
+ }
226
+ function s3FileExt(client) {
227
+ return new DrizzleSingleStoreS3Extension(client);
228
+ }
229
+ export {
230
+ DrizzleSingleStoreS3Extension,
231
+ s3FileExt
232
+ };
233
+ //# sourceMappingURL=extension.js.map