@dotdo/pglite 0.1.0 → 0.1.1

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 (327) hide show
  1. package/dist/amcheck.tar.gz +0 -0
  2. package/dist/auth_delay.tar.gz +0 -0
  3. package/dist/auto_explain.tar.gz +0 -0
  4. package/dist/basebackup_to_shell.tar.gz +0 -0
  5. package/dist/basic_archive.tar.gz +0 -0
  6. package/dist/bloom.tar.gz +0 -0
  7. package/dist/btree_gin.tar.gz +0 -0
  8. package/dist/btree_gist.tar.gz +0 -0
  9. package/dist/{chunk-FY2WAP66.js → chunk-5U7S5PTI.js} +2 -2
  10. package/dist/chunk-5U7S5PTI.js.map +1 -0
  11. package/dist/{chunk-NS5M47NH.js → chunk-I55HERVV.js} +3 -3
  12. package/dist/chunk-I55HERVV.js.map +1 -0
  13. package/dist/{chunk-XGK36GMM.js → chunk-J77SUHST.js} +2 -2
  14. package/dist/chunk-J77SUHST.js.map +1 -0
  15. package/dist/citext.tar.gz +0 -0
  16. package/dist/contrib/amcheck.cjs +1 -1
  17. package/dist/contrib/amcheck.cjs.map +1 -1
  18. package/dist/contrib/amcheck.d.cts +10 -0
  19. package/dist/contrib/amcheck.d.ts +10 -0
  20. package/dist/contrib/amcheck.js +1 -1
  21. package/dist/contrib/amcheck.js.map +1 -1
  22. package/dist/contrib/auto_explain.cjs +1 -1
  23. package/dist/contrib/auto_explain.cjs.map +1 -1
  24. package/dist/contrib/auto_explain.d.cts +10 -0
  25. package/dist/contrib/auto_explain.d.ts +10 -0
  26. package/dist/contrib/auto_explain.js +1 -1
  27. package/dist/contrib/auto_explain.js.map +1 -1
  28. package/dist/contrib/bloom.cjs +1 -1
  29. package/dist/contrib/bloom.cjs.map +1 -1
  30. package/dist/contrib/bloom.d.cts +10 -0
  31. package/dist/contrib/bloom.d.ts +10 -0
  32. package/dist/contrib/bloom.js +1 -1
  33. package/dist/contrib/bloom.js.map +1 -1
  34. package/dist/contrib/btree_gin.cjs +1 -1
  35. package/dist/contrib/btree_gin.cjs.map +1 -1
  36. package/dist/contrib/btree_gin.d.cts +10 -0
  37. package/dist/contrib/btree_gin.d.ts +10 -0
  38. package/dist/contrib/btree_gin.js +1 -1
  39. package/dist/contrib/btree_gin.js.map +1 -1
  40. package/dist/contrib/btree_gist.cjs +1 -1
  41. package/dist/contrib/btree_gist.cjs.map +1 -1
  42. package/dist/contrib/btree_gist.d.cts +10 -0
  43. package/dist/contrib/btree_gist.d.ts +10 -0
  44. package/dist/contrib/btree_gist.js +1 -1
  45. package/dist/contrib/btree_gist.js.map +1 -1
  46. package/dist/contrib/citext.cjs +1 -1
  47. package/dist/contrib/citext.cjs.map +1 -1
  48. package/dist/contrib/citext.d.cts +10 -0
  49. package/dist/contrib/citext.d.ts +10 -0
  50. package/dist/contrib/citext.js +1 -1
  51. package/dist/contrib/citext.js.map +1 -1
  52. package/dist/contrib/cube.cjs +1 -1
  53. package/dist/contrib/cube.cjs.map +1 -1
  54. package/dist/contrib/cube.d.cts +10 -0
  55. package/dist/contrib/cube.d.ts +10 -0
  56. package/dist/contrib/cube.js +1 -1
  57. package/dist/contrib/cube.js.map +1 -1
  58. package/dist/contrib/dict_int.cjs +1 -1
  59. package/dist/contrib/dict_int.cjs.map +1 -1
  60. package/dist/contrib/dict_int.d.cts +10 -0
  61. package/dist/contrib/dict_int.d.ts +10 -0
  62. package/dist/contrib/dict_int.js +1 -1
  63. package/dist/contrib/dict_int.js.map +1 -1
  64. package/dist/contrib/dict_xsyn.cjs +1 -1
  65. package/dist/contrib/dict_xsyn.cjs.map +1 -1
  66. package/dist/contrib/dict_xsyn.d.cts +10 -0
  67. package/dist/contrib/dict_xsyn.d.ts +10 -0
  68. package/dist/contrib/dict_xsyn.js +1 -1
  69. package/dist/contrib/dict_xsyn.js.map +1 -1
  70. package/dist/contrib/earthdistance.cjs +1 -1
  71. package/dist/contrib/earthdistance.cjs.map +1 -1
  72. package/dist/contrib/earthdistance.d.cts +10 -0
  73. package/dist/contrib/earthdistance.d.ts +10 -0
  74. package/dist/contrib/earthdistance.js +1 -1
  75. package/dist/contrib/earthdistance.js.map +1 -1
  76. package/dist/contrib/file_fdw.cjs +1 -1
  77. package/dist/contrib/file_fdw.cjs.map +1 -1
  78. package/dist/contrib/file_fdw.d.cts +10 -0
  79. package/dist/contrib/file_fdw.d.ts +10 -0
  80. package/dist/contrib/file_fdw.js +1 -1
  81. package/dist/contrib/file_fdw.js.map +1 -1
  82. package/dist/contrib/fuzzystrmatch.cjs +1 -1
  83. package/dist/contrib/fuzzystrmatch.cjs.map +1 -1
  84. package/dist/contrib/fuzzystrmatch.d.cts +10 -0
  85. package/dist/contrib/fuzzystrmatch.d.ts +10 -0
  86. package/dist/contrib/fuzzystrmatch.js +1 -1
  87. package/dist/contrib/fuzzystrmatch.js.map +1 -1
  88. package/dist/contrib/hstore.cjs +1 -1
  89. package/dist/contrib/hstore.cjs.map +1 -1
  90. package/dist/contrib/hstore.d.cts +10 -0
  91. package/dist/contrib/hstore.d.ts +10 -0
  92. package/dist/contrib/hstore.js +1 -1
  93. package/dist/contrib/hstore.js.map +1 -1
  94. package/dist/contrib/intarray.cjs +1 -1
  95. package/dist/contrib/intarray.cjs.map +1 -1
  96. package/dist/contrib/intarray.d.cts +10 -0
  97. package/dist/contrib/intarray.d.ts +10 -0
  98. package/dist/contrib/intarray.js +1 -1
  99. package/dist/contrib/intarray.js.map +1 -1
  100. package/dist/contrib/isn.cjs +1 -1
  101. package/dist/contrib/isn.cjs.map +1 -1
  102. package/dist/contrib/isn.d.cts +10 -0
  103. package/dist/contrib/isn.d.ts +10 -0
  104. package/dist/contrib/isn.js +1 -1
  105. package/dist/contrib/isn.js.map +1 -1
  106. package/dist/contrib/lo.cjs +1 -1
  107. package/dist/contrib/lo.cjs.map +1 -1
  108. package/dist/contrib/lo.d.cts +10 -0
  109. package/dist/contrib/lo.d.ts +10 -0
  110. package/dist/contrib/lo.js +1 -1
  111. package/dist/contrib/lo.js.map +1 -1
  112. package/dist/contrib/ltree.cjs +1 -1
  113. package/dist/contrib/ltree.cjs.map +1 -1
  114. package/dist/contrib/ltree.d.cts +10 -0
  115. package/dist/contrib/ltree.d.ts +10 -0
  116. package/dist/contrib/ltree.js +1 -1
  117. package/dist/contrib/ltree.js.map +1 -1
  118. package/dist/contrib/pageinspect.cjs +1 -1
  119. package/dist/contrib/pageinspect.cjs.map +1 -1
  120. package/dist/contrib/pageinspect.d.cts +10 -0
  121. package/dist/contrib/pageinspect.d.ts +10 -0
  122. package/dist/contrib/pageinspect.js +1 -1
  123. package/dist/contrib/pageinspect.js.map +1 -1
  124. package/dist/contrib/pg_buffercache.cjs +1 -1
  125. package/dist/contrib/pg_buffercache.cjs.map +1 -1
  126. package/dist/contrib/pg_buffercache.d.cts +10 -0
  127. package/dist/contrib/pg_buffercache.d.ts +10 -0
  128. package/dist/contrib/pg_buffercache.js +1 -1
  129. package/dist/contrib/pg_buffercache.js.map +1 -1
  130. package/dist/contrib/pg_freespacemap.cjs +1 -1
  131. package/dist/contrib/pg_freespacemap.cjs.map +1 -1
  132. package/dist/contrib/pg_freespacemap.d.cts +10 -0
  133. package/dist/contrib/pg_freespacemap.d.ts +10 -0
  134. package/dist/contrib/pg_freespacemap.js +1 -1
  135. package/dist/contrib/pg_freespacemap.js.map +1 -1
  136. package/dist/contrib/pg_surgery.cjs +1 -1
  137. package/dist/contrib/pg_surgery.cjs.map +1 -1
  138. package/dist/contrib/pg_surgery.d.cts +10 -0
  139. package/dist/contrib/pg_surgery.d.ts +10 -0
  140. package/dist/contrib/pg_surgery.js +1 -1
  141. package/dist/contrib/pg_surgery.js.map +1 -1
  142. package/dist/contrib/pg_trgm.cjs +1 -1
  143. package/dist/contrib/pg_trgm.cjs.map +1 -1
  144. package/dist/contrib/pg_trgm.d.cts +10 -0
  145. package/dist/contrib/pg_trgm.d.ts +10 -0
  146. package/dist/contrib/pg_trgm.js +1 -1
  147. package/dist/contrib/pg_trgm.js.map +1 -1
  148. package/dist/contrib/pg_visibility.cjs +1 -1
  149. package/dist/contrib/pg_visibility.cjs.map +1 -1
  150. package/dist/contrib/pg_visibility.d.cts +10 -0
  151. package/dist/contrib/pg_visibility.d.ts +10 -0
  152. package/dist/contrib/pg_visibility.js +1 -1
  153. package/dist/contrib/pg_visibility.js.map +1 -1
  154. package/dist/contrib/pg_walinspect.cjs +1 -1
  155. package/dist/contrib/pg_walinspect.cjs.map +1 -1
  156. package/dist/contrib/pg_walinspect.d.cts +10 -0
  157. package/dist/contrib/pg_walinspect.d.ts +10 -0
  158. package/dist/contrib/pg_walinspect.js +1 -1
  159. package/dist/contrib/pg_walinspect.js.map +1 -1
  160. package/dist/contrib/pgcrypto.cjs +1 -1
  161. package/dist/contrib/pgcrypto.cjs.map +1 -1
  162. package/dist/contrib/pgcrypto.d.cts +10 -0
  163. package/dist/contrib/pgcrypto.d.ts +10 -0
  164. package/dist/contrib/pgcrypto.js +1 -1
  165. package/dist/contrib/pgcrypto.js.map +1 -1
  166. package/dist/contrib/seg.cjs +1 -1
  167. package/dist/contrib/seg.cjs.map +1 -1
  168. package/dist/contrib/seg.d.cts +10 -0
  169. package/dist/contrib/seg.d.ts +10 -0
  170. package/dist/contrib/seg.js +1 -1
  171. package/dist/contrib/seg.js.map +1 -1
  172. package/dist/contrib/tablefunc.cjs +1 -1
  173. package/dist/contrib/tablefunc.cjs.map +1 -1
  174. package/dist/contrib/tablefunc.d.cts +10 -0
  175. package/dist/contrib/tablefunc.d.ts +10 -0
  176. package/dist/contrib/tablefunc.js +1 -1
  177. package/dist/contrib/tablefunc.js.map +1 -1
  178. package/dist/contrib/tcn.cjs +1 -1
  179. package/dist/contrib/tcn.cjs.map +1 -1
  180. package/dist/contrib/tcn.d.cts +10 -0
  181. package/dist/contrib/tcn.d.ts +10 -0
  182. package/dist/contrib/tcn.js +1 -1
  183. package/dist/contrib/tcn.js.map +1 -1
  184. package/dist/contrib/tsm_system_rows.cjs +1 -1
  185. package/dist/contrib/tsm_system_rows.cjs.map +1 -1
  186. package/dist/contrib/tsm_system_rows.d.cts +10 -0
  187. package/dist/contrib/tsm_system_rows.d.ts +10 -0
  188. package/dist/contrib/tsm_system_rows.js +1 -1
  189. package/dist/contrib/tsm_system_rows.js.map +1 -1
  190. package/dist/contrib/tsm_system_time.cjs +1 -1
  191. package/dist/contrib/tsm_system_time.cjs.map +1 -1
  192. package/dist/contrib/tsm_system_time.d.cts +10 -0
  193. package/dist/contrib/tsm_system_time.d.ts +10 -0
  194. package/dist/contrib/tsm_system_time.js +1 -1
  195. package/dist/contrib/tsm_system_time.js.map +1 -1
  196. package/dist/contrib/unaccent.cjs +1 -1
  197. package/dist/contrib/unaccent.cjs.map +1 -1
  198. package/dist/contrib/unaccent.d.cts +10 -0
  199. package/dist/contrib/unaccent.d.ts +10 -0
  200. package/dist/contrib/unaccent.js +1 -1
  201. package/dist/contrib/unaccent.js.map +1 -1
  202. package/dist/contrib/uuid_ossp.cjs +1 -1
  203. package/dist/contrib/uuid_ossp.cjs.map +1 -1
  204. package/dist/contrib/uuid_ossp.d.cts +10 -0
  205. package/dist/contrib/uuid_ossp.d.ts +10 -0
  206. package/dist/contrib/uuid_ossp.js +1 -1
  207. package/dist/contrib/uuid_ossp.js.map +1 -1
  208. package/dist/cube.tar.gz +0 -0
  209. package/dist/dblink.tar.gz +0 -0
  210. package/dist/dict_int.tar.gz +0 -0
  211. package/dist/dict_xsyn.tar.gz +0 -0
  212. package/dist/earthdistance.tar.gz +0 -0
  213. package/dist/file_fdw.tar.gz +0 -0
  214. package/dist/fs/base.cjs +1 -1
  215. package/dist/fs/base.cjs.map +1 -1
  216. package/dist/fs/base.d.cts +1 -0
  217. package/dist/fs/base.d.ts +1 -0
  218. package/dist/fs/base.js +1 -1
  219. package/dist/fs/nodefs.cjs +1 -1
  220. package/dist/fs/nodefs.cjs.map +1 -1
  221. package/dist/fs/nodefs.d.cts +12 -0
  222. package/dist/fs/nodefs.d.ts +12 -0
  223. package/dist/fs/nodefs.js +1 -1
  224. package/dist/fs/opfs-ahp.cjs +3 -3
  225. package/dist/fs/opfs-ahp.cjs.map +1 -1
  226. package/dist/fs/opfs-ahp.d.cts +112 -0
  227. package/dist/fs/opfs-ahp.d.ts +112 -0
  228. package/dist/fs/opfs-ahp.js +1 -1
  229. package/dist/fuzzystrmatch.tar.gz +0 -0
  230. package/dist/hstore.tar.gz +0 -0
  231. package/dist/index.cjs +7 -7
  232. package/dist/index.cjs.map +1 -1
  233. package/dist/index.d.cts +416 -0
  234. package/dist/index.d.ts +416 -0
  235. package/dist/index.js +4 -4
  236. package/dist/index.js.map +1 -1
  237. package/dist/intagg.tar.gz +0 -0
  238. package/dist/intarray.tar.gz +0 -0
  239. package/dist/isn.tar.gz +0 -0
  240. package/dist/live/index.cjs +5 -5
  241. package/dist/live/index.cjs.map +1 -1
  242. package/dist/live/index.d.cts +149 -0
  243. package/dist/live/index.d.ts +149 -0
  244. package/dist/live/index.js +1 -1
  245. package/dist/live/index.js.map +1 -1
  246. package/dist/lo.tar.gz +0 -0
  247. package/dist/ltree.tar.gz +0 -0
  248. package/dist/oid2name.tar.gz +0 -0
  249. package/dist/pageinspect.tar.gz +0 -0
  250. package/dist/passwordcheck.tar.gz +0 -0
  251. package/dist/pg_buffercache.tar.gz +0 -0
  252. package/dist/pg_freespacemap.tar.gz +0 -0
  253. package/dist/pg_hashids/index.cjs +1 -1
  254. package/dist/pg_hashids/index.cjs.map +1 -1
  255. package/dist/pg_hashids/index.d.cts +11 -0
  256. package/dist/pg_hashids/index.d.ts +11 -0
  257. package/dist/pg_hashids/index.js +1 -1
  258. package/dist/pg_hashids/index.js.map +1 -1
  259. package/dist/pg_hashids.tar.gz +0 -0
  260. package/dist/pg_ivm/index.cjs +1 -1
  261. package/dist/pg_ivm/index.cjs.map +1 -1
  262. package/dist/pg_ivm/index.d.cts +11 -0
  263. package/dist/pg_ivm/index.d.ts +11 -0
  264. package/dist/pg_ivm/index.js +1 -1
  265. package/dist/pg_ivm/index.js.map +1 -1
  266. package/dist/pg_ivm.tar.gz +0 -0
  267. package/dist/pg_prewarm.tar.gz +0 -0
  268. package/dist/pg_stat_statements.tar.gz +0 -0
  269. package/dist/pg_surgery.tar.gz +0 -0
  270. package/dist/pg_textsearch.tar.gz +0 -0
  271. package/dist/pg_trgm.tar.gz +0 -0
  272. package/dist/pg_uuidv7/index.cjs +1 -1
  273. package/dist/pg_uuidv7/index.cjs.map +1 -1
  274. package/dist/pg_uuidv7/index.d.cts +11 -0
  275. package/dist/pg_uuidv7/index.d.ts +11 -0
  276. package/dist/pg_uuidv7/index.js +1 -1
  277. package/dist/pg_uuidv7/index.js.map +1 -1
  278. package/dist/pg_uuidv7.tar.gz +0 -0
  279. package/dist/pg_visibility.tar.gz +0 -0
  280. package/dist/pg_walinspect.tar.gz +0 -0
  281. package/dist/pgcrypto.tar.gz +0 -0
  282. package/dist/pglite-RfkRSGmH.d.cts +1507 -0
  283. package/dist/pglite-RfkRSGmH.d.ts +1507 -0
  284. package/dist/pglite.cjs +3 -3
  285. package/dist/pglite.data +0 -0
  286. package/dist/pglite.html +1 -0
  287. package/dist/pglite.js +16 -0
  288. package/dist/pglite.wasm +0 -0
  289. package/dist/pgrowlocks.tar.gz +0 -0
  290. package/dist/pgstattuple.tar.gz +0 -0
  291. package/dist/pgtap/index.cjs +1 -1
  292. package/dist/pgtap/index.cjs.map +1 -1
  293. package/dist/pgtap/index.d.cts +11 -0
  294. package/dist/pgtap/index.d.ts +11 -0
  295. package/dist/pgtap/index.js +1 -1
  296. package/dist/pgtap/index.js.map +1 -1
  297. package/dist/pgtap.tar.gz +0 -0
  298. package/dist/postgres_fdw.tar.gz +0 -0
  299. package/dist/seg.tar.gz +0 -0
  300. package/dist/spi.tar.gz +0 -0
  301. package/dist/tablefunc.tar.gz +0 -0
  302. package/dist/tcn.tar.gz +0 -0
  303. package/dist/templating.d.cts +69 -0
  304. package/dist/templating.d.ts +69 -0
  305. package/dist/test_decoding.tar.gz +0 -0
  306. package/dist/tsm_system_rows.tar.gz +0 -0
  307. package/dist/tsm_system_time.tar.gz +0 -0
  308. package/dist/unaccent.tar.gz +0 -0
  309. package/dist/uuid-ossp.tar.gz +0 -0
  310. package/dist/vacuumlo.tar.gz +0 -0
  311. package/dist/vector/index.cjs +1 -1
  312. package/dist/vector/index.cjs.map +1 -1
  313. package/dist/vector/index.d.cts +11 -0
  314. package/dist/vector/index.d.ts +11 -0
  315. package/dist/vector/index.js +1 -1
  316. package/dist/vector/index.js.map +1 -1
  317. package/dist/vector.tar.gz +0 -0
  318. package/dist/worker/index.cjs.map +1 -1
  319. package/dist/worker/index.d.cts +115 -0
  320. package/dist/worker/index.d.ts +115 -0
  321. package/dist/worker/index.js +1 -1
  322. package/dist/worker/index.js.map +1 -1
  323. package/dist/xml2.tar.gz +0 -0
  324. package/package.json +1 -1
  325. package/dist/chunk-FY2WAP66.js.map +0 -1
  326. package/dist/chunk-NS5M47NH.js.map +0 -1
  327. package/dist/chunk-XGK36GMM.js.map +0 -1
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
@@ -1,2 +1,2 @@
1
- import{b as ae,e as s,f as h,g as d,h as p,i as oe,j as y}from"./chunk-VCBR6USK.js";var hr={};ae(hr,{ABSTIME:()=>Ct,ACLITEM:()=>vt,BIT:()=>jt,BOOL:()=>be,BPCHAR:()=>_e,BYTEA:()=>ge,CHAR:()=>wt,CID:()=>St,CIDR:()=>Et,CIRCLE:()=>Nt,DATE:()=>He,FLOAT4:()=>je,FLOAT8:()=>Qe,GTSVECTOR:()=>sr,INET:()=>Vt,INT2:()=>Fe,INT4:()=>Ge,INT8:()=>we,INTERVAL:()=>Gt,JSON:()=>Ae,JSONB:()=>Ye,MACADDR:()=>Ot,MACADDR8:()=>Lt,MONEY:()=>kt,NUMERIC:()=>_t,OID:()=>We,PATH:()=>Rt,PG_DEPENDENCIES:()=>tr,PG_LSN:()=>Zt,PG_NDISTINCT:()=>er,PG_NODE_TREE:()=>It,POLYGON:()=>Tt,REFCURSOR:()=>zt,REGCLASS:()=>$t,REGCONFIG:()=>ir,REGDICTIONARY:()=>ar,REGNAMESPACE:()=>or,REGOPER:()=>qt,REGOPERATOR:()=>Yt,REGPROC:()=>At,REGPROCEDURE:()=>Ht,REGROLE:()=>ur,REGTYPE:()=>Kt,RELTIME:()=>Pt,SMGR:()=>Mt,TEXT:()=>V,TID:()=>Bt,TIME:()=>Ft,TIMESTAMP:()=>qe,TIMESTAMPTZ:()=>Be,TIMETZ:()=>Wt,TINTERVAL:()=>Ut,TSQUERY:()=>nr,TSVECTOR:()=>rr,TXID_SNAPSHOT:()=>Xt,UUID:()=>Jt,VARBIT:()=>Qt,VARCHAR:()=>ze,XID:()=>xt,XML:()=>Dt,arrayParser:()=>yr,arraySerializer:()=>Ke,parseType:()=>ue,parsers:()=>lr,serializers:()=>cr,types:()=>$e});y();var bt=globalThis.JSON.parse,gt=globalThis.JSON.stringify,be=16,ge=17,wt=18,we=20,Fe=21,Ge=23,At=24,V=25,We=26,Bt=27,xt=28,St=29,Ae=114,Dt=142,It=194,Mt=210,Rt=602,Tt=604,Et=650,je=700,Qe=701,Ct=702,Pt=703,Ut=704,Nt=718,Lt=774,kt=790,Ot=829,Vt=869,vt=1033,_e=1042,ze=1043,He=1082,Ft=1083,qe=1114,Be=1184,Gt=1186,Wt=1266,jt=1560,Qt=1562,_t=1700,zt=1790,Ht=2202,qt=2203,Yt=2204,$t=2205,Kt=2206,Jt=2950,Xt=2970,Zt=3220,er=3361,tr=3402,rr=3614,nr=3615,sr=3642,ir=3734,ar=3769,Ye=3802,or=4089,ur=4096,$e={string:{to:V,from:[V,ze,_e],serialize:e=>{if(typeof e=="string")return e;if(typeof e=="number")return e.toString();throw new Error("Invalid input for string type")},parse:e=>e},number:{to:0,from:[Fe,Ge,We,je,Qe],serialize:e=>e.toString(),parse:e=>+e},bigint:{to:we,from:[we],serialize:e=>e.toString(),parse:e=>{let t=BigInt(e);return t<Number.MIN_SAFE_INTEGER||t>Number.MAX_SAFE_INTEGER?t:Number(t)}},json:{to:Ae,from:[Ae,Ye],serialize:e=>typeof e=="string"?e:gt(e),parse:e=>bt(e)},boolean:{to:be,from:[be],serialize:e=>{if(typeof e!="boolean")throw new Error("Invalid input for boolean type");return e?"t":"f"},parse:e=>e==="t"},date:{to:Be,from:[He,qe,Be],serialize:e=>{if(typeof e=="string")return e;if(typeof e=="number")return new Date(e).toISOString();if(e instanceof Date)return e.toISOString();throw new Error("Invalid input for date type")},parse:e=>new Date(e)},bytea:{to:ge,from:[ge],serialize:e=>{if(!(e instanceof Uint8Array))throw new Error("Invalid input for bytea type");return"\\x"+Array.from(e).map(t=>t.toString(16).padStart(2,"0")).join("")},parse:e=>{let t=e.slice(2);return Uint8Array.from({length:t.length/2},(r,n)=>parseInt(t.substring(n*2,(n+1)*2),16))}}},xe=pr($e),lr=xe.parsers,cr=xe.serializers;function ue(e,t,r){if(e===null)return null;let n=r?.[t]??xe.parsers[t];return n?n(e,t):e}function pr(e){return Object.keys(e).reduce(({parsers:t,serializers:r},n)=>{let{to:i,from:a,serialize:u,parse:f}=e[n];return r[i]=u,r[n]=u,t[n]=f,Array.isArray(a)?a.forEach(c=>{t[c]=f,r[c]=u}):(t[a]=f,r[a]=u),{parsers:t,serializers:r}},{parsers:{},serializers:{}})}var dr=/\\/g,fr=/"/g;function mr(e){return e.replace(dr,"\\\\").replace(fr,'\\"')}function Ke(e,t,r){if(Array.isArray(e)===!1)return e;if(!e.length)return"{}";let n=e[0],i=r===1020?";":",";return Array.isArray(n)?`{${e.map(a=>Ke(a,t,r)).join(i)}}`:`{${e.map(a=>(a===void 0&&(a=null),a===null?"null":'"'+mr(t?t(a):a.toString())+'"')).join(i)}}`}var he={i:0,char:null,str:"",quoted:!1,last:0,p:null};function yr(e,t,r){return he.i=he.last=0,Je(he,e,t,r)[0]}function Je(e,t,r,n){let i=[],a=n===1020?";":",";for(;e.i<t.length;e.i++){if(e.char=t[e.i],e.quoted)e.char==="\\"?e.str+=t[++e.i]:e.char==='"'?(i.push(r?r(e.str):e.str),e.str="",e.quoted=t[e.i+1]==='"',e.last=e.i+2):e.str+=e.char;else if(e.char==='"')e.quoted=!0;else if(e.char==="{")e.last=++e.i,i.push(Je(e,t,r,n));else if(e.char==="}"){e.quoted=!1,e.last<e.i&&i.push(r?r(t.slice(e.last,e.i)):t.slice(e.last,e.i)),e.last=e.i+1;break}else e.char===a&&e.p!=="}"&&e.p!=='"'&&(i.push(r?r(t.slice(e.last,e.i)):t.slice(e.last,e.i)),e.last=e.i+1);e.p=e.char}return e.last<e.i&&i.push(r?r(t.slice(e.last,e.i+1)):t.slice(e.last,e.i+1)),i}var wr={};ae(wr,{parseDescribeStatementResults:()=>Se,parseResults:()=>br});y();function br(e,t,r,n){let i=[],a={rows:[],fields:[]},u=0,f={...t,...r?.parsers};return e.forEach(c=>{switch(c.name){case"rowDescription":{let M=c;a.fields=M.fields.map(E=>({name:E.name,dataTypeID:E.dataTypeID}));break}case"dataRow":{if(!a)break;let M=c;r?.rowMode==="array"?a.rows.push(M.fields.map((E,ie)=>ue(E,a.fields[ie].dataTypeID,f))):a.rows.push(Object.fromEntries(M.fields.map((E,ie)=>[a.fields[ie].name,ue(E,a.fields[ie].dataTypeID,f)])));break}case"commandComplete":{u+=gr(c),i.push({...a,affectedRows:u,...n?{blob:n}:{}}),a={rows:[],fields:[]};break}}}),i.length===0&&i.push({affectedRows:0,rows:[],fields:[]}),i}function gr(e){let t=e.text.split(" ");switch(t[0]){case"INSERT":return parseInt(t[2],10);case"UPDATE":case"DELETE":case"COPY":case"MERGE":return parseInt(t[1],10);default:return 0}}function Se(e){let t=e.find(r=>r.name==="parameterDescription");return t?t.dataTypeIDs:[]}var Ue={};ae(Ue,{AuthenticationCleartextPassword:()=>F,AuthenticationMD5Password:()=>G,AuthenticationOk:()=>v,AuthenticationSASL:()=>W,AuthenticationSASLContinue:()=>j,AuthenticationSASLFinal:()=>Q,BackendKeyDataMessage:()=>K,CommandCompleteMessage:()=>Z,CopyDataMessage:()=>_,CopyResponse:()=>z,DataRowMessage:()=>ee,DatabaseError:()=>C,Field:()=>H,NoticeMessage:()=>te,NotificationResponseMessage:()=>J,ParameterDescriptionMessage:()=>Y,ParameterStatusMessage:()=>$,ReadyForQueryMessage:()=>X,RowDescriptionMessage:()=>q,bindComplete:()=>Ie,closeComplete:()=>Me,copyDone:()=>Pe,emptyQuery:()=>Ce,noData:()=>Re,parseComplete:()=>De,portalSuspended:()=>Te,replicationStart:()=>Ee});y();var De={name:"parseComplete",length:5},Ie={name:"bindComplete",length:5},Me={name:"closeComplete",length:5},Re={name:"noData",length:5},Te={name:"portalSuspended",length:5},Ee={name:"replicationStart",length:4},Ce={name:"emptyQuery",length:4},Pe={name:"copyDone",length:4},v=class{constructor(t){this.length=t;this.name="authenticationOk"}},F=class{constructor(t){this.length=t;this.name="authenticationCleartextPassword"}},G=class{constructor(t,r){this.length=t;this.salt=r;this.name="authenticationMD5Password"}},W=class{constructor(t,r){this.length=t;this.mechanisms=r;this.name="authenticationSASL"}},j=class{constructor(t,r){this.length=t;this.data=r;this.name="authenticationSASLContinue"}},Q=class{constructor(t,r){this.length=t;this.data=r;this.name="authenticationSASLFinal"}},C=class extends Error{constructor(r,n,i){super(r);this.length=n;this.name=i}},_=class{constructor(t,r){this.length=t;this.chunk=r;this.name="copyData"}},z=class{constructor(t,r,n,i){this.length=t;this.name=r;this.binary=n;this.columnTypes=new Array(i)}},H=class{constructor(t,r,n,i,a,u,f){this.name=t;this.tableID=r;this.columnID=n;this.dataTypeID=i;this.dataTypeSize=a;this.dataTypeModifier=u;this.format=f}},q=class{constructor(t,r){this.length=t;this.fieldCount=r;this.name="rowDescription";this.fields=new Array(this.fieldCount)}},Y=class{constructor(t,r){this.length=t;this.parameterCount=r;this.name="parameterDescription";this.dataTypeIDs=new Array(this.parameterCount)}},$=class{constructor(t,r,n){this.length=t;this.parameterName=r;this.parameterValue=n;this.name="parameterStatus"}},K=class{constructor(t,r,n){this.length=t;this.processID=r;this.secretKey=n;this.name="backendKeyData"}},J=class{constructor(t,r,n,i){this.length=t;this.processId=r;this.channel=n;this.payload=i;this.name="notification"}},X=class{constructor(t,r){this.length=t;this.status=r;this.name="readyForQuery"}},Z=class{constructor(t,r){this.length=t;this.text=r;this.name="commandComplete"}},ee=class{constructor(t,r){this.length=t;this.fields=r;this.name="dataRow";this.fieldCount=r.length}},te=class{constructor(t,r){this.length=t;this.message=r;this.name="notice"}};var zr={};ae(zr,{Parser:()=>ye,messages:()=>Ue,serialize:()=>O});y();y();y();y();function P(e){let t=e.length;for(let r=e.length-1;r>=0;r--){let n=e.charCodeAt(r);n>127&&n<=2047?t++:n>2047&&n<=65535&&(t+=2),n>=56320&&n<=57343&&r--}return t}var b,g,N,ce,L,B,le,U,Xe,T=class{constructor(t=256){this.size=t;h(this,B);h(this,b);h(this,g,5);h(this,N,!1);h(this,ce,new TextEncoder);h(this,L,0);d(this,b,p(this,B,le).call(this,t))}addInt32(t){return p(this,B,U).call(this,4),s(this,b).setInt32(s(this,g),t,s(this,N)),d(this,g,s(this,g)+4),this}addInt16(t){return p(this,B,U).call(this,2),s(this,b).setInt16(s(this,g),t,s(this,N)),d(this,g,s(this,g)+2),this}addCString(t){return t&&this.addString(t),p(this,B,U).call(this,1),s(this,b).setUint8(s(this,g),0),oe(this,g)._++,this}addString(t=""){let r=P(t);return p(this,B,U).call(this,r),s(this,ce).encodeInto(t,new Uint8Array(s(this,b).buffer,s(this,g))),d(this,g,s(this,g)+r),this}add(t){return p(this,B,U).call(this,t.byteLength),new Uint8Array(s(this,b).buffer).set(new Uint8Array(t),s(this,g)),d(this,g,s(this,g)+t.byteLength),this}flush(t){let r=p(this,B,Xe).call(this,t);return d(this,g,5),d(this,b,p(this,B,le).call(this,this.size)),new Uint8Array(r)}};b=new WeakMap,g=new WeakMap,N=new WeakMap,ce=new WeakMap,L=new WeakMap,B=new WeakSet,le=function(t){return new DataView(new ArrayBuffer(t))},U=function(t){if(s(this,b).byteLength-s(this,g)<t){let n=s(this,b).buffer,i=n.byteLength+(n.byteLength>>1)+t;d(this,b,p(this,B,le).call(this,i)),new Uint8Array(s(this,b).buffer).set(new Uint8Array(n))}},Xe=function(t){if(t){s(this,b).setUint8(s(this,L),t);let r=s(this,g)-(s(this,L)+1);s(this,b).setInt32(s(this,L)+1,r,s(this,N))}return s(this,b).buffer.slice(t?0:5,s(this,g))};var m=new T,Ar=e=>{m.addInt16(3).addInt16(0);for(let n of Object.keys(e))m.addCString(n).addCString(e[n]);m.addCString("client_encoding").addCString("UTF8");let t=m.addCString("").flush(),r=t.byteLength+4;return new T().addInt32(r).add(t.buffer).flush()},Br=()=>{let e=new DataView(new ArrayBuffer(8));return e.setInt32(0,8,!1),e.setInt32(4,80877103,!1),new Uint8Array(e.buffer)},xr=e=>m.addCString(e).flush(112),Sr=(e,t)=>(m.addCString(e).addInt32(P(t)).addString(t),m.flush(112)),Dr=e=>m.addString(e).flush(112),Ir=e=>m.addCString(e).flush(81),Mr=[],Rr=e=>{let t=e.name??"";t.length>63&&(console.error("Warning! Postgres only supports 63 characters for query names."),console.error("You supplied %s (%s)",t,t.length),console.error("This can cause conflicts and silent errors executing queries"));let r=m.addCString(t).addCString(e.text).addInt16(e.types?.length??0);return e.types?.forEach(n=>r.addInt32(n)),m.flush(80)},k=new T;var Tr=(e,t)=>{for(let r=0;r<e.length;r++){let n=t?t(e[r],r):e[r];if(n===null)m.addInt16(0),k.addInt32(-1);else if(n instanceof ArrayBuffer||ArrayBuffer.isView(n)){let i=ArrayBuffer.isView(n)?n.buffer.slice(n.byteOffset,n.byteOffset+n.byteLength):n;m.addInt16(1),k.addInt32(i.byteLength),k.add(i)}else m.addInt16(0),k.addInt32(P(n)),k.addString(n)}},Er=(e={})=>{let t=e.portal??"",r=e.statement??"",n=e.binary??!1,i=e.values??Mr,a=i.length;return m.addCString(t).addCString(r),m.addInt16(a),Tr(i,e.valueMapper),m.addInt16(a),m.add(k.flush().buffer),m.addInt16(n?1:0),m.flush(66)},Cr=new Uint8Array([69,0,0,0,9,0,0,0,0,0]),Pr=e=>{if(!e||!e.portal&&!e.rows)return Cr;let t=e.portal??"",r=e.rows??0,n=P(t),i=4+n+1+4,a=new DataView(new ArrayBuffer(1+i));return a.setUint8(0,69),a.setInt32(1,i,!1),new TextEncoder().encodeInto(t,new Uint8Array(a.buffer,5)),a.setUint8(n+5,0),a.setUint32(a.byteLength-4,r,!1),new Uint8Array(a.buffer)},Ur=(e,t)=>{let r=new DataView(new ArrayBuffer(16));return r.setInt32(0,16,!1),r.setInt16(4,1234,!1),r.setInt16(6,5678,!1),r.setInt32(8,e,!1),r.setInt32(12,t,!1),new Uint8Array(r.buffer)},Ne=(e,t)=>{let r=new T;return r.addCString(t),r.flush(e)},Nr=m.addCString("P").flush(68),Lr=m.addCString("S").flush(68),kr=e=>e.name?Ne(68,`${e.type}${e.name??""}`):e.type==="P"?Nr:Lr,Or=e=>{let t=`${e.type}${e.name??""}`;return Ne(67,t)},Vr=e=>m.add(e).flush(100),vr=e=>Ne(102,e),pe=e=>new Uint8Array([e,0,0,0,4]),Fr=pe(72),Gr=pe(83),Wr=pe(88),jr=pe(99),O={startup:Ar,password:xr,requestSsl:Br,sendSASLInitialResponseMessage:Sr,sendSCRAMClientFinalMessage:Dr,query:Ir,parse:Rr,bind:Er,execute:Pr,describe:kr,close:Or,flush:()=>Fr,sync:()=>Gr,end:()=>Wr,copyData:Vr,copyDone:()=>jr,copyFail:vr,cancel:Ur};y();y();var Le={text:0,binary:1};y();var Qr=new ArrayBuffer(0),R,w,fe,me,re,de=class{constructor(t=0){h(this,R,new DataView(Qr));h(this,w);h(this,fe,"utf-8");h(this,me,new TextDecoder(s(this,fe)));h(this,re,!1);d(this,w,t)}setBuffer(t,r){d(this,w,t),d(this,R,new DataView(r))}int16(){let t=s(this,R).getInt16(s(this,w),s(this,re));return d(this,w,s(this,w)+2),t}byte(){let t=s(this,R).getUint8(s(this,w));return oe(this,w)._++,t}int32(){let t=s(this,R).getInt32(s(this,w),s(this,re));return d(this,w,s(this,w)+4),t}string(t){return s(this,me).decode(this.bytes(t))}cstring(){let t=s(this,w),r=t;for(;s(this,R).getUint8(r++)!==0;);let n=this.string(r-t-1);return d(this,w,r),n}bytes(t){let r=s(this,R).buffer.slice(s(this,w),s(this,w)+t);return d(this,w,s(this,w)+t),new Uint8Array(r)}};R=new WeakMap,w=new WeakMap,fe=new WeakMap,me=new WeakMap,re=new WeakMap;var ke=1,_r=4,Ze=ke+_r,et=new ArrayBuffer(0);var A,x,S,o,l,tt,rt,nt,st,it,at,ot,Oe,ut,lt,ct,pt,dt,ft,mt,yt,Ve,ye=class{constructor(){h(this,l);h(this,A,new DataView(et));h(this,x,0);h(this,S,0);h(this,o,new de)}parse(t,r){p(this,l,tt).call(this,ArrayBuffer.isView(t)?t.buffer.slice(t.byteOffset,t.byteOffset+t.byteLength):t);let n=s(this,S)+s(this,x),i=s(this,S);for(;i+Ze<=n;){let a=s(this,A).getUint8(i),u=s(this,A).getUint32(i+ke,!1),f=ke+u;if(f+i<=n&&u>0){let c=p(this,l,rt).call(this,i+Ze,a,u,s(this,A).buffer);r(c),i+=f}else break}i===n?(d(this,A,new DataView(et)),d(this,x,0),d(this,S,0)):(d(this,x,n-i),d(this,S,i))}};A=new WeakMap,x=new WeakMap,S=new WeakMap,o=new WeakMap,l=new WeakSet,tt=function(t){if(s(this,x)>0){let r=s(this,x)+t.byteLength;if(r+s(this,S)>s(this,A).byteLength){let i;if(r<=s(this,A).byteLength&&s(this,S)>=s(this,x))i=s(this,A).buffer;else{let a=s(this,A).byteLength*2;for(;r>=a;)a*=2;i=new ArrayBuffer(a)}new Uint8Array(i).set(new Uint8Array(s(this,A).buffer,s(this,S),s(this,x))),d(this,A,new DataView(i)),d(this,S,0)}new Uint8Array(s(this,A).buffer).set(new Uint8Array(t),s(this,S)+s(this,x)),d(this,x,r)}else d(this,A,new DataView(t)),d(this,S,0),d(this,x,t.byteLength)},rt=function(t,r,n,i){switch(r){case 50:return Ie;case 49:return De;case 51:return Me;case 110:return Re;case 115:return Te;case 99:return Pe;case 87:return Ee;case 73:return Ce;case 68:return p(this,l,dt).call(this,t,n,i);case 67:return p(this,l,st).call(this,t,n,i);case 90:return p(this,l,nt).call(this,t,n,i);case 65:return p(this,l,ut).call(this,t,n,i);case 82:return p(this,l,yt).call(this,t,n,i);case 83:return p(this,l,ft).call(this,t,n,i);case 75:return p(this,l,mt).call(this,t,n,i);case 69:return p(this,l,Ve).call(this,t,n,i,"error");case 78:return p(this,l,Ve).call(this,t,n,i,"notice");case 84:return p(this,l,lt).call(this,t,n,i);case 116:return p(this,l,pt).call(this,t,n,i);case 71:return p(this,l,at).call(this,t,n,i);case 72:return p(this,l,ot).call(this,t,n,i);case 100:return p(this,l,it).call(this,t,n,i);default:return new C("received invalid response: "+r.toString(16),n,"error")}},nt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).string(1);return new X(r,i)},st=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).cstring();return new Z(r,i)},it=function(t,r,n){let i=n.slice(t,t+(r-4));return new _(r,new Uint8Array(i))},at=function(t,r,n){return p(this,l,Oe).call(this,t,r,n,"copyInResponse")},ot=function(t,r,n){return p(this,l,Oe).call(this,t,r,n,"copyOutResponse")},Oe=function(t,r,n,i){s(this,o).setBuffer(t,n);let a=s(this,o).byte()!==0,u=s(this,o).int16(),f=new z(r,i,a,u);for(let c=0;c<u;c++)f.columnTypes[c]=s(this,o).int16();return f},ut=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int32(),a=s(this,o).cstring(),u=s(this,o).cstring();return new J(r,i,a,u)},lt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int16(),a=new q(r,i);for(let u=0;u<i;u++)a.fields[u]=p(this,l,ct).call(this);return a},ct=function(){let t=s(this,o).cstring(),r=s(this,o).int32(),n=s(this,o).int16(),i=s(this,o).int32(),a=s(this,o).int16(),u=s(this,o).int32(),f=s(this,o).int16()===0?Le.text:Le.binary;return new H(t,r,n,i,a,u,f)},pt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int16(),a=new Y(r,i);for(let u=0;u<i;u++)a.dataTypeIDs[u]=s(this,o).int32();return a},dt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int16(),a=new Array(i);for(let u=0;u<i;u++){let f=s(this,o).int32();a[u]=f===-1?null:s(this,o).string(f)}return new ee(r,a)},ft=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).cstring(),a=s(this,o).cstring();return new $(r,i,a)},mt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int32(),a=s(this,o).int32();return new K(r,i,a)},yt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int32();switch(i){case 0:return new v(r);case 3:return new F(r);case 5:return new G(r,s(this,o).bytes(4));case 10:{let a=[];for(;;){let u=s(this,o).cstring();if(u.length===0)return new W(r,a);a.push(u)}}case 11:return new j(r,s(this,o).string(r-8));case 12:return new Q(r,s(this,o).string(r-8));default:throw new Error("Unknown authenticationOk message type "+i)}},Ve=function(t,r,n,i){s(this,o).setBuffer(t,n);let a={},u=s(this,o).string(1);for(;u!=="\0";)a[u]=s(this,o).cstring(),u=s(this,o).string(1);let f=a.M,c=i==="notice"?new te(r,f):new C(f,r,i);return c.severity=a.S,c.code=a.C,c.detail=a.D,c.hint=a.H,c.position=a.P,c.internalPosition=a.p,c.internalQuery=a.q,c.where=a.W,c.schema=a.s,c.table=a.t,c.column=a.c,c.dataType=a.d,c.constraint=a.n,c.file=a.F,c.line=a.L,c.routine=a.R,c};y();var ve=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",se;function ht(){try{return new URL("../release/pglite.wasm",import.meta.url)}catch{throw new Error("Cannot resolve WASM URL. In Cloudflare Workers, you must provide wasmModule option.")}}function Hr(){try{return new URL("../release/pglite.data",import.meta.url)}catch{throw new Error("Cannot resolve fsBundle URL. In Cloudflare Workers, you must provide fsBundle option.")}}async function En(){if(ve||se)return;let e=ht();se=fetch(e)}var ne;async function Cn(e,t){if(t||ne)return{instance:await WebAssembly.instantiate(t||ne,e),module:t||ne};let r=ht();if(ve){let i=await(await import("fs/promises")).readFile(r),{module:a,instance:u}=await WebAssembly.instantiate(i,e);return ne=a,{instance:u,module:a}}else{se||(se=fetch(r));let n=await se,{module:i,instance:a}=await WebAssembly.instantiateStreaming(n,e);return ne=i,{instance:a,module:i}}}async function Pn(){let e=Hr();return ve?(await(await import("fs/promises")).readFile(e)).buffer:(await fetch(e)).arrayBuffer()}var Un=()=>{if(globalThis.crypto?.randomUUID)return globalThis.crypto.randomUUID();let e=new Uint8Array(16);if(globalThis.crypto?.getRandomValues)globalThis.crypto.getRandomValues(e);else for(let r=0;r<e.length;r++)e[r]=Math.floor(Math.random()*256);e[6]=e[6]&15|64,e[8]=e[8]&63|128;let t=[];return e.forEach(r=>{t.push(r.toString(16).padStart(2,"0"))}),t.slice(0,4).join("")+"-"+t.slice(4,6).join("")+"-"+t.slice(6,8).join("")+"-"+t.slice(8,10).join("")+"-"+t.slice(10).join("")};async function Nn(e,t,r,n){if(!r||r.length===0)return t;n=n??e;let i=[];try{await e.execProtocol(O.parse({text:t}),{syncToFs:!1}),i.push(...(await e.execProtocol(O.describe({type:"S"}),{syncToFs:!1})).messages)}finally{i.push(...(await e.execProtocol(O.sync(),{syncToFs:!1})).messages)}let a=Se(i),u=t.replace(/\$([0-9]+)/g,(c,M)=>"%"+M+"L");return(await n.query(`SELECT format($1, ${r.map((c,M)=>`$${M+2}`).join(", ")}) as query`,[u,...r],{paramTypes:[V,...a]})).rows[0].query}function Ln(e){let t,r=!1,n=async()=>{if(!t){r=!1;return}r=!0;let{args:i,resolve:a,reject:u}=t;t=void 0;try{let f=await e(...i);a(f)}catch(f){u(f)}finally{n()}};return async(...i)=>{t&&t.resolve(void 0);let a=new Promise((u,f)=>{t={args:i,resolve:u,reject:f}});return r||n(),a}}function kn(e){let t;return e.startsWith('"')&&e.endsWith('"')?t=e.substring(1,e.length-1):t=e.toLowerCase(),t}export{lr as a,cr as b,Ke as c,yr as d,hr as e,br as f,Se as g,wr as h,O as i,C as j,J as k,Z as l,te as m,Ue as n,ye as o,zr as p,ve as q,En as r,Cn as s,Pn as t,Un as u,Nn as v,Ln as w,kn as x};
2
- //# sourceMappingURL=chunk-FY2WAP66.js.map
1
+ import{b as ae,e as s,f as h,g as d,h as p,i as oe,j as y}from"./chunk-VCBR6USK.js";var hr={};ae(hr,{ABSTIME:()=>Ct,ACLITEM:()=>vt,BIT:()=>jt,BOOL:()=>be,BPCHAR:()=>_e,BYTEA:()=>ge,CHAR:()=>wt,CID:()=>St,CIDR:()=>Et,CIRCLE:()=>Nt,DATE:()=>He,FLOAT4:()=>je,FLOAT8:()=>Qe,GTSVECTOR:()=>sr,INET:()=>Vt,INT2:()=>Fe,INT4:()=>Ge,INT8:()=>we,INTERVAL:()=>Gt,JSON:()=>Ae,JSONB:()=>Ye,MACADDR:()=>Ot,MACADDR8:()=>Lt,MONEY:()=>kt,NUMERIC:()=>_t,OID:()=>We,PATH:()=>Mt,PG_DEPENDENCIES:()=>tr,PG_LSN:()=>Zt,PG_NDISTINCT:()=>er,PG_NODE_TREE:()=>It,POLYGON:()=>Tt,REFCURSOR:()=>zt,REGCLASS:()=>$t,REGCONFIG:()=>ir,REGDICTIONARY:()=>ar,REGNAMESPACE:()=>or,REGOPER:()=>qt,REGOPERATOR:()=>Yt,REGPROC:()=>At,REGPROCEDURE:()=>Ht,REGROLE:()=>ur,REGTYPE:()=>Kt,RELTIME:()=>Pt,SMGR:()=>Rt,TEXT:()=>V,TID:()=>Bt,TIME:()=>Ft,TIMESTAMP:()=>qe,TIMESTAMPTZ:()=>Be,TIMETZ:()=>Wt,TINTERVAL:()=>Ut,TSQUERY:()=>nr,TSVECTOR:()=>rr,TXID_SNAPSHOT:()=>Xt,UUID:()=>Jt,VARBIT:()=>Qt,VARCHAR:()=>ze,XID:()=>xt,XML:()=>Dt,arrayParser:()=>yr,arraySerializer:()=>Ke,parseType:()=>ue,parsers:()=>lr,serializers:()=>cr,types:()=>$e});y();var bt=globalThis.JSON.parse,gt=globalThis.JSON.stringify,be=16,ge=17,wt=18,we=20,Fe=21,Ge=23,At=24,V=25,We=26,Bt=27,xt=28,St=29,Ae=114,Dt=142,It=194,Rt=210,Mt=602,Tt=604,Et=650,je=700,Qe=701,Ct=702,Pt=703,Ut=704,Nt=718,Lt=774,kt=790,Ot=829,Vt=869,vt=1033,_e=1042,ze=1043,He=1082,Ft=1083,qe=1114,Be=1184,Gt=1186,Wt=1266,jt=1560,Qt=1562,_t=1700,zt=1790,Ht=2202,qt=2203,Yt=2204,$t=2205,Kt=2206,Jt=2950,Xt=2970,Zt=3220,er=3361,tr=3402,rr=3614,nr=3615,sr=3642,ir=3734,ar=3769,Ye=3802,or=4089,ur=4096,$e={string:{to:V,from:[V,ze,_e],serialize:e=>{if(typeof e=="string")return e;if(typeof e=="number")return e.toString();throw new Error("Invalid input for string type")},parse:e=>e},number:{to:0,from:[Fe,Ge,We,je,Qe],serialize:e=>e.toString(),parse:e=>+e},bigint:{to:we,from:[we],serialize:e=>e.toString(),parse:e=>{let t=BigInt(e);return t<Number.MIN_SAFE_INTEGER||t>Number.MAX_SAFE_INTEGER?t:Number(t)}},json:{to:Ae,from:[Ae,Ye],serialize:e=>typeof e=="string"?e:gt(e),parse:e=>bt(e)},boolean:{to:be,from:[be],serialize:e=>{if(typeof e!="boolean")throw new Error("Invalid input for boolean type");return e?"t":"f"},parse:e=>e==="t"},date:{to:Be,from:[He,qe,Be],serialize:e=>{if(typeof e=="string")return e;if(typeof e=="number")return new Date(e).toISOString();if(e instanceof Date)return e.toISOString();throw new Error("Invalid input for date type")},parse:e=>new Date(e)},bytea:{to:ge,from:[ge],serialize:e=>{if(!(e instanceof Uint8Array))throw new Error("Invalid input for bytea type");return"\\x"+Array.from(e).map(t=>t.toString(16).padStart(2,"0")).join("")},parse:e=>{let t=e.slice(2);return Uint8Array.from({length:t.length/2},(r,n)=>parseInt(t.substring(n*2,(n+1)*2),16))}}},xe=pr($e),lr=xe.parsers,cr=xe.serializers;function ue(e,t,r){if(e===null)return null;let n=r?.[t]??xe.parsers[t];return n?n(e,t):e}function pr(e){return Object.keys(e).reduce(({parsers:t,serializers:r},n)=>{let{to:i,from:a,serialize:u,parse:f}=e[n];return r[i]=u,r[n]=u,t[n]=f,Array.isArray(a)?a.forEach(c=>{t[c]=f,r[c]=u}):(t[a]=f,r[a]=u),{parsers:t,serializers:r}},{parsers:{},serializers:{}})}var dr=/\\/g,fr=/"/g;function mr(e){return e.replace(dr,"\\\\").replace(fr,'\\"')}function Ke(e,t,r){if(Array.isArray(e)===!1)return e;if(!e.length)return"{}";let n=e[0],i=r===1020?";":",";return Array.isArray(n)?`{${e.map(a=>Ke(a,t,r)).join(i)}}`:`{${e.map(a=>(a===void 0&&(a=null),a===null?"null":'"'+mr(t?t(a):a.toString())+'"')).join(i)}}`}var he={i:0,char:null,str:"",quoted:!1,last:0,p:null};function yr(e,t,r){return he.i=he.last=0,Je(he,e,t,r)[0]}function Je(e,t,r,n){let i=[],a=n===1020?";":",";for(;e.i<t.length;e.i++){if(e.char=t[e.i],e.quoted)e.char==="\\"?e.str+=t[++e.i]:e.char==='"'?(i.push(r?r(e.str):e.str),e.str="",e.quoted=t[e.i+1]==='"',e.last=e.i+2):e.str+=e.char;else if(e.char==='"')e.quoted=!0;else if(e.char==="{")e.last=++e.i,i.push(Je(e,t,r,n));else if(e.char==="}"){e.quoted=!1,e.last<e.i&&i.push(r?r(t.slice(e.last,e.i)):t.slice(e.last,e.i)),e.last=e.i+1;break}else e.char===a&&e.p!=="}"&&e.p!=='"'&&(i.push(r?r(t.slice(e.last,e.i)):t.slice(e.last,e.i)),e.last=e.i+1);e.p=e.char}return e.last<e.i&&i.push(r?r(t.slice(e.last,e.i+1)):t.slice(e.last,e.i+1)),i}var wr={};ae(wr,{parseDescribeStatementResults:()=>Se,parseResults:()=>br});y();function br(e,t,r,n){let i=[],a={rows:[],fields:[]},u=0,f={...t,...r?.parsers};return e.forEach(c=>{switch(c.name){case"rowDescription":{let R=c;a.fields=R.fields.map(E=>({name:E.name,dataTypeID:E.dataTypeID}));break}case"dataRow":{if(!a)break;let R=c;r?.rowMode==="array"?a.rows.push(R.fields.map((E,ie)=>ue(E,a.fields[ie].dataTypeID,f))):a.rows.push(Object.fromEntries(R.fields.map((E,ie)=>[a.fields[ie].name,ue(E,a.fields[ie].dataTypeID,f)])));break}case"commandComplete":{u+=gr(c),i.push({...a,affectedRows:u,...n?{blob:n}:{}}),a={rows:[],fields:[]};break}}}),i.length===0&&i.push({affectedRows:0,rows:[],fields:[]}),i}function gr(e){let t=e.text.split(" ");switch(t[0]){case"INSERT":return parseInt(t[2],10);case"UPDATE":case"DELETE":case"COPY":case"MERGE":return parseInt(t[1],10);default:return 0}}function Se(e){let t=e.find(r=>r.name==="parameterDescription");return t?t.dataTypeIDs:[]}var Ue={};ae(Ue,{AuthenticationCleartextPassword:()=>F,AuthenticationMD5Password:()=>G,AuthenticationOk:()=>v,AuthenticationSASL:()=>W,AuthenticationSASLContinue:()=>j,AuthenticationSASLFinal:()=>Q,BackendKeyDataMessage:()=>K,CommandCompleteMessage:()=>Z,CopyDataMessage:()=>_,CopyResponse:()=>z,DataRowMessage:()=>ee,DatabaseError:()=>C,Field:()=>H,NoticeMessage:()=>te,NotificationResponseMessage:()=>J,ParameterDescriptionMessage:()=>Y,ParameterStatusMessage:()=>$,ReadyForQueryMessage:()=>X,RowDescriptionMessage:()=>q,bindComplete:()=>Ie,closeComplete:()=>Re,copyDone:()=>Pe,emptyQuery:()=>Ce,noData:()=>Me,parseComplete:()=>De,portalSuspended:()=>Te,replicationStart:()=>Ee});y();var De={name:"parseComplete",length:5},Ie={name:"bindComplete",length:5},Re={name:"closeComplete",length:5},Me={name:"noData",length:5},Te={name:"portalSuspended",length:5},Ee={name:"replicationStart",length:4},Ce={name:"emptyQuery",length:4},Pe={name:"copyDone",length:4},v=class{constructor(t){this.length=t;this.name="authenticationOk"}},F=class{constructor(t){this.length=t;this.name="authenticationCleartextPassword"}},G=class{constructor(t,r){this.length=t;this.salt=r;this.name="authenticationMD5Password"}},W=class{constructor(t,r){this.length=t;this.mechanisms=r;this.name="authenticationSASL"}},j=class{constructor(t,r){this.length=t;this.data=r;this.name="authenticationSASLContinue"}},Q=class{constructor(t,r){this.length=t;this.data=r;this.name="authenticationSASLFinal"}},C=class extends Error{constructor(r,n,i){super(r);this.length=n;this.name=i}},_=class{constructor(t,r){this.length=t;this.chunk=r;this.name="copyData"}},z=class{constructor(t,r,n,i){this.length=t;this.name=r;this.binary=n;this.columnTypes=new Array(i)}},H=class{constructor(t,r,n,i,a,u,f){this.name=t;this.tableID=r;this.columnID=n;this.dataTypeID=i;this.dataTypeSize=a;this.dataTypeModifier=u;this.format=f}},q=class{constructor(t,r){this.length=t;this.fieldCount=r;this.name="rowDescription";this.fields=new Array(this.fieldCount)}},Y=class{constructor(t,r){this.length=t;this.parameterCount=r;this.name="parameterDescription";this.dataTypeIDs=new Array(this.parameterCount)}},$=class{constructor(t,r,n){this.length=t;this.parameterName=r;this.parameterValue=n;this.name="parameterStatus"}},K=class{constructor(t,r,n){this.length=t;this.processID=r;this.secretKey=n;this.name="backendKeyData"}},J=class{constructor(t,r,n,i){this.length=t;this.processId=r;this.channel=n;this.payload=i;this.name="notification"}},X=class{constructor(t,r){this.length=t;this.status=r;this.name="readyForQuery"}},Z=class{constructor(t,r){this.length=t;this.text=r;this.name="commandComplete"}},ee=class{constructor(t,r){this.length=t;this.fields=r;this.name="dataRow";this.fieldCount=r.length}},te=class{constructor(t,r){this.length=t;this.message=r;this.name="notice"}};var zr={};ae(zr,{Parser:()=>ye,messages:()=>Ue,serialize:()=>O});y();y();y();y();function P(e){let t=e.length;for(let r=e.length-1;r>=0;r--){let n=e.charCodeAt(r);n>127&&n<=2047?t++:n>2047&&n<=65535&&(t+=2),n>=56320&&n<=57343&&r--}return t}var b,g,N,ce,L,B,le,U,Xe,T=class{constructor(t=256){this.size=t;h(this,B);h(this,b);h(this,g,5);h(this,N,!1);h(this,ce,new TextEncoder);h(this,L,0);d(this,b,p(this,B,le).call(this,t))}addInt32(t){return p(this,B,U).call(this,4),s(this,b).setInt32(s(this,g),t,s(this,N)),d(this,g,s(this,g)+4),this}addInt16(t){return p(this,B,U).call(this,2),s(this,b).setInt16(s(this,g),t,s(this,N)),d(this,g,s(this,g)+2),this}addCString(t){return t&&this.addString(t),p(this,B,U).call(this,1),s(this,b).setUint8(s(this,g),0),oe(this,g)._++,this}addString(t=""){let r=P(t);return p(this,B,U).call(this,r),s(this,ce).encodeInto(t,new Uint8Array(s(this,b).buffer,s(this,g))),d(this,g,s(this,g)+r),this}add(t){return p(this,B,U).call(this,t.byteLength),new Uint8Array(s(this,b).buffer).set(new Uint8Array(t),s(this,g)),d(this,g,s(this,g)+t.byteLength),this}flush(t){let r=p(this,B,Xe).call(this,t);return d(this,g,5),d(this,b,p(this,B,le).call(this,this.size)),new Uint8Array(r)}};b=new WeakMap,g=new WeakMap,N=new WeakMap,ce=new WeakMap,L=new WeakMap,B=new WeakSet,le=function(t){return new DataView(new ArrayBuffer(t))},U=function(t){if(s(this,b).byteLength-s(this,g)<t){let n=s(this,b).buffer,i=n.byteLength+(n.byteLength>>1)+t;d(this,b,p(this,B,le).call(this,i)),new Uint8Array(s(this,b).buffer).set(new Uint8Array(n))}},Xe=function(t){if(t){s(this,b).setUint8(s(this,L),t);let r=s(this,g)-(s(this,L)+1);s(this,b).setInt32(s(this,L)+1,r,s(this,N))}return s(this,b).buffer.slice(t?0:5,s(this,g))};var m=new T,Ar=e=>{m.addInt16(3).addInt16(0);for(let n of Object.keys(e))m.addCString(n).addCString(e[n]);m.addCString("client_encoding").addCString("UTF8");let t=m.addCString("").flush(),r=t.byteLength+4;return new T().addInt32(r).add(t.buffer).flush()},Br=()=>{let e=new DataView(new ArrayBuffer(8));return e.setInt32(0,8,!1),e.setInt32(4,80877103,!1),new Uint8Array(e.buffer)},xr=e=>m.addCString(e).flush(112),Sr=(e,t)=>(m.addCString(e).addInt32(P(t)).addString(t),m.flush(112)),Dr=e=>m.addString(e).flush(112),Ir=e=>m.addCString(e).flush(81),Rr=[],Mr=e=>{let t=e.name??"";t.length>63&&(console.error("Warning! Postgres only supports 63 characters for query names."),console.error("You supplied %s (%s)",t,t.length),console.error("This can cause conflicts and silent errors executing queries"));let r=m.addCString(t).addCString(e.text).addInt16(e.types?.length??0);return e.types?.forEach(n=>r.addInt32(n)),m.flush(80)},k=new T;var Tr=(e,t)=>{for(let r=0;r<e.length;r++){let n=t?t(e[r],r):e[r];if(n===null)m.addInt16(0),k.addInt32(-1);else if(n instanceof ArrayBuffer||ArrayBuffer.isView(n)){let i=ArrayBuffer.isView(n)?n.buffer.slice(n.byteOffset,n.byteOffset+n.byteLength):n;m.addInt16(1),k.addInt32(i.byteLength),k.add(i)}else m.addInt16(0),k.addInt32(P(n)),k.addString(n)}},Er=(e={})=>{let t=e.portal??"",r=e.statement??"",n=e.binary??!1,i=e.values??Rr,a=i.length;return m.addCString(t).addCString(r),m.addInt16(a),Tr(i,e.valueMapper),m.addInt16(a),m.add(k.flush().buffer),m.addInt16(n?1:0),m.flush(66)},Cr=new Uint8Array([69,0,0,0,9,0,0,0,0,0]),Pr=e=>{if(!e||!e.portal&&!e.rows)return Cr;let t=e.portal??"",r=e.rows??0,n=P(t),i=4+n+1+4,a=new DataView(new ArrayBuffer(1+i));return a.setUint8(0,69),a.setInt32(1,i,!1),new TextEncoder().encodeInto(t,new Uint8Array(a.buffer,5)),a.setUint8(n+5,0),a.setUint32(a.byteLength-4,r,!1),new Uint8Array(a.buffer)},Ur=(e,t)=>{let r=new DataView(new ArrayBuffer(16));return r.setInt32(0,16,!1),r.setInt16(4,1234,!1),r.setInt16(6,5678,!1),r.setInt32(8,e,!1),r.setInt32(12,t,!1),new Uint8Array(r.buffer)},Ne=(e,t)=>{let r=new T;return r.addCString(t),r.flush(e)},Nr=m.addCString("P").flush(68),Lr=m.addCString("S").flush(68),kr=e=>e.name?Ne(68,`${e.type}${e.name??""}`):e.type==="P"?Nr:Lr,Or=e=>{let t=`${e.type}${e.name??""}`;return Ne(67,t)},Vr=e=>m.add(e).flush(100),vr=e=>Ne(102,e),pe=e=>new Uint8Array([e,0,0,0,4]),Fr=pe(72),Gr=pe(83),Wr=pe(88),jr=pe(99),O={startup:Ar,password:xr,requestSsl:Br,sendSASLInitialResponseMessage:Sr,sendSCRAMClientFinalMessage:Dr,query:Ir,parse:Mr,bind:Er,execute:Pr,describe:kr,close:Or,flush:()=>Fr,sync:()=>Gr,end:()=>Wr,copyData:Vr,copyDone:()=>jr,copyFail:vr,cancel:Ur};y();y();var Le={text:0,binary:1};y();var Qr=new ArrayBuffer(0),M,w,fe,me,re,de=class{constructor(t=0){h(this,M,new DataView(Qr));h(this,w);h(this,fe,"utf-8");h(this,me,new TextDecoder(s(this,fe)));h(this,re,!1);d(this,w,t)}setBuffer(t,r){d(this,w,t),d(this,M,new DataView(r))}int16(){let t=s(this,M).getInt16(s(this,w),s(this,re));return d(this,w,s(this,w)+2),t}byte(){let t=s(this,M).getUint8(s(this,w));return oe(this,w)._++,t}int32(){let t=s(this,M).getInt32(s(this,w),s(this,re));return d(this,w,s(this,w)+4),t}string(t){return s(this,me).decode(this.bytes(t))}cstring(){let t=s(this,w),r=t;for(;s(this,M).getUint8(r++)!==0;);let n=this.string(r-t-1);return d(this,w,r),n}bytes(t){let r=s(this,M).buffer.slice(s(this,w),s(this,w)+t);return d(this,w,s(this,w)+t),new Uint8Array(r)}};M=new WeakMap,w=new WeakMap,fe=new WeakMap,me=new WeakMap,re=new WeakMap;var ke=1,_r=4,Ze=ke+_r,et=new ArrayBuffer(0);var A,x,S,o,l,tt,rt,nt,st,it,at,ot,Oe,ut,lt,ct,pt,dt,ft,mt,yt,Ve,ye=class{constructor(){h(this,l);h(this,A,new DataView(et));h(this,x,0);h(this,S,0);h(this,o,new de)}parse(t,r){p(this,l,tt).call(this,ArrayBuffer.isView(t)?t.buffer.slice(t.byteOffset,t.byteOffset+t.byteLength):t);let n=s(this,S)+s(this,x),i=s(this,S);for(;i+Ze<=n;){let a=s(this,A).getUint8(i),u=s(this,A).getUint32(i+ke,!1),f=ke+u;if(f+i<=n&&u>0){let c=p(this,l,rt).call(this,i+Ze,a,u,s(this,A).buffer);r(c),i+=f}else break}i===n?(d(this,A,new DataView(et)),d(this,x,0),d(this,S,0)):(d(this,x,n-i),d(this,S,i))}};A=new WeakMap,x=new WeakMap,S=new WeakMap,o=new WeakMap,l=new WeakSet,tt=function(t){if(s(this,x)>0){let r=s(this,x)+t.byteLength;if(r+s(this,S)>s(this,A).byteLength){let i;if(r<=s(this,A).byteLength&&s(this,S)>=s(this,x))i=s(this,A).buffer;else{let a=s(this,A).byteLength*2;for(;r>=a;)a*=2;i=new ArrayBuffer(a)}new Uint8Array(i).set(new Uint8Array(s(this,A).buffer,s(this,S),s(this,x))),d(this,A,new DataView(i)),d(this,S,0)}new Uint8Array(s(this,A).buffer).set(new Uint8Array(t),s(this,S)+s(this,x)),d(this,x,r)}else d(this,A,new DataView(t)),d(this,S,0),d(this,x,t.byteLength)},rt=function(t,r,n,i){switch(r){case 50:return Ie;case 49:return De;case 51:return Re;case 110:return Me;case 115:return Te;case 99:return Pe;case 87:return Ee;case 73:return Ce;case 68:return p(this,l,dt).call(this,t,n,i);case 67:return p(this,l,st).call(this,t,n,i);case 90:return p(this,l,nt).call(this,t,n,i);case 65:return p(this,l,ut).call(this,t,n,i);case 82:return p(this,l,yt).call(this,t,n,i);case 83:return p(this,l,ft).call(this,t,n,i);case 75:return p(this,l,mt).call(this,t,n,i);case 69:return p(this,l,Ve).call(this,t,n,i,"error");case 78:return p(this,l,Ve).call(this,t,n,i,"notice");case 84:return p(this,l,lt).call(this,t,n,i);case 116:return p(this,l,pt).call(this,t,n,i);case 71:return p(this,l,at).call(this,t,n,i);case 72:return p(this,l,ot).call(this,t,n,i);case 100:return p(this,l,it).call(this,t,n,i);default:return new C("received invalid response: "+r.toString(16),n,"error")}},nt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).string(1);return new X(r,i)},st=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).cstring();return new Z(r,i)},it=function(t,r,n){let i=n.slice(t,t+(r-4));return new _(r,new Uint8Array(i))},at=function(t,r,n){return p(this,l,Oe).call(this,t,r,n,"copyInResponse")},ot=function(t,r,n){return p(this,l,Oe).call(this,t,r,n,"copyOutResponse")},Oe=function(t,r,n,i){s(this,o).setBuffer(t,n);let a=s(this,o).byte()!==0,u=s(this,o).int16(),f=new z(r,i,a,u);for(let c=0;c<u;c++)f.columnTypes[c]=s(this,o).int16();return f},ut=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int32(),a=s(this,o).cstring(),u=s(this,o).cstring();return new J(r,i,a,u)},lt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int16(),a=new q(r,i);for(let u=0;u<i;u++)a.fields[u]=p(this,l,ct).call(this);return a},ct=function(){let t=s(this,o).cstring(),r=s(this,o).int32(),n=s(this,o).int16(),i=s(this,o).int32(),a=s(this,o).int16(),u=s(this,o).int32(),f=s(this,o).int16()===0?Le.text:Le.binary;return new H(t,r,n,i,a,u,f)},pt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int16(),a=new Y(r,i);for(let u=0;u<i;u++)a.dataTypeIDs[u]=s(this,o).int32();return a},dt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int16(),a=new Array(i);for(let u=0;u<i;u++){let f=s(this,o).int32();a[u]=f===-1?null:s(this,o).string(f)}return new ee(r,a)},ft=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).cstring(),a=s(this,o).cstring();return new $(r,i,a)},mt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int32(),a=s(this,o).int32();return new K(r,i,a)},yt=function(t,r,n){s(this,o).setBuffer(t,n);let i=s(this,o).int32();switch(i){case 0:return new v(r);case 3:return new F(r);case 5:return new G(r,s(this,o).bytes(4));case 10:{let a=[];for(;;){let u=s(this,o).cstring();if(u.length===0)return new W(r,a);a.push(u)}}case 11:return new j(r,s(this,o).string(r-8));case 12:return new Q(r,s(this,o).string(r-8));default:throw new Error("Unknown authenticationOk message type "+i)}},Ve=function(t,r,n,i){s(this,o).setBuffer(t,n);let a={},u=s(this,o).string(1);for(;u!=="\0";)a[u]=s(this,o).cstring(),u=s(this,o).string(1);let f=a.M,c=i==="notice"?new te(r,f):new C(f,r,i);return c.severity=a.S,c.code=a.C,c.detail=a.D,c.hint=a.H,c.position=a.P,c.internalPosition=a.p,c.internalQuery=a.q,c.where=a.W,c.schema=a.s,c.table=a.t,c.column=a.c,c.dataType=a.d,c.constraint=a.n,c.file=a.F,c.line=a.L,c.routine=a.R,c};y();var ve=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string",se;function ht(){try{return new URL("./pglite.wasm",import.meta.url)}catch{throw new Error("Cannot resolve WASM URL. In Cloudflare Workers, you must provide wasmModule option.")}}function Hr(){try{return new URL("./pglite.data",import.meta.url)}catch{throw new Error("Cannot resolve fsBundle URL. In Cloudflare Workers, you must provide fsBundle option.")}}async function En(){if(ve||se)return;let e=ht();se=fetch(e)}var ne;async function Cn(e,t){if(t||ne)return{instance:await WebAssembly.instantiate(t||ne,e),module:t||ne};let r=ht();if(ve){let i=await(await import("fs/promises")).readFile(r),{module:a,instance:u}=await WebAssembly.instantiate(i,e);return ne=a,{instance:u,module:a}}else{se||(se=fetch(r));let n=await se,{module:i,instance:a}=await WebAssembly.instantiateStreaming(n,e);return ne=i,{instance:a,module:i}}}async function Pn(){let e=Hr();return ve?(await(await import("fs/promises")).readFile(e)).buffer:(await fetch(e)).arrayBuffer()}var Un=()=>{if(globalThis.crypto?.randomUUID)return globalThis.crypto.randomUUID();let e=new Uint8Array(16);if(globalThis.crypto?.getRandomValues)globalThis.crypto.getRandomValues(e);else for(let r=0;r<e.length;r++)e[r]=Math.floor(Math.random()*256);e[6]=e[6]&15|64,e[8]=e[8]&63|128;let t=[];return e.forEach(r=>{t.push(r.toString(16).padStart(2,"0"))}),t.slice(0,4).join("")+"-"+t.slice(4,6).join("")+"-"+t.slice(6,8).join("")+"-"+t.slice(8,10).join("")+"-"+t.slice(10).join("")};async function Nn(e,t,r,n){if(!r||r.length===0)return t;n=n??e;let i=[];try{await e.execProtocol(O.parse({text:t}),{syncToFs:!1}),i.push(...(await e.execProtocol(O.describe({type:"S"}),{syncToFs:!1})).messages)}finally{i.push(...(await e.execProtocol(O.sync(),{syncToFs:!1})).messages)}let a=Se(i),u=t.replace(/\$([0-9]+)/g,(c,R)=>"%"+R+"L");return(await n.query(`SELECT format($1, ${r.map((c,R)=>`$${R+2}`).join(", ")}) as query`,[u,...r],{paramTypes:[V,...a]})).rows[0].query}function Ln(e){let t,r=!1,n=async()=>{if(!t){r=!1;return}r=!0;let{args:i,resolve:a,reject:u}=t;t=void 0;try{let f=await e(...i);a(f)}catch(f){u(f)}finally{n()}};return async(...i)=>{t&&t.resolve(void 0);let a=new Promise((u,f)=>{t={args:i,resolve:u,reject:f}});return r||n(),a}}function kn(e){let t;return e.startsWith('"')&&e.endsWith('"')?t=e.substring(1,e.length-1):t=e.toLowerCase(),t}export{lr as a,cr as b,Ke as c,yr as d,hr as e,br as f,Se as g,wr as h,O as i,C as j,J as k,Z as l,te as m,Ue as n,ye as o,zr as p,ve as q,En as r,Cn as s,Pn as t,Un as u,Nn as v,Ln as w,kn as x};
2
+ //# sourceMappingURL=chunk-5U7S5PTI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/types.ts","../src/parse.ts","../../pg-protocol/src/messages.ts","../../pg-protocol/src/index.ts","../../pg-protocol/src/serializer.ts","../../pg-protocol/src/buffer-writer.ts","../../pg-protocol/src/string-utils.ts","../../pg-protocol/src/parser.ts","../../pg-protocol/src/types.ts","../../pg-protocol/src/buffer-reader.ts","../src/utils.ts"],"sourcesContent":["/*\nBased on postgres.js types.js\nhttps://github.com/porsager/postgres/blob/master/src/types.js\nPublished under the Unlicense:\nhttps://github.com/porsager/postgres/blob/master/UNLICENSE \n*/\n\nimport type { ParserOptions } from './interface.js'\n\nconst JSON_parse = globalThis.JSON.parse\nconst JSON_stringify = globalThis.JSON.stringify\n\nexport const BOOL = 16,\n BYTEA = 17,\n CHAR = 18,\n INT8 = 20,\n INT2 = 21,\n INT4 = 23,\n REGPROC = 24,\n TEXT = 25,\n OID = 26,\n TID = 27,\n XID = 28,\n CID = 29,\n JSON = 114,\n XML = 142,\n PG_NODE_TREE = 194,\n SMGR = 210,\n PATH = 602,\n POLYGON = 604,\n CIDR = 650,\n FLOAT4 = 700,\n FLOAT8 = 701,\n ABSTIME = 702,\n RELTIME = 703,\n TINTERVAL = 704,\n CIRCLE = 718,\n MACADDR8 = 774,\n MONEY = 790,\n MACADDR = 829,\n INET = 869,\n ACLITEM = 1033,\n BPCHAR = 1042,\n VARCHAR = 1043,\n DATE = 1082,\n TIME = 1083,\n TIMESTAMP = 1114,\n TIMESTAMPTZ = 1184,\n INTERVAL = 1186,\n TIMETZ = 1266,\n BIT = 1560,\n VARBIT = 1562,\n NUMERIC = 1700,\n REFCURSOR = 1790,\n REGPROCEDURE = 2202,\n REGOPER = 2203,\n REGOPERATOR = 2204,\n REGCLASS = 2205,\n REGTYPE = 2206,\n UUID = 2950,\n TXID_SNAPSHOT = 2970,\n PG_LSN = 3220,\n PG_NDISTINCT = 3361,\n PG_DEPENDENCIES = 3402,\n TSVECTOR = 3614,\n TSQUERY = 3615,\n GTSVECTOR = 3642,\n REGCONFIG = 3734,\n REGDICTIONARY = 3769,\n JSONB = 3802,\n REGNAMESPACE = 4089,\n REGROLE = 4096\n\nexport const types = {\n string: {\n to: TEXT,\n from: [TEXT, VARCHAR, BPCHAR],\n serialize: (x: string | number) => {\n if (typeof x === 'string') {\n return x\n } else if (typeof x === 'number') {\n return x.toString()\n } else {\n throw new Error('Invalid input for string type')\n }\n },\n parse: (x: string) => x,\n },\n number: {\n to: 0,\n from: [INT2, INT4, OID, FLOAT4, FLOAT8],\n serialize: (x: number) => x.toString(),\n parse: (x: string) => +x,\n },\n bigint: {\n to: INT8,\n from: [INT8],\n serialize: (x: bigint) => x.toString(),\n parse: (x: string) => {\n const n = BigInt(x)\n if (n < Number.MIN_SAFE_INTEGER || n > Number.MAX_SAFE_INTEGER) {\n return n // return BigInt\n } else {\n return Number(n) // in range of standard JS numbers so return number\n }\n },\n },\n json: {\n to: JSON,\n from: [JSON, JSONB],\n serialize: (x: any) => {\n if (typeof x === 'string') {\n return x\n } else {\n return JSON_stringify(x)\n }\n },\n parse: (x: string) => JSON_parse(x),\n },\n boolean: {\n to: BOOL,\n from: [BOOL],\n serialize: (x: boolean) => {\n if (typeof x !== 'boolean') {\n throw new Error('Invalid input for boolean type')\n }\n return x ? 't' : 'f'\n },\n parse: (x: string) => x === 't',\n },\n date: {\n to: TIMESTAMPTZ,\n from: [DATE, TIMESTAMP, TIMESTAMPTZ],\n serialize: (x: Date | string | number) => {\n if (typeof x === 'string') {\n return x\n } else if (typeof x === 'number') {\n return new Date(x).toISOString()\n } else if (x instanceof Date) {\n return x.toISOString()\n } else {\n throw new Error('Invalid input for date type')\n }\n },\n parse: (x: string | number) => new Date(x),\n },\n bytea: {\n to: BYTEA,\n from: [BYTEA],\n serialize: (x: Uint8Array) => {\n if (!(x instanceof Uint8Array)) {\n throw new Error('Invalid input for bytea type')\n }\n return (\n '\\\\x' +\n Array.from(x)\n .map((byte) => byte.toString(16).padStart(2, '0'))\n .join('')\n )\n },\n parse: (x: string): Uint8Array => {\n const hexString = x.slice(2)\n return Uint8Array.from({ length: hexString.length / 2 }, (_, idx) =>\n parseInt(hexString.substring(idx * 2, (idx + 1) * 2), 16),\n )\n },\n },\n} satisfies TypeHandlers\n\nexport type Parser = (x: string, typeId?: number) => any\nexport type Serializer = (x: any) => string\n\nexport type TypeHandler = {\n to: number\n from: number | number[]\n serialize: Serializer\n parse: Parser\n}\n\nexport type TypeHandlers = {\n [key: string]: TypeHandler\n}\n\nconst defaultHandlers = typeHandlers(types)\n\nexport const parsers = defaultHandlers.parsers\nexport const serializers = defaultHandlers.serializers\n\nexport function parseType(\n x: string | null,\n type: number,\n parsers?: ParserOptions,\n): any {\n if (x === null) {\n return null\n }\n const handler = parsers?.[type] ?? defaultHandlers.parsers[type]\n if (handler) {\n return handler(x, type)\n } else {\n return x\n }\n}\n\nfunction typeHandlers(types: TypeHandlers) {\n return Object.keys(types).reduce(\n ({ parsers, serializers }, k) => {\n const { to, from, serialize, parse } = types[k]\n serializers[to] = serialize\n serializers[k] = serialize\n parsers[k] = parse\n if (Array.isArray(from)) {\n from.forEach((f) => {\n parsers[f] = parse\n serializers[f] = serialize\n })\n } else {\n parsers[from] = parse\n serializers[from] = serialize\n }\n return { parsers, serializers }\n },\n {\n parsers: {} as {\n [key: number | string]: (x: string, typeId?: number) => any\n },\n serializers: {} as {\n [key: number | string]: Serializer\n },\n },\n )\n}\n\nconst escapeBackslash = /\\\\/g\nconst escapeQuote = /\"/g\n\nfunction arrayEscape(x: string) {\n return x.replace(escapeBackslash, '\\\\\\\\').replace(escapeQuote, '\\\\\"')\n}\n\nexport function arraySerializer(\n xs: any,\n serializer: Serializer | undefined,\n typarray: number,\n): string {\n if (Array.isArray(xs) === false) return xs\n\n if (!xs.length) return '{}'\n\n const first = xs[0]\n // Only _box (1020) has the ';' delimiter for arrays, all other types use the ',' delimiter\n const delimiter = typarray === 1020 ? ';' : ','\n\n if (Array.isArray(first)) {\n return `{${xs.map((x) => arraySerializer(x, serializer, typarray)).join(delimiter)}}`\n } else {\n return `{${xs\n .map((x) => {\n if (x === undefined) {\n x = null\n // TODO: Add an option to specify how to handle undefined values\n }\n return x === null\n ? 'null'\n : '\"' + arrayEscape(serializer ? serializer(x) : x.toString()) + '\"'\n })\n .join(delimiter)}}`\n }\n}\n\nconst arrayParserState = {\n i: 0,\n char: null as string | null,\n str: '',\n quoted: false,\n last: 0,\n p: null as string | null,\n}\n\nexport function arrayParser(x: string, parser: Parser, typarray: number) {\n arrayParserState.i = arrayParserState.last = 0\n return arrayParserLoop(arrayParserState, x, parser, typarray)[0]\n}\n\nfunction arrayParserLoop(\n s: typeof arrayParserState,\n x: string,\n parser: Parser | undefined,\n typarray: number,\n): any[] {\n const xs = []\n // Only _box (1020) has the ';' delimiter for arrays, all other types use the ',' delimiter\n const delimiter = typarray === 1020 ? ';' : ','\n for (; s.i < x.length; s.i++) {\n s.char = x[s.i]\n if (s.quoted) {\n if (s.char === '\\\\') {\n s.str += x[++s.i]\n } else if (s.char === '\"') {\n xs.push(parser ? parser(s.str) : s.str)\n s.str = ''\n s.quoted = x[s.i + 1] === '\"'\n s.last = s.i + 2\n } else {\n s.str += s.char\n }\n } else if (s.char === '\"') {\n s.quoted = true\n } else if (s.char === '{') {\n s.last = ++s.i\n xs.push(arrayParserLoop(s, x, parser, typarray))\n } else if (s.char === '}') {\n s.quoted = false\n s.last < s.i &&\n xs.push(parser ? parser(x.slice(s.last, s.i)) : x.slice(s.last, s.i))\n s.last = s.i + 1\n break\n } else if (s.char === delimiter && s.p !== '}' && s.p !== '\"') {\n xs.push(parser ? parser(x.slice(s.last, s.i)) : x.slice(s.last, s.i))\n s.last = s.i + 1\n }\n s.p = s.char\n }\n s.last < s.i &&\n xs.push(\n parser ? parser(x.slice(s.last, s.i + 1)) : x.slice(s.last, s.i + 1),\n )\n return xs\n}\n","import {\n BackendMessage,\n RowDescriptionMessage,\n DataRowMessage,\n CommandCompleteMessage,\n ParameterDescriptionMessage,\n} from '@electric-sql/pg-protocol/messages'\nimport type { Results, QueryOptions, Row } from './interface.js'\nimport { parseType, type Parser } from './types.js'\n\n/**\n * This function is used to parse the results of either a simple or extended query.\n * https://www.postgresql.org/docs/current/protocol-flow.html#PROTOCOL-FLOW-SIMPLE-QUERY\n */\nexport function parseResults(\n messages: Array<BackendMessage>,\n defaultParsers: Record<number | string, Parser>,\n options?: QueryOptions,\n blob?: Blob,\n): Array<Results> {\n const resultSets: Results[] = []\n let currentResultSet: Results = { rows: [], fields: [] }\n let affectedRows = 0\n const parsers = { ...defaultParsers, ...options?.parsers }\n\n messages.forEach((message) => {\n switch (message.name) {\n case 'rowDescription': {\n const msg = message as RowDescriptionMessage\n currentResultSet.fields = msg.fields.map((field) => ({\n name: field.name,\n dataTypeID: field.dataTypeID,\n }))\n break\n }\n case 'dataRow': {\n if (!currentResultSet) break\n const msg = message as DataRowMessage\n if (options?.rowMode === 'array') {\n // In array mode, rows contain arrays instead of objects\n // Type assertion needed because Row type defaults to object\n currentResultSet.rows.push(\n msg.fields.map((field, i) =>\n parseType(field, currentResultSet!.fields[i].dataTypeID, parsers),\n ) as unknown as Row,\n )\n } else {\n // rowMode === \"object\"\n currentResultSet.rows.push(\n Object.fromEntries(\n msg.fields.map((field, i) => [\n currentResultSet!.fields[i].name,\n parseType(\n field,\n currentResultSet!.fields[i].dataTypeID,\n parsers,\n ),\n ]),\n ),\n )\n }\n break\n }\n case 'commandComplete': {\n const msg = message as CommandCompleteMessage\n affectedRows += retrieveRowCount(msg)\n\n resultSets.push({\n ...currentResultSet,\n affectedRows,\n ...(blob ? { blob } : {}),\n })\n\n currentResultSet = { rows: [], fields: [] }\n break\n }\n }\n })\n\n if (resultSets.length === 0) {\n resultSets.push({\n affectedRows: 0,\n rows: [],\n fields: [],\n })\n }\n\n return resultSets\n}\n\nfunction retrieveRowCount(msg: CommandCompleteMessage): number {\n const parts = msg.text.split(' ')\n switch (parts[0]) {\n case 'INSERT':\n return parseInt(parts[2], 10)\n case 'UPDATE':\n case 'DELETE':\n case 'COPY':\n case 'MERGE':\n return parseInt(parts[1], 10)\n default:\n return 0\n }\n}\n\n/** Get the dataTypeIDs from a list of messages, if it's available. */\nexport function parseDescribeStatementResults(\n messages: Array<BackendMessage>,\n): number[] {\n const message = messages.find(\n (msg): msg is ParameterDescriptionMessage =>\n msg.name === 'parameterDescription',\n )\n\n if (message) {\n return message.dataTypeIDs\n }\n\n return []\n}\n","import { Mode } from './types'\n\nexport type MessageName =\n | 'parseComplete'\n | 'bindComplete'\n | 'closeComplete'\n | 'noData'\n | 'portalSuspended'\n | 'replicationStart'\n | 'emptyQuery'\n | 'copyDone'\n | 'copyData'\n | 'rowDescription'\n | 'parameterDescription'\n | 'parameterStatus'\n | 'backendKeyData'\n | 'notification'\n | 'readyForQuery'\n | 'commandComplete'\n | 'dataRow'\n | 'copyInResponse'\n | 'copyOutResponse'\n | 'authenticationOk'\n | 'authenticationMD5Password'\n | 'authenticationCleartextPassword'\n | 'authenticationSASL'\n | 'authenticationSASLContinue'\n | 'authenticationSASLFinal'\n | 'error'\n | 'notice'\n\nexport type BackendMessage = {\n name: MessageName\n length: number\n}\n\nexport const parseComplete: BackendMessage = {\n name: 'parseComplete',\n length: 5,\n}\n\nexport const bindComplete: BackendMessage = {\n name: 'bindComplete',\n length: 5,\n}\n\nexport const closeComplete: BackendMessage = {\n name: 'closeComplete',\n length: 5,\n}\n\nexport const noData: BackendMessage = {\n name: 'noData',\n length: 5,\n}\n\nexport const portalSuspended: BackendMessage = {\n name: 'portalSuspended',\n length: 5,\n}\n\nexport const replicationStart: BackendMessage = {\n name: 'replicationStart',\n length: 4,\n}\n\nexport const emptyQuery: BackendMessage = {\n name: 'emptyQuery',\n length: 4,\n}\n\nexport const copyDone: BackendMessage = {\n name: 'copyDone',\n length: 4,\n}\n\nexport class AuthenticationOk implements BackendMessage {\n public readonly name = 'authenticationOk'\n constructor(public readonly length: number) {}\n}\n\nexport class AuthenticationCleartextPassword implements BackendMessage {\n public readonly name = 'authenticationCleartextPassword'\n constructor(public readonly length: number) {}\n}\n\nexport class AuthenticationMD5Password implements BackendMessage {\n public readonly name = 'authenticationMD5Password'\n constructor(\n public readonly length: number,\n public readonly salt: Uint8Array,\n ) {}\n}\n\nexport class AuthenticationSASL implements BackendMessage {\n public readonly name = 'authenticationSASL'\n constructor(\n public readonly length: number,\n public readonly mechanisms: string[],\n ) {}\n}\n\nexport class AuthenticationSASLContinue implements BackendMessage {\n public readonly name = 'authenticationSASLContinue'\n constructor(\n public readonly length: number,\n public readonly data: string,\n ) {}\n}\n\nexport class AuthenticationSASLFinal implements BackendMessage {\n public readonly name = 'authenticationSASLFinal'\n constructor(\n public readonly length: number,\n public readonly data: string,\n ) {}\n}\n\nexport type AuthenticationMessage =\n | AuthenticationOk\n | AuthenticationCleartextPassword\n | AuthenticationMD5Password\n | AuthenticationSASL\n | AuthenticationSASLContinue\n | AuthenticationSASLFinal\n\ninterface NoticeOrError {\n message: string | undefined\n severity: string | undefined\n code: string | undefined\n detail: string | undefined\n hint: string | undefined\n position: string | undefined\n internalPosition: string | undefined\n internalQuery: string | undefined\n where: string | undefined\n schema: string | undefined\n table: string | undefined\n column: string | undefined\n dataType: string | undefined\n constraint: string | undefined\n file: string | undefined\n line: string | undefined\n routine: string | undefined\n}\n\nexport class DatabaseError extends Error implements NoticeOrError {\n public severity: string | undefined\n public code: string | undefined\n public detail: string | undefined\n public hint: string | undefined\n public position: string | undefined\n public internalPosition: string | undefined\n public internalQuery: string | undefined\n public where: string | undefined\n public schema: string | undefined\n public table: string | undefined\n public column: string | undefined\n public dataType: string | undefined\n public constraint: string | undefined\n public file: string | undefined\n public line: string | undefined\n public routine: string | undefined\n constructor(\n message: string,\n public readonly length: number,\n public readonly name: MessageName,\n ) {\n super(message)\n }\n}\n\nexport class CopyDataMessage implements BackendMessage {\n public readonly name = 'copyData'\n constructor(\n public readonly length: number,\n public readonly chunk: Uint8Array,\n ) {}\n}\n\nexport class CopyResponse implements BackendMessage {\n public readonly columnTypes: number[]\n constructor(\n public readonly length: number,\n public readonly name: MessageName,\n public readonly binary: boolean,\n columnCount: number,\n ) {\n this.columnTypes = new Array(columnCount)\n }\n}\n\nexport class Field {\n constructor(\n public readonly name: string,\n public readonly tableID: number,\n public readonly columnID: number,\n public readonly dataTypeID: number,\n public readonly dataTypeSize: number,\n public readonly dataTypeModifier: number,\n public readonly format: Mode,\n ) {}\n}\n\nexport class RowDescriptionMessage implements BackendMessage {\n public readonly name: MessageName = 'rowDescription'\n public readonly fields: Field[]\n constructor(\n public readonly length: number,\n public readonly fieldCount: number,\n ) {\n this.fields = new Array(this.fieldCount)\n }\n}\n\nexport class ParameterDescriptionMessage implements BackendMessage {\n public readonly name: MessageName = 'parameterDescription'\n public readonly dataTypeIDs: number[]\n constructor(\n public readonly length: number,\n public readonly parameterCount: number,\n ) {\n this.dataTypeIDs = new Array(this.parameterCount)\n }\n}\n\nexport class ParameterStatusMessage implements BackendMessage {\n public readonly name: MessageName = 'parameterStatus'\n constructor(\n public readonly length: number,\n public readonly parameterName: string,\n public readonly parameterValue: string,\n ) {}\n}\n\nexport class BackendKeyDataMessage implements BackendMessage {\n public readonly name: MessageName = 'backendKeyData'\n constructor(\n public readonly length: number,\n public readonly processID: number,\n public readonly secretKey: number,\n ) {}\n}\n\nexport class NotificationResponseMessage implements BackendMessage {\n public readonly name: MessageName = 'notification'\n constructor(\n public readonly length: number,\n public readonly processId: number,\n public readonly channel: string,\n public readonly payload: string,\n ) {}\n}\n\nexport class ReadyForQueryMessage implements BackendMessage {\n public readonly name: MessageName = 'readyForQuery'\n constructor(\n public readonly length: number,\n public readonly status: string,\n ) {}\n}\n\nexport class CommandCompleteMessage implements BackendMessage {\n public readonly name: MessageName = 'commandComplete'\n constructor(\n public readonly length: number,\n public readonly text: string,\n ) {}\n}\n\nexport class DataRowMessage implements BackendMessage {\n public readonly fieldCount: number\n public readonly name: MessageName = 'dataRow'\n constructor(\n public length: number,\n public fields: (string | null)[],\n ) {\n this.fieldCount = fields.length\n }\n}\n\nexport class NoticeMessage implements BackendMessage, NoticeOrError {\n constructor(\n public readonly length: number,\n public readonly message: string | undefined,\n ) {}\n public readonly name = 'notice'\n public severity: string | undefined\n public code: string | undefined\n public detail: string | undefined\n public hint: string | undefined\n public position: string | undefined\n public internalPosition: string | undefined\n public internalQuery: string | undefined\n public where: string | undefined\n public schema: string | undefined\n public table: string | undefined\n public column: string | undefined\n public dataType: string | undefined\n public constraint: string | undefined\n public file: string | undefined\n public line: string | undefined\n public routine: string | undefined\n}\n","export { serialize } from './serializer'\nexport { Parser } from './parser'\nexport * as messages from './messages'\n","import { Writer } from './buffer-writer'\nimport { byteLengthUtf8 } from './string-utils'\n\nconst enum code {\n startup = 0x70,\n query = 0x51,\n parse = 0x50,\n bind = 0x42,\n execute = 0x45,\n flush = 0x48,\n sync = 0x53,\n end = 0x58,\n close = 0x43,\n describe = 0x44,\n copyFromChunk = 0x64,\n copyDone = 0x63,\n copyFail = 0x66,\n}\n\ntype LegalValue = string | ArrayBuffer | ArrayBufferView | null\n\nconst writer = new Writer()\n\nconst startup = (opts: Record<string, string>): Uint8Array => {\n // protocol version\n writer.addInt16(3).addInt16(0)\n for (const key of Object.keys(opts)) {\n writer.addCString(key).addCString(opts[key])\n }\n\n writer.addCString('client_encoding').addCString('UTF8')\n\n const bodyBuffer = writer.addCString('').flush()\n // this message is sent without a code\n\n const length = bodyBuffer.byteLength + 4\n\n return new Writer().addInt32(length).add(bodyBuffer.buffer as ArrayBuffer).flush()\n}\n\nconst requestSsl = (): Uint8Array => {\n const bufferView = new DataView(new ArrayBuffer(8))\n bufferView.setInt32(0, 8, false)\n bufferView.setInt32(4, 80877103, false)\n return new Uint8Array(bufferView.buffer)\n}\n\nconst password = (password: string): Uint8Array => {\n return writer.addCString(password).flush(code.startup)\n}\n\nconst sendSASLInitialResponseMessage = (\n mechanism: string,\n initialResponse: string,\n): Uint8Array => {\n // 0x70 = 'p'\n writer\n .addCString(mechanism)\n .addInt32(byteLengthUtf8(initialResponse))\n .addString(initialResponse)\n\n return writer.flush(code.startup)\n}\n\nconst sendSCRAMClientFinalMessage = (additionalData: string): Uint8Array => {\n return writer.addString(additionalData).flush(code.startup)\n}\n\nconst query = (text: string): Uint8Array => {\n return writer.addCString(text).flush(code.query)\n}\n\ntype ParseOpts = {\n name?: string\n types?: number[]\n text: string\n}\n\nconst emptyValueArray: LegalValue[] = []\n\nconst parse = (query: ParseOpts): Uint8Array => {\n // expect something like this:\n // { name: 'queryName',\n // text: 'select * from blah',\n // types: ['int8', 'bool'] }\n\n // normalize missing query names to allow for null\n const name = query.name ?? ''\n if (name.length > 63) {\n /* eslint-disable no-console */\n console.error(\n 'Warning! Postgres only supports 63 characters for query names.',\n )\n console.error('You supplied %s (%s)', name, name.length)\n console.error(\n 'This can cause conflicts and silent errors executing queries',\n )\n /* eslint-enable no-console */\n }\n\n const buffer = writer\n .addCString(name) // name of query\n .addCString(query.text) // actual query text\n .addInt16(query.types?.length ?? 0)\n\n query.types?.forEach((type) => buffer.addInt32(type))\n\n return writer.flush(code.parse)\n}\n\ntype ValueMapper = (param: unknown, index: number) => LegalValue\n\ntype BindOpts = {\n portal?: string\n binary?: boolean\n statement?: string\n values?: LegalValue[]\n // optional map from JS value to postgres value per parameter\n valueMapper?: ValueMapper\n}\n\nconst paramWriter = new Writer()\n\n// make this a const enum so typescript will inline the value\nconst enum ParamType {\n STRING = 0,\n BINARY = 1,\n}\n\nconst writeValues = (values: LegalValue[], valueMapper?: ValueMapper): void => {\n for (let i = 0; i < values.length; i++) {\n const mappedVal = valueMapper ? valueMapper(values[i], i) : values[i]\n if (mappedVal === null) {\n // add the param type (string) to the writer\n writer.addInt16(ParamType.STRING)\n // write -1 to the param writer to indicate null\n paramWriter.addInt32(-1)\n } else if (\n mappedVal instanceof ArrayBuffer ||\n ArrayBuffer.isView(mappedVal)\n ) {\n const buffer = ArrayBuffer.isView(mappedVal)\n ? (mappedVal.buffer.slice(\n mappedVal.byteOffset,\n mappedVal.byteOffset + mappedVal.byteLength,\n ) as ArrayBuffer)\n : mappedVal\n // add the param type (binary) to the writer\n writer.addInt16(ParamType.BINARY)\n // add the buffer to the param writer\n paramWriter.addInt32(buffer.byteLength)\n paramWriter.add(buffer)\n } else {\n // add the param type (string) to the writer\n writer.addInt16(ParamType.STRING)\n paramWriter.addInt32(byteLengthUtf8(mappedVal))\n paramWriter.addString(mappedVal)\n }\n }\n}\n\nconst bind = (config: BindOpts = {}): Uint8Array => {\n // normalize config\n const portal = config.portal ?? ''\n const statement = config.statement ?? ''\n const binary = config.binary ?? false\n const values = config.values ?? emptyValueArray\n const len = values.length\n\n writer.addCString(portal).addCString(statement)\n writer.addInt16(len)\n\n writeValues(values, config.valueMapper)\n\n writer.addInt16(len)\n writer.add(paramWriter.flush().buffer as ArrayBuffer)\n\n // format code\n writer.addInt16(binary ? ParamType.BINARY : ParamType.STRING)\n return writer.flush(code.bind)\n}\n\ntype ExecOpts = {\n portal?: string\n rows?: number\n}\n\nconst emptyExecute = new Uint8Array([\n code.execute,\n 0x00,\n 0x00,\n 0x00,\n 0x09,\n 0x00,\n 0x00,\n 0x00,\n 0x00,\n 0x00,\n])\n\nconst execute = (config?: ExecOpts): Uint8Array => {\n // this is the happy path for most queries\n if (!config || (!config.portal && !config.rows)) {\n return emptyExecute\n }\n\n const portal = config.portal ?? ''\n const rows = config.rows ?? 0\n\n const portalLength = byteLengthUtf8(portal)\n const len = 4 + portalLength + 1 + 4\n // one extra bit for code\n const bufferView = new DataView(new ArrayBuffer(1 + len))\n bufferView.setUint8(0, code.execute)\n bufferView.setInt32(1, len, false)\n new TextEncoder().encodeInto(portal, new Uint8Array(bufferView.buffer, 5))\n bufferView.setUint8(portalLength + 5, 0) // null terminate portal cString\n bufferView.setUint32(bufferView.byteLength - 4, rows, false)\n return new Uint8Array(bufferView.buffer)\n}\n\nconst cancel = (processID: number, secretKey: number): Uint8Array => {\n const bufferView = new DataView(new ArrayBuffer(16))\n bufferView.setInt32(0, 16, false)\n bufferView.setInt16(4, 1234, false)\n bufferView.setInt16(6, 5678, false)\n bufferView.setInt32(8, processID, false)\n bufferView.setInt32(12, secretKey, false)\n return new Uint8Array(bufferView.buffer)\n}\n\ntype PortalOpts = {\n type: 'S' | 'P'\n name?: string\n}\n\nconst cstringMessage = (code: code, string: string): Uint8Array => {\n const writer = new Writer()\n writer.addCString(string)\n return writer.flush(code)\n}\n\nconst emptyDescribePortal = writer.addCString('P').flush(code.describe)\nconst emptyDescribeStatement = writer.addCString('S').flush(code.describe)\n\nconst describe = (msg: PortalOpts): Uint8Array => {\n return msg.name\n ? cstringMessage(code.describe, `${msg.type}${msg.name ?? ''}`)\n : msg.type === 'P'\n ? emptyDescribePortal\n : emptyDescribeStatement\n}\n\nconst close = (msg: PortalOpts): Uint8Array => {\n const text = `${msg.type}${msg.name ?? ''}`\n return cstringMessage(code.close, text)\n}\n\nconst copyData = (chunk: ArrayBuffer): Uint8Array => {\n return writer.add(chunk).flush(code.copyFromChunk)\n}\n\nconst copyFail = (message: string): Uint8Array => {\n return cstringMessage(code.copyFail, message)\n}\n\nconst codeOnlyBuffer = (code: code): Uint8Array =>\n new Uint8Array([code, 0x00, 0x00, 0x00, 0x04])\n\nconst flushBuffer = codeOnlyBuffer(code.flush)\nconst syncBuffer = codeOnlyBuffer(code.sync)\nconst endBuffer = codeOnlyBuffer(code.end)\nconst copyDoneBuffer = codeOnlyBuffer(code.copyDone)\n\nconst serialize = {\n startup,\n password,\n requestSsl,\n sendSASLInitialResponseMessage,\n sendSCRAMClientFinalMessage,\n query,\n parse,\n bind,\n execute,\n describe,\n close,\n flush: () => flushBuffer,\n sync: () => syncBuffer,\n end: () => endBuffer,\n copyData,\n copyDone: () => copyDoneBuffer,\n copyFail,\n cancel,\n}\n\nexport { serialize }\n","import { byteLengthUtf8 } from './string-utils'\n\nexport class Writer {\n #bufferView: DataView\n #offset: number = 5\n\n readonly #littleEndian = false as const\n readonly #encoder = new TextEncoder()\n readonly #headerPosition: number = 0\n constructor(private size = 256) {\n this.#bufferView = this.#allocateBuffer(size)\n }\n\n #allocateBuffer(size: number): DataView {\n return new DataView(new ArrayBuffer(size))\n }\n\n #ensure(size: number): void {\n const remaining = this.#bufferView.byteLength - this.#offset\n if (remaining < size) {\n const oldBuffer = this.#bufferView.buffer\n // exponential growth factor of around ~ 1.5\n // https://stackoverflow.com/questions/2269063/buffer-growth-strategy\n const newSize = oldBuffer.byteLength + (oldBuffer.byteLength >> 1) + size\n this.#bufferView = this.#allocateBuffer(newSize)\n new Uint8Array(this.#bufferView.buffer).set(new Uint8Array(oldBuffer))\n }\n }\n\n public addInt32(num: number): Writer {\n this.#ensure(4)\n this.#bufferView.setInt32(this.#offset, num, this.#littleEndian)\n this.#offset += 4\n return this\n }\n\n public addInt16(num: number): Writer {\n this.#ensure(2)\n this.#bufferView.setInt16(this.#offset, num, this.#littleEndian)\n this.#offset += 2\n return this\n }\n\n public addCString(string: string): Writer {\n if (string) {\n // TODO(msfstef): might be faster to extract `addString` code and\n // ensure length + 1 once rather than length and then +1?\n this.addString(string)\n }\n\n // set null terminator\n this.#ensure(1)\n this.#bufferView.setUint8(this.#offset, 0)\n this.#offset++\n return this\n }\n\n public addString(string: string = ''): Writer {\n const length = byteLengthUtf8(string)\n this.#ensure(length)\n this.#encoder.encodeInto(\n string,\n new Uint8Array(this.#bufferView.buffer, this.#offset),\n )\n this.#offset += length\n return this\n }\n\n public add(otherBuffer: ArrayBuffer): Writer {\n this.#ensure(otherBuffer.byteLength)\n new Uint8Array(this.#bufferView.buffer).set(\n new Uint8Array(otherBuffer),\n this.#offset,\n )\n\n this.#offset += otherBuffer.byteLength\n return this\n }\n\n #join(code?: number): ArrayBuffer {\n if (code) {\n this.#bufferView.setUint8(this.#headerPosition, code)\n // length is everything in this packet minus the code\n const length = this.#offset - (this.#headerPosition + 1)\n this.#bufferView.setInt32(\n this.#headerPosition + 1,\n length,\n this.#littleEndian,\n )\n }\n return this.#bufferView.buffer.slice(code ? 0 : 5, this.#offset) as ArrayBuffer\n }\n\n public flush(code?: number): Uint8Array {\n const result = this.#join(code)\n this.#offset = 5\n this.#bufferView = this.#allocateBuffer(this.size)\n return new Uint8Array(result)\n }\n}\n","/**\n * Calculates the byte length of a UTF-8 encoded string\n * Adapted from https://stackoverflow.com/a/23329386\n * @param str - UTF-8 encoded string\n * @returns byte length of string\n */\nfunction byteLengthUtf8(str: string): number {\n let byteLength = str.length\n for (let i = str.length - 1; i >= 0; i--) {\n const code = str.charCodeAt(i)\n if (code > 0x7f && code <= 0x7ff) byteLength++\n else if (code > 0x7ff && code <= 0xffff) byteLength += 2\n if (code >= 0xdc00 && code <= 0xdfff) i-- // trail surrogate\n }\n return byteLength\n}\n\nexport { byteLengthUtf8 }\n","import {\n bindComplete,\n parseComplete,\n closeComplete,\n noData,\n portalSuspended,\n copyDone,\n replicationStart,\n emptyQuery,\n ReadyForQueryMessage,\n CommandCompleteMessage,\n CopyDataMessage,\n CopyResponse,\n NotificationResponseMessage,\n RowDescriptionMessage,\n ParameterDescriptionMessage,\n Field,\n DataRowMessage,\n ParameterStatusMessage,\n BackendKeyDataMessage,\n DatabaseError,\n BackendMessage,\n MessageName,\n NoticeMessage,\n AuthenticationMessage,\n AuthenticationOk,\n AuthenticationCleartextPassword,\n AuthenticationMD5Password,\n AuthenticationSASL,\n AuthenticationSASLContinue,\n AuthenticationSASLFinal,\n} from './messages'\nimport { BufferParameter, Modes } from './types'\nimport { BufferReader } from './buffer-reader'\n\n// every message is prefixed with a single bye\nconst CODE_LENGTH = 1 as const\n// every message has an int32 length which includes itself but does\n// NOT include the code in the length\nconst LEN_LENGTH = 4 as const\n\nconst HEADER_LENGTH = CODE_LENGTH + LEN_LENGTH\n\nexport type Packet = {\n code: number\n packet: ArrayBuffer\n}\n\nconst emptyBuffer = new ArrayBuffer(0)\n\nconst enum MessageCodes {\n DataRow = 0x44, // D\n ParseComplete = 0x31, // 1\n BindComplete = 0x32, // 2\n CloseComplete = 0x33, // 3\n CommandComplete = 0x43, // C\n ReadyForQuery = 0x5a, // Z\n NoData = 0x6e, // n\n NotificationResponse = 0x41, // A\n AuthenticationResponse = 0x52, // R\n ParameterStatus = 0x53, // S\n BackendKeyData = 0x4b, // K\n ErrorMessage = 0x45, // E\n NoticeMessage = 0x4e, // N\n RowDescriptionMessage = 0x54, // T\n ParameterDescriptionMessage = 0x74, // t\n PortalSuspended = 0x73, // s\n ReplicationStart = 0x57, // W\n EmptyQuery = 0x49, // I\n CopyIn = 0x47, // G\n CopyOut = 0x48, // H\n CopyDone = 0x63, // c\n CopyData = 0x64, // d\n}\n\nexport type MessageCallback = (msg: BackendMessage) => void\n\nexport class Parser {\n #bufferView: DataView = new DataView(emptyBuffer)\n #bufferRemainingLength: number = 0\n #bufferOffset: number = 0\n #reader = new BufferReader()\n\n public parse(buffer: BufferParameter, callback: MessageCallback) {\n this.#mergeBuffer(\n ArrayBuffer.isView(buffer)\n ? (buffer.buffer.slice(\n buffer.byteOffset,\n buffer.byteOffset + buffer.byteLength,\n ) as ArrayBuffer)\n : buffer,\n )\n const bufferFullLength = this.#bufferOffset + this.#bufferRemainingLength\n let offset = this.#bufferOffset\n while (offset + HEADER_LENGTH <= bufferFullLength) {\n // code is 1 byte long - it identifies the message type\n const code = this.#bufferView.getUint8(offset)\n // length is 1 Uint32BE - it is the length of the message EXCLUDING the code\n const length = this.#bufferView.getUint32(offset + CODE_LENGTH, false)\n const fullMessageLength = CODE_LENGTH + length\n if (fullMessageLength + offset <= bufferFullLength && length > 0) {\n const message = this.#handlePacket(\n offset + HEADER_LENGTH,\n code,\n length,\n this.#bufferView.buffer as ArrayBuffer,\n )\n callback(message)\n offset += fullMessageLength\n } else {\n break\n }\n }\n if (offset === bufferFullLength) {\n // No more use for the buffer\n this.#bufferView = new DataView(emptyBuffer)\n this.#bufferRemainingLength = 0\n this.#bufferOffset = 0\n } else {\n // Adjust the cursors of remainingBuffer\n this.#bufferRemainingLength = bufferFullLength - offset\n this.#bufferOffset = offset\n }\n }\n\n #mergeBuffer(buffer: ArrayBuffer): void {\n if (this.#bufferRemainingLength > 0) {\n const newLength = this.#bufferRemainingLength + buffer.byteLength\n const newFullLength = newLength + this.#bufferOffset\n if (newFullLength > this.#bufferView.byteLength) {\n // We can't concat the new buffer with the remaining one\n let newBuffer: ArrayBuffer\n if (\n newLength <= this.#bufferView.byteLength &&\n this.#bufferOffset >= this.#bufferRemainingLength\n ) {\n // We can move the relevant part to the beginning of the buffer instead of allocating a new buffer\n newBuffer = this.#bufferView.buffer as ArrayBuffer\n } else {\n // Allocate a new larger buffer\n let newBufferLength = this.#bufferView.byteLength * 2\n while (newLength >= newBufferLength) {\n newBufferLength *= 2\n }\n newBuffer = new ArrayBuffer(newBufferLength)\n }\n // Move the remaining buffer to the new one\n new Uint8Array(newBuffer).set(\n new Uint8Array(\n this.#bufferView.buffer,\n this.#bufferOffset,\n this.#bufferRemainingLength,\n ),\n )\n this.#bufferView = new DataView(newBuffer)\n this.#bufferOffset = 0\n }\n\n // Concat the new buffer with the remaining one\n new Uint8Array(this.#bufferView.buffer).set(\n new Uint8Array(buffer),\n this.#bufferOffset + this.#bufferRemainingLength,\n )\n this.#bufferRemainingLength = newLength\n } else {\n this.#bufferView = new DataView(buffer)\n this.#bufferOffset = 0\n this.#bufferRemainingLength = buffer.byteLength\n }\n }\n\n #handlePacket(\n offset: number,\n code: number,\n length: number,\n bytes: ArrayBuffer,\n ): BackendMessage {\n switch (code) {\n case MessageCodes.BindComplete:\n return bindComplete\n case MessageCodes.ParseComplete:\n return parseComplete\n case MessageCodes.CloseComplete:\n return closeComplete\n case MessageCodes.NoData:\n return noData\n case MessageCodes.PortalSuspended:\n return portalSuspended\n case MessageCodes.CopyDone:\n return copyDone\n case MessageCodes.ReplicationStart:\n return replicationStart\n case MessageCodes.EmptyQuery:\n return emptyQuery\n case MessageCodes.DataRow:\n return this.#parseDataRowMessage(offset, length, bytes)\n case MessageCodes.CommandComplete:\n return this.#parseCommandCompleteMessage(offset, length, bytes)\n case MessageCodes.ReadyForQuery:\n return this.#parseReadyForQueryMessage(offset, length, bytes)\n case MessageCodes.NotificationResponse:\n return this.#parseNotificationMessage(offset, length, bytes)\n case MessageCodes.AuthenticationResponse:\n return this.#parseAuthenticationResponse(offset, length, bytes)\n case MessageCodes.ParameterStatus:\n return this.#parseParameterStatusMessage(offset, length, bytes)\n case MessageCodes.BackendKeyData:\n return this.#parseBackendKeyData(offset, length, bytes)\n case MessageCodes.ErrorMessage:\n return this.#parseErrorMessage(offset, length, bytes, 'error')\n case MessageCodes.NoticeMessage:\n return this.#parseErrorMessage(offset, length, bytes, 'notice')\n case MessageCodes.RowDescriptionMessage:\n return this.#parseRowDescriptionMessage(offset, length, bytes)\n case MessageCodes.ParameterDescriptionMessage:\n return this.#parseParameterDescriptionMessage(offset, length, bytes)\n case MessageCodes.CopyIn:\n return this.#parseCopyInMessage(offset, length, bytes)\n case MessageCodes.CopyOut:\n return this.#parseCopyOutMessage(offset, length, bytes)\n case MessageCodes.CopyData:\n return this.#parseCopyData(offset, length, bytes)\n default:\n return new DatabaseError(\n 'received invalid response: ' + code.toString(16),\n length,\n 'error',\n )\n }\n }\n\n #parseReadyForQueryMessage(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n ) {\n this.#reader.setBuffer(offset, bytes)\n const status = this.#reader.string(1)\n return new ReadyForQueryMessage(length, status)\n }\n\n #parseCommandCompleteMessage(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n ) {\n this.#reader.setBuffer(offset, bytes)\n const text = this.#reader.cstring()\n return new CommandCompleteMessage(length, text)\n }\n\n #parseCopyData(offset: number, length: number, bytes: ArrayBuffer) {\n const chunk = bytes.slice(offset, offset + (length - 4))\n return new CopyDataMessage(length, new Uint8Array(chunk))\n }\n\n #parseCopyInMessage(offset: number, length: number, bytes: ArrayBuffer) {\n return this.#parseCopyMessage(offset, length, bytes, 'copyInResponse')\n }\n\n #parseCopyOutMessage(offset: number, length: number, bytes: ArrayBuffer) {\n return this.#parseCopyMessage(offset, length, bytes, 'copyOutResponse')\n }\n\n #parseCopyMessage(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n messageName: MessageName,\n ) {\n this.#reader.setBuffer(offset, bytes)\n const isBinary = this.#reader.byte() !== 0\n const columnCount = this.#reader.int16()\n const message = new CopyResponse(length, messageName, isBinary, columnCount)\n for (let i = 0; i < columnCount; i++) {\n message.columnTypes[i] = this.#reader.int16()\n }\n return message\n }\n\n #parseNotificationMessage(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n ) {\n this.#reader.setBuffer(offset, bytes)\n const processId = this.#reader.int32()\n const channel = this.#reader.cstring()\n const payload = this.#reader.cstring()\n return new NotificationResponseMessage(length, processId, channel, payload)\n }\n\n #parseRowDescriptionMessage(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n ) {\n this.#reader.setBuffer(offset, bytes)\n const fieldCount = this.#reader.int16()\n const message = new RowDescriptionMessage(length, fieldCount)\n for (let i = 0; i < fieldCount; i++) {\n message.fields[i] = this.#parseField()\n }\n return message\n }\n\n #parseField(): Field {\n const name = this.#reader.cstring()\n const tableID = this.#reader.int32()\n const columnID = this.#reader.int16()\n const dataTypeID = this.#reader.int32()\n const dataTypeSize = this.#reader.int16()\n const dataTypeModifier = this.#reader.int32()\n const mode = this.#reader.int16() === 0 ? Modes.text : Modes.binary\n return new Field(\n name,\n tableID,\n columnID,\n dataTypeID,\n dataTypeSize,\n dataTypeModifier,\n mode,\n )\n }\n\n #parseParameterDescriptionMessage(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n ) {\n this.#reader.setBuffer(offset, bytes)\n const parameterCount = this.#reader.int16()\n const message = new ParameterDescriptionMessage(length, parameterCount)\n for (let i = 0; i < parameterCount; i++) {\n message.dataTypeIDs[i] = this.#reader.int32()\n }\n return message\n }\n\n #parseDataRowMessage(offset: number, length: number, bytes: ArrayBuffer) {\n this.#reader.setBuffer(offset, bytes)\n const fieldCount = this.#reader.int16()\n const fields: (string | null)[] = new Array(fieldCount)\n for (let i = 0; i < fieldCount; i++) {\n const len = this.#reader.int32()\n // a -1 for length means the value of the field is null\n fields[i] = len === -1 ? null : this.#reader.string(len)\n }\n return new DataRowMessage(length, fields)\n }\n\n #parseParameterStatusMessage(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n ) {\n this.#reader.setBuffer(offset, bytes)\n const name = this.#reader.cstring()\n const value = this.#reader.cstring()\n return new ParameterStatusMessage(length, name, value)\n }\n\n #parseBackendKeyData(offset: number, length: number, bytes: ArrayBuffer) {\n this.#reader.setBuffer(offset, bytes)\n const processID = this.#reader.int32()\n const secretKey = this.#reader.int32()\n return new BackendKeyDataMessage(length, processID, secretKey)\n }\n\n #parseAuthenticationResponse(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n ): AuthenticationMessage {\n this.#reader.setBuffer(offset, bytes)\n const code = this.#reader.int32()\n switch (code) {\n case 0:\n return new AuthenticationOk(length)\n case 3:\n return new AuthenticationCleartextPassword(length)\n\n case 5:\n return new AuthenticationMD5Password(length, this.#reader.bytes(4))\n\n case 10: {\n const mechanisms: string[] = []\n while (true) {\n const mechanism = this.#reader.cstring()\n if (mechanism.length === 0) {\n return new AuthenticationSASL(length, mechanisms)\n }\n mechanisms.push(mechanism)\n }\n }\n case 11:\n return new AuthenticationSASLContinue(\n length,\n this.#reader.string(length - 8),\n )\n\n case 12:\n return new AuthenticationSASLFinal(\n length,\n this.#reader.string(length - 8),\n )\n\n default:\n throw new Error('Unknown authenticationOk message type ' + code)\n }\n }\n\n #parseErrorMessage(\n offset: number,\n length: number,\n bytes: ArrayBuffer,\n name: MessageName,\n ) {\n this.#reader.setBuffer(offset, bytes)\n const fields: Record<string, string> = {}\n let fieldType = this.#reader.string(1)\n while (fieldType !== '\\0') {\n fields[fieldType] = this.#reader.cstring()\n fieldType = this.#reader.string(1)\n }\n\n const messageValue = fields.M\n\n const message =\n name === 'notice'\n ? new NoticeMessage(length, messageValue)\n : new DatabaseError(messageValue, length, name)\n\n message.severity = fields.S\n message.code = fields.C\n message.detail = fields.D\n message.hint = fields.H\n message.position = fields.P\n message.internalPosition = fields.p\n message.internalQuery = fields.q\n message.where = fields.W\n message.schema = fields.s\n message.table = fields.t\n message.column = fields.c\n message.dataType = fields.d\n message.constraint = fields.n\n message.file = fields.F\n message.line = fields.L\n message.routine = fields.R\n return message\n }\n}\n","export const Modes = {\n text: 0,\n binary: 1,\n} as const\n\nexport type Mode = (typeof Modes)[keyof typeof Modes]\n\nexport type BufferParameter = ArrayBuffer | ArrayBufferView\n","const emptyBuffer = new ArrayBuffer(0)\n\nexport class BufferReader {\n #bufferView: DataView = new DataView(emptyBuffer)\n #offset: number\n\n // TODO(bmc): support non-utf8 encoding?\n readonly #encoding: string = 'utf-8' as const\n readonly #decoder = new TextDecoder(this.#encoding)\n readonly #littleEndian: boolean = false as const\n\n constructor(offset: number = 0) {\n this.#offset = offset\n }\n\n public setBuffer(offset: number, buffer: ArrayBuffer): void {\n this.#offset = offset\n this.#bufferView = new DataView(buffer)\n }\n\n public int16(): number {\n // const result = this.buffer.readInt16BE(this.#offset)\n const result = this.#bufferView.getInt16(this.#offset, this.#littleEndian)\n this.#offset += 2\n return result\n }\n\n public byte(): number {\n // const result = this.bufferView[this.#offset]\n const result = this.#bufferView.getUint8(this.#offset)\n this.#offset++\n return result\n }\n\n public int32(): number {\n // const result = this.buffer.readInt32BE(this.#offset)\n const result = this.#bufferView.getInt32(this.#offset, this.#littleEndian)\n this.#offset += 4\n return result\n }\n\n public string(length: number): string {\n // const result = this.#bufferView.toString(\n // this.#encoding,\n // this.#offset,\n // this.#offset + length,\n // )\n // this.#offset += length\n\n const result = this.#decoder.decode(this.bytes(length))\n return result\n }\n\n public cstring(): string {\n // const start = this.#offset\n // let end = start\n // while (this.#bufferView[end++] !== 0) {}\n\n const start = this.#offset\n let end = start\n while (this.#bufferView.getUint8(end++) !== 0) {\n // no-op - increment until terminator reached\n }\n const result = this.string(end - start - 1)\n this.#offset = end\n return result\n }\n\n public bytes(length: number): Uint8Array {\n // const result = this.buffer.slice(this.#offset, this.#offset + length)\n const result = this.#bufferView.buffer.slice(\n this.#offset,\n this.#offset + length,\n )\n this.#offset += length\n return new Uint8Array(result)\n }\n}\n","import type { PGliteInterfaceBase, Transaction } from './interface.js'\nimport { serialize as serializeProtocol } from '@electric-sql/pg-protocol'\nimport { parseDescribeStatementResults } from './parse.js'\nimport { TEXT } from './types.js'\n\nexport const IN_NODE =\n typeof process === 'object' &&\n typeof process.versions === 'object' &&\n typeof process.versions.node === 'string'\n\nlet wasmDownloadPromise: Promise<Response> | undefined\n\n// Helper to safely get wasm URL - deferred to avoid import.meta.url issues in Workers\nfunction getWasmUrl(): URL {\n try {\n return new URL('../release/pglite.wasm', import.meta.url)\n } catch {\n throw new Error(\n 'Cannot resolve WASM URL. In Cloudflare Workers, you must provide wasmModule option.',\n )\n }\n}\n\n// Helper to safely get fsBundle URL - deferred to avoid import.meta.url issues in Workers\nfunction getFsBundleUrl(): URL {\n try {\n return new URL('../release/pglite.data', import.meta.url)\n } catch {\n throw new Error(\n 'Cannot resolve fsBundle URL. In Cloudflare Workers, you must provide fsBundle option.',\n )\n }\n}\n\nexport async function startWasmDownload() {\n if (IN_NODE || wasmDownloadPromise) {\n return\n }\n const moduleUrl = getWasmUrl()\n wasmDownloadPromise = fetch(moduleUrl)\n}\n\n// This is a global cache of the PGlite Wasm module to avoid having to re-download or\n// compile it on subsequent calls.\nlet cachedWasmModule: WebAssembly.Module | undefined\n\nexport async function instantiateWasm(\n imports: WebAssembly.Imports,\n module?: WebAssembly.Module,\n): Promise<{\n instance: WebAssembly.Instance\n module: WebAssembly.Module\n}> {\n // Check for provided module FIRST before trying to resolve URLs\n if (module || cachedWasmModule) {\n return {\n instance: await WebAssembly.instantiate(\n module || cachedWasmModule!,\n imports,\n ),\n module: module || cachedWasmModule!,\n }\n }\n // Only resolve URL if no module provided - this may throw in Workers\n const moduleUrl = getWasmUrl()\n if (IN_NODE) {\n const fs = await import('fs/promises')\n const buffer = await fs.readFile(moduleUrl)\n const { module: newModule, instance } = await WebAssembly.instantiate(\n buffer,\n imports,\n )\n cachedWasmModule = newModule\n return {\n instance,\n module: newModule,\n }\n } else {\n if (!wasmDownloadPromise) {\n wasmDownloadPromise = fetch(moduleUrl)\n }\n const response = await wasmDownloadPromise\n const { module: newModule, instance } =\n await WebAssembly.instantiateStreaming(response, imports)\n cachedWasmModule = newModule\n return {\n instance,\n module: newModule,\n }\n }\n}\n\nexport async function getFsBundle(): Promise<ArrayBuffer> {\n // Only resolve URL when called - this may throw in Workers\n // Callers should provide fsBundle option to avoid this\n const fsBundleUrl = getFsBundleUrl()\n if (IN_NODE) {\n const fs = await import('fs/promises')\n const fileData = await fs.readFile(fsBundleUrl)\n return fileData.buffer\n } else {\n const response = await fetch(fsBundleUrl)\n return response.arrayBuffer()\n }\n}\n\nexport const uuid = (): string => {\n // best case, `crypto.randomUUID` is available\n if (globalThis.crypto?.randomUUID) {\n return globalThis.crypto.randomUUID()\n }\n\n const bytes = new Uint8Array(16)\n\n if (globalThis.crypto?.getRandomValues) {\n // `crypto.getRandomValues` is available even in non-secure contexts\n globalThis.crypto.getRandomValues(bytes)\n } else {\n // fallback to Math.random, if the Crypto API is completely missing\n for (let i = 0; i < bytes.length; i++) {\n bytes[i] = Math.floor(Math.random() * 256)\n }\n }\n\n bytes[6] = (bytes[6] & 0x0f) | 0x40 // Set the 4 most significant bits to 0100\n bytes[8] = (bytes[8] & 0x3f) | 0x80 // Set the 2 most significant bits to 10\n\n const hexValues: string[] = []\n bytes.forEach((byte) => {\n hexValues.push(byte.toString(16).padStart(2, '0'))\n })\n\n return (\n hexValues.slice(0, 4).join('') +\n '-' +\n hexValues.slice(4, 6).join('') +\n '-' +\n hexValues.slice(6, 8).join('') +\n '-' +\n hexValues.slice(8, 10).join('') +\n '-' +\n hexValues.slice(10).join('')\n )\n}\n\n/**\n * Formats a query with parameters\n * Expects that any tables/relations referenced in the query exist in the database\n * due to requiring them to be present to describe the parameters types.\n * `tx` is optional, and to be used when formatQuery is called during a transaction.\n * @param pg - The PGlite instance\n * @param query - The query to format\n * @param params - The parameters to format the query with\n * @param tx - The transaction to use, defaults to the PGlite instance\n * @returns The formatted query\n */\nexport async function formatQuery(\n pg: PGliteInterfaceBase,\n query: string,\n params?: any[] | null,\n tx?: Transaction | PGliteInterfaceBase,\n) {\n if (!params || params.length === 0) {\n // no params so no formatting needed\n return query\n }\n\n tx = tx ?? pg\n\n // Get the types of the parameters\n const messages = []\n try {\n await pg.execProtocol(serializeProtocol.parse({ text: query }), {\n syncToFs: false,\n })\n\n messages.push(\n ...(\n await pg.execProtocol(serializeProtocol.describe({ type: 'S' }), {\n syncToFs: false,\n })\n ).messages,\n )\n } finally {\n messages.push(\n ...(await pg.execProtocol(serializeProtocol.sync(), { syncToFs: false }))\n .messages,\n )\n }\n\n const dataTypeIDs = parseDescribeStatementResults(messages)\n\n // replace $1, $2, etc with %1L, %2L, etc\n const subbedQuery = query.replace(/\\$([0-9]+)/g, (_, num) => {\n return '%' + num + 'L'\n })\n\n const ret = await tx.query<{\n query: string\n }>(\n `SELECT format($1, ${params.map((_, i) => `$${i + 2}`).join(', ')}) as query`,\n [subbedQuery, ...params],\n { paramTypes: [TEXT, ...dataTypeIDs] },\n )\n return ret.rows[0].query\n}\n\n/**\n * Debounce a function to ensure that only one instance of the function is running at\n * a time.\n * - If the function is called while an instance is already running, the new\n * call is scheduled to run after the current instance completes.\n * - If there is already a scheduled call, it is replaced with the new call.\n * @param fn - The function to debounce\n * @returns A debounced version of the function\n */\nexport function debounceMutex<A extends any[], R>(\n fn: (...args: A) => Promise<R>,\n): (...args: A) => Promise<R | void> {\n let next:\n | {\n args: A\n resolve: (value: R | void) => void\n reject: (reason?: any) => void\n }\n | undefined = undefined\n\n let isRunning = false\n const processNext = async () => {\n if (!next) {\n isRunning = false\n return\n }\n isRunning = true\n const { args, resolve, reject } = next\n next = undefined\n try {\n const ret = await fn(...args)\n resolve(ret)\n } catch (e) {\n reject(e)\n } finally {\n processNext()\n }\n }\n return async (...args: A) => {\n if (next) {\n next.resolve(undefined)\n }\n const promise = new Promise<R | void>((resolve, reject) => {\n next = { args, resolve, reject }\n })\n if (!isRunning) {\n processNext()\n }\n return promise\n }\n}\n\n/**\n * Postgresql handles quoted names as CaseSensitive and unquoted as lower case.\n * If input is quoted, returns an unquoted string (same casing)\n * If input is unquoted, returns a lower-case string\n */\nexport function toPostgresName(input: string): string {\n let output\n if (input.startsWith('\"') && input.endsWith('\"')) {\n // Postgres sensitive case\n output = input.substring(1, input.length - 1)\n } else {\n // Postgres case insensitive - all to lower\n output = input.toLowerCase()\n }\n return output\n}\n"],"mappings":"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","names":["types_exports","__export","ABSTIME","ACLITEM","BIT","BOOL","BPCHAR","BYTEA","CHAR","CID","CIDR","CIRCLE","DATE","FLOAT4","FLOAT8","GTSVECTOR","INET","INT2","INT4","INT8","INTERVAL","JSON","JSONB","MACADDR","MACADDR8","MONEY","NUMERIC","OID","PATH","PG_DEPENDENCIES","PG_LSN","PG_NDISTINCT","PG_NODE_TREE","POLYGON","REFCURSOR","REGCLASS","REGCONFIG","REGDICTIONARY","REGNAMESPACE","REGOPER","REGOPERATOR","REGPROC","REGPROCEDURE","REGROLE","REGTYPE","RELTIME","SMGR","TEXT","TID","TIME","TIMESTAMP","TIMESTAMPTZ","TIMETZ","TINTERVAL","TSQUERY","TSVECTOR","TXID_SNAPSHOT","UUID","VARBIT","VARCHAR","XID","XML","arrayParser","arraySerializer","parseType","parsers","serializers","types","init_esm_shims","JSON_parse","JSON_stringify","x","n","byte","hexString","_","idx","defaultHandlers","typeHandlers","type","handler","k","to","from","serialize","parse","f","escapeBackslash","escapeQuote","arrayEscape","xs","serializer","typarray","first","delimiter","arrayParserState","parser","arrayParserLoop","s","parse_exports","__export","parseDescribeStatementResults","parseResults","init_esm_shims","parseResults","messages","defaultParsers","options","blob","resultSets","currentResultSet","affectedRows","parsers","message","msg","field","i","parseType","retrieveRowCount","parts","parseDescribeStatementResults","messages_exports","__export","AuthenticationCleartextPassword","AuthenticationMD5Password","AuthenticationOk","AuthenticationSASL","AuthenticationSASLContinue","AuthenticationSASLFinal","BackendKeyDataMessage","CommandCompleteMessage","CopyDataMessage","CopyResponse","DataRowMessage","DatabaseError","Field","NoticeMessage","NotificationResponseMessage","ParameterDescriptionMessage","ParameterStatusMessage","ReadyForQueryMessage","RowDescriptionMessage","bindComplete","closeComplete","copyDone","emptyQuery","noData","parseComplete","portalSuspended","replicationStart","init_esm_shims","length","salt","mechanisms","data","message","name","chunk","binary","columnCount","tableID","columnID","dataTypeID","dataTypeSize","dataTypeModifier","format","fieldCount","parameterCount","parameterName","parameterValue","processID","secretKey","processId","channel","payload","status","text","fields","src_exports","__export","Parser","messages_exports","serialize","init_esm_shims","init_esm_shims","init_esm_shims","init_esm_shims","byteLengthUtf8","str","byteLength","i","code","_bufferView","_offset","_littleEndian","_encoder","_headerPosition","_Writer_instances","allocateBuffer_fn","ensure_fn","join_fn","Writer","size","__privateAdd","__privateSet","__privateMethod","num","__privateGet","string","__privateWrapper","length","byteLengthUtf8","otherBuffer","code","result","oldBuffer","newSize","writer","Writer","startup","opts","key","bodyBuffer","length","requestSsl","bufferView","password","sendSASLInitialResponseMessage","mechanism","initialResponse","byteLengthUtf8","sendSCRAMClientFinalMessage","additionalData","query","text","emptyValueArray","parse","name","buffer","type","paramWriter","writeValues","values","valueMapper","i","mappedVal","writer","paramWriter","buffer","byteLengthUtf8","bind","config","portal","statement","binary","emptyValueArray","len","emptyExecute","execute","rows","portalLength","bufferView","cancel","processID","secretKey","cstringMessage","code","string","Writer","emptyDescribePortal","emptyDescribeStatement","describe","msg","close","text","copyData","chunk","copyFail","message","codeOnlyBuffer","flushBuffer","syncBuffer","endBuffer","copyDoneBuffer","serialize","startup","password","requestSsl","sendSASLInitialResponseMessage","sendSCRAMClientFinalMessage","query","parse","init_esm_shims","init_esm_shims","Modes","init_esm_shims","emptyBuffer","_bufferView","_offset","_encoding","_decoder","_littleEndian","BufferReader","offset","__privateAdd","__privateGet","__privateSet","buffer","result","__privateWrapper","length","start","end","CODE_LENGTH","LEN_LENGTH","HEADER_LENGTH","emptyBuffer","_bufferView","_bufferRemainingLength","_bufferOffset","_reader","_Parser_instances","mergeBuffer_fn","handlePacket_fn","parseReadyForQueryMessage_fn","parseCommandCompleteMessage_fn","parseCopyData_fn","parseCopyInMessage_fn","parseCopyOutMessage_fn","parseCopyMessage_fn","parseNotificationMessage_fn","parseRowDescriptionMessage_fn","parseField_fn","parseParameterDescriptionMessage_fn","parseDataRowMessage_fn","parseParameterStatusMessage_fn","parseBackendKeyData_fn","parseAuthenticationResponse_fn","parseErrorMessage_fn","Parser","__privateAdd","emptyBuffer","BufferReader","buffer","callback","__privateMethod","bufferFullLength","__privateGet","offset","HEADER_LENGTH","code","length","CODE_LENGTH","fullMessageLength","message","__privateSet","newLength","newBuffer","newBufferLength","bytes","bindComplete","parseComplete","closeComplete","noData","portalSuspended","copyDone","replicationStart","emptyQuery","DatabaseError","status","ReadyForQueryMessage","text","CommandCompleteMessage","chunk","CopyDataMessage","messageName","isBinary","columnCount","CopyResponse","i","processId","channel","payload","NotificationResponseMessage","fieldCount","RowDescriptionMessage","name","tableID","columnID","dataTypeID","dataTypeSize","dataTypeModifier","mode","Modes","Field","parameterCount","ParameterDescriptionMessage","fields","len","DataRowMessage","value","ParameterStatusMessage","processID","secretKey","BackendKeyDataMessage","AuthenticationOk","AuthenticationCleartextPassword","AuthenticationMD5Password","mechanisms","mechanism","AuthenticationSASL","AuthenticationSASLContinue","AuthenticationSASLFinal","fieldType","messageValue","NoticeMessage","init_esm_shims","IN_NODE","wasmDownloadPromise","getWasmUrl","getFsBundleUrl","startWasmDownload","moduleUrl","cachedWasmModule","instantiateWasm","imports","module","buffer","newModule","instance","response","getFsBundle","fsBundleUrl","uuid","bytes","i","hexValues","byte","formatQuery","pg","query","params","tx","messages","serialize","dataTypeIDs","parseDescribeStatementResults","subbedQuery","_","num","TEXT","debounceMutex","fn","next","isRunning","processNext","args","resolve","reject","ret","e","promise","toPostgresName","input","output"]}
@@ -1,9 +1,9 @@
1
- import{a as v,b as B,c as A,d as q,f as _,g as z,i as l,j as g}from"./chunk-FY2WAP66.js";import{d as R}from"./chunk-OO3CQQYD.js";import{e as P,f as w,g as d,h as a,j as f}from"./chunk-VCBR6USK.js";f();f();function E(m){let s=m.e;return s.query=m.query,s.params=m.params,s.queryOptions=m.options,s}var T,p,t,y,x,h,O,k=class{constructor(){w(this,t);this.serializers={...B};this.parsers={...v};w(this,T,!1);w(this,p,!1)}async _initArrayTypes({force:s=!1}={}){if(P(this,T)&&!s)return;d(this,T,!0);let e=await this.query(`
1
+ import{a as Q,b as v,c as A,d as q,f as _,g as z,i as l,j as g}from"./chunk-5U7S5PTI.js";import{d as R}from"./chunk-OO3CQQYD.js";import{e as P,f as w,g as d,h as a,j as f}from"./chunk-VCBR6USK.js";f();f();function E(m){let s=m.e;return s.query=m.query,s.params=m.params,s.queryOptions=m.options,s}var T,p,t,y,x,h,O,k=class{constructor(){w(this,t);this.serializers={...v};this.parsers={...Q};w(this,T,!1);w(this,p,!1)}async _initArrayTypes({force:s=!1}={}){if(P(this,T)&&!s)return;d(this,T,!0);let e=await this.query(`
2
2
  SELECT b.oid, b.typarray
3
3
  FROM pg_catalog.pg_type a
4
4
  LEFT JOIN pg_catalog.pg_type b ON b.oid = a.typelem
5
5
  WHERE a.typcategory = 'A'
6
6
  GROUP BY b.oid, b.typarray
7
7
  ORDER BY b.oid
8
- `);for(let r of e.rows)this.serializers[r.typarray]=o=>A(o,this.serializers[r.oid],r.typarray),this.parsers[r.typarray]=o=>q(o,this.parsers[r.oid],r.typarray)}async refreshArrayTypes(){await this._initArrayTypes({force:!0})}async query(s,e,r){return await this._checkReady(),await this._runExclusiveTransaction(async()=>await a(this,t,x).call(this,s,e,r))}async sql(s,...e){let{query:r,params:o}=R(s,...e);return await this.query(r,o)}async exec(s,e){return await this._checkReady(),await this._runExclusiveTransaction(async()=>await a(this,t,h).call(this,s,e))}async describeQuery(s,e){let r=[];try{await a(this,t,y).call(this,l.parse({text:s,types:e?.paramTypes}),e),r=await a(this,t,y).call(this,l.describe({type:"S"}),e)}catch(n){throw n instanceof g?E({e:n,options:e,params:void 0,query:s}):n}finally{r.push(...await a(this,t,y).call(this,l.sync(),e))}let o=r.find(n=>n.name==="parameterDescription"),i=r.find(n=>n.name==="rowDescription"),c=o?.dataTypeIDs.map(n=>({dataTypeID:n,serializer:this.serializers[n]}))??[],u=i?.fields.map(n=>({name:n.name,dataTypeID:n.dataTypeID,parser:this.parsers[n.dataTypeID]}))??[];return{queryParams:c,resultFields:u}}async transaction(s){return await this._checkReady(),await this._runExclusiveTransaction(async()=>{await a(this,t,h).call(this,"BEGIN"),d(this,p,!0);let e=!1,r=()=>{if(e)throw new Error("Transaction is closed")},o={query:async(i,c,u)=>(r(),await a(this,t,x).call(this,i,c,u)),sql:async(i,...c)=>{let{query:u,params:n}=R(i,...c);return await a(this,t,x).call(this,u,n)},exec:async(i,c)=>(r(),await a(this,t,h).call(this,i,c)),rollback:async()=>{r(),await a(this,t,h).call(this,"ROLLBACK"),e=!0},listen:async(i,c)=>(r(),await this.listen(i,c,o)),get closed(){return e}};try{let i=await s(o);return e||(e=!0,await a(this,t,h).call(this,"COMMIT")),d(this,p,!1),i}catch(i){throw e||await a(this,t,h).call(this,"ROLLBACK"),d(this,p,!1),i}})}async runExclusive(s){return await this._runExclusiveQuery(s)}};T=new WeakMap,p=new WeakMap,t=new WeakSet,y=async function(s,e={}){return await this.execProtocolStream(s,{...e,syncToFs:!1})},x=async function(s,e=[],r){return await this._runExclusiveQuery(async()=>{a(this,t,O).call(this,"runQuery",s,e,r),await this._handleBlob(r?.blob);let o=[];try{let c=await a(this,t,y).call(this,l.parse({text:s,types:r?.paramTypes}),r),u=z(await a(this,t,y).call(this,l.describe({type:"S"}),r)),n=e.map((b,S)=>{let D=u[S];if(b==null)return null;let Q=r?.serializers?.[D]??this.serializers[D];return Q?Q(b):b.toString()});o=[...c,...await a(this,t,y).call(this,l.bind({values:n}),r),...await a(this,t,y).call(this,l.describe({type:"P"}),r),...await a(this,t,y).call(this,l.execute({}),r)]}catch(c){throw c instanceof g?E({e:c,options:r,params:e,query:s}):c}finally{o.push(...await a(this,t,y).call(this,l.sync(),r))}await this._cleanupBlob(),P(this,p)||await this.syncToFs();let i=await this._getWrittenBlob();return _(o,this.parsers,r,i)[0]})},h=async function(s,e){return await this._runExclusiveQuery(async()=>{a(this,t,O).call(this,"runExec",s,e),await this._handleBlob(e?.blob);let r=[];try{r=await a(this,t,y).call(this,l.query(s),e)}catch(i){throw i instanceof g?E({e:i,options:e,params:void 0,query:s}):i}finally{r.push(...await a(this,t,y).call(this,l.sync(),e))}this._cleanupBlob(),P(this,p)||await this.syncToFs();let o=await this._getWrittenBlob();return _(r,this.parsers,e,o)})},O=function(...s){this.debug>0&&console.log(...s)};export{k as a};
9
- //# sourceMappingURL=chunk-NS5M47NH.js.map
8
+ `);for(let r of e.rows)this.serializers[r.typarray]=o=>A(o,this.serializers[r.oid],r.typarray),this.parsers[r.typarray]=o=>q(o,this.parsers[r.oid],r.typarray)}async refreshArrayTypes(){await this._initArrayTypes({force:!0})}async query(s,e,r){return await this._checkReady(),await this._runExclusiveTransaction(async()=>await a(this,t,x).call(this,s,e,r))}async sql(s,...e){let{query:r,params:o}=R(s,...e);return await this.query(r,o)}async exec(s,e){return await this._checkReady(),await this._runExclusiveTransaction(async()=>await a(this,t,h).call(this,s,e))}async describeQuery(s,e){let r=[];try{await a(this,t,y).call(this,l.parse({text:s,types:e?.paramTypes}),e),r=await a(this,t,y).call(this,l.describe({type:"S"}),e)}catch(n){throw n instanceof g?E({e:n,options:e,params:void 0,query:s}):n}finally{r.push(...await a(this,t,y).call(this,l.sync(),e))}let o=r.find(n=>n.name==="parameterDescription"),i=r.find(n=>n.name==="rowDescription"),c=o?.dataTypeIDs.map(n=>({dataTypeID:n,serializer:this.serializers[n]}))??[],u=i?.fields.map(n=>({name:n.name,dataTypeID:n.dataTypeID,parser:this.parsers[n.dataTypeID]}))??[];return{queryParams:c,resultFields:u}}async transaction(s){return await this._checkReady(),await this._runExclusiveTransaction(async()=>{await a(this,t,h).call(this,"BEGIN"),d(this,p,!0);let e=!1,r=()=>{if(e)throw new Error("Transaction is closed")},o={query:async(i,c,u)=>(r(),await a(this,t,x).call(this,i,c,u)),sql:async(i,...c)=>{let{query:u,params:n}=R(i,...c);return await a(this,t,x).call(this,u,n)},exec:async(i,c)=>(r(),await a(this,t,h).call(this,i,c)),rollback:async()=>{r(),await a(this,t,h).call(this,"ROLLBACK"),e=!0},listen:async(i,c)=>(r(),await this.listen(i,c,o)),get closed(){return e}};try{let i=await s(o);return e||(e=!0,await a(this,t,h).call(this,"COMMIT")),d(this,p,!1),i}catch(i){throw e||await a(this,t,h).call(this,"ROLLBACK"),d(this,p,!1),i}})}async runExclusive(s){return await this._runExclusiveQuery(s)}};T=new WeakMap,p=new WeakMap,t=new WeakSet,y=async function(s,e={}){return await this.execProtocolStream(s,{...e,syncToFs:!1})},x=async function(s,e=[],r){return await this._runExclusiveQuery(async()=>{a(this,t,O).call(this,"runQuery",s,e,r),await this._handleBlob(r?.blob);let o=[];try{let c=await a(this,t,y).call(this,l.parse({text:s,types:r?.paramTypes}),r),u=z(await a(this,t,y).call(this,l.describe({type:"S"}),r)),n=e.map((b,S)=>{let D=u[S];if(b==null)return null;let B=r?.serializers?.[D]??this.serializers[D];return B?B(b):b.toString()});o=[...c,...await a(this,t,y).call(this,l.bind({values:n}),r),...await a(this,t,y).call(this,l.describe({type:"P"}),r),...await a(this,t,y).call(this,l.execute({}),r)]}catch(c){throw c instanceof g?E({e:c,options:r,params:e,query:s}):c}finally{o.push(...await a(this,t,y).call(this,l.sync(),r))}await this._cleanupBlob(),P(this,p)||await this.syncToFs();let i=await this._getWrittenBlob();return _(o,this.parsers,r,i)[0]})},h=async function(s,e){return await this._runExclusiveQuery(async()=>{a(this,t,O).call(this,"runExec",s,e),await this._handleBlob(e?.blob);let r=[];try{r=await a(this,t,y).call(this,l.query(s),e)}catch(i){throw i instanceof g?E({e:i,options:e,params:void 0,query:s}):i}finally{r.push(...await a(this,t,y).call(this,l.sync(),e))}this._cleanupBlob(),P(this,p)||await this.syncToFs();let o=await this._getWrittenBlob();return _(r,this.parsers,e,o)})},O=function(...s){this.debug>0&&console.log(...s)};export{k as a};
9
+ //# sourceMappingURL=chunk-I55HERVV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/base.ts","../src/errors.ts"],"sourcesContent":["import { query as queryTemplate } from './templating.js'\nimport { parseDescribeStatementResults, parseResults } from './parse.js'\nimport {\n type Serializer,\n type Parser,\n serializers,\n parsers,\n arraySerializer,\n arrayParser,\n} from './types.js'\nimport type {\n DebugLevel,\n PGliteInterfaceBase,\n Results,\n Transaction,\n QueryOptions,\n ExecProtocolOptions,\n ExecProtocolResult,\n DescribeQueryResult,\n} from './interface.js'\n\nimport { serialize as serializeProtocol } from '@electric-sql/pg-protocol'\nimport {\n RowDescriptionMessage,\n ParameterDescriptionMessage,\n DatabaseError,\n BackendMessage,\n} from '@electric-sql/pg-protocol/messages'\nimport { makePGliteError } from './errors.js'\n\nexport abstract class BasePGlite\n implements Pick<PGliteInterfaceBase, 'query' | 'sql' | 'exec' | 'transaction'>\n{\n serializers: Record<number | string, Serializer> = { ...serializers }\n parsers: Record<number | string, Parser> = { ...parsers }\n #arrayTypesInitialized = false\n\n // # Abstract properties:\n abstract debug: DebugLevel\n\n // # Private properties:\n #inTransaction = false\n\n // # Abstract methods:\n\n /**\n * Execute a postgres wire protocol message\n * @param message The postgres wire protocol message to execute\n * @returns The result of the query\n */\n abstract execProtocol(\n message: Uint8Array,\n { syncToFs, onNotice }: ExecProtocolOptions,\n ): Promise<ExecProtocolResult>\n\n /**\n * Execute a postgres wire protocol message\n * @param message The postgres wire protocol message to execute\n * @returns The parsed results of the query\n */\n abstract execProtocolStream(\n message: Uint8Array,\n { syncToFs, onNotice }: ExecProtocolOptions,\n ): Promise<BackendMessage[]>\n\n /**\n * Execute a postgres wire protocol message directly without wrapping the response.\n * Only use if `execProtocol()` doesn't suite your needs.\n *\n * **Warning:** This bypasses PGlite's protocol wrappers that manage error/notice messages,\n * transactions, and notification listeners. Only use if you need to bypass these wrappers and\n * don't intend to use the above features.\n *\n * @param message The postgres wire protocol message to execute\n * @returns The direct message data response produced by Postgres\n */\n abstract execProtocolRaw(\n message: Uint8Array,\n { syncToFs }: ExecProtocolOptions,\n ): Promise<Uint8Array>\n\n /**\n * Sync the database to the filesystem\n * @returns Promise that resolves when the database is synced to the filesystem\n */\n abstract syncToFs(): Promise<void>\n\n /**\n * Handle a file attached to the current query\n * @param file The file to handle\n */\n abstract _handleBlob(blob?: File | Blob): Promise<void>\n\n /**\n * Get the written file\n */\n abstract _getWrittenBlob(): Promise<File | Blob | undefined>\n\n /**\n * Cleanup the current file\n */\n abstract _cleanupBlob(): Promise<void>\n\n abstract _checkReady(): Promise<void>\n abstract _runExclusiveQuery<T>(fn: () => Promise<T>): Promise<T>\n abstract _runExclusiveTransaction<T>(fn: () => Promise<T>): Promise<T>\n\n /**\n * Listen for notifications on a channel\n */\n abstract listen(\n channel: string,\n callback: (payload: string) => void,\n tx?: Transaction,\n ): Promise<(tx?: Transaction) => Promise<void>>\n\n // # Concrete implementations:\n\n /**\n * Initialize the array types\n * The oid if the type of an element and the typarray is the oid of the type of the\n * array.\n * We extract these from the database then create the serializers/parsers for\n * each type.\n * This should be called at the end of #init() in the implementing class.\n */\n async _initArrayTypes({ force = false } = {}) {\n if (this.#arrayTypesInitialized && !force) return\n this.#arrayTypesInitialized = true\n\n const types = await this.query<{ oid: number; typarray: number }>(`\n SELECT b.oid, b.typarray\n FROM pg_catalog.pg_type a\n LEFT JOIN pg_catalog.pg_type b ON b.oid = a.typelem\n WHERE a.typcategory = 'A'\n GROUP BY b.oid, b.typarray\n ORDER BY b.oid\n `)\n\n for (const type of types.rows) {\n this.serializers[type.typarray] = (x) =>\n arraySerializer(x, this.serializers[type.oid], type.typarray)\n this.parsers[type.typarray] = (x) =>\n arrayParser(x, this.parsers[type.oid], type.typarray)\n }\n }\n\n async #execProtocolNoSync(\n message: Uint8Array,\n options: ExecProtocolOptions = {},\n ): Promise<BackendMessage[]> {\n return await this.execProtocolStream(message, {\n ...options,\n syncToFs: false,\n })\n }\n\n /**\n * Re-syncs the array types from the database\n * This is useful if you add a new type to the database and want to use it, otherwise pglite won't recognize it.\n */\n async refreshArrayTypes() {\n await this._initArrayTypes({ force: true })\n }\n\n /**\n * Execute a single SQL statement\n * This uses the \"Extended Query\" postgres wire protocol message.\n * @param query The query to execute\n * @param params Optional parameters for the query\n * @returns The result of the query\n */\n async query<T>(\n query: string,\n params?: any[],\n options?: QueryOptions,\n ): Promise<Results<T>> {\n await this._checkReady()\n // We wrap the public query method in the transaction mutex to ensure that\n // only one query can be executed at a time and not concurrently with a\n // transaction.\n return await this._runExclusiveTransaction(async () => {\n return await this.#runQuery<T>(query, params, options)\n })\n }\n\n /**\n * Execute a single SQL statement like with {@link PGlite.query}, but with a\n * templated statement where template values will be treated as parameters.\n *\n * You can use helpers from `/template` to further format the query with\n * identifiers, raw SQL, and nested statements.\n *\n * This uses the \"Extended Query\" postgres wire protocol message.\n *\n * @param query The query to execute with parameters as template values\n * @returns The result of the query\n *\n * @example\n * ```ts\n * const results = await db.sql`SELECT * FROM ${identifier`foo`} WHERE id = ${id}`\n * ```\n */\n async sql<T>(\n sqlStrings: TemplateStringsArray,\n ...params: any[]\n ): Promise<Results<T>> {\n const { query, params: actualParams } = queryTemplate(sqlStrings, ...params)\n return await this.query(query, actualParams)\n }\n\n /**\n * Execute a SQL query, this can have multiple statements.\n * This uses the \"Simple Query\" postgres wire protocol message.\n * @param query The query to execute\n * @returns The result of the query\n */\n async exec(query: string, options?: QueryOptions): Promise<Array<Results>> {\n await this._checkReady()\n // We wrap the public exec method in the transaction mutex to ensure that\n // only one query can be executed at a time and not concurrently with a\n // transaction.\n return await this._runExclusiveTransaction(async () => {\n return await this.#runExec(query, options)\n })\n }\n\n /**\n * Internal method to execute a query\n * Not protected by the transaction mutex, so it can be used inside a transaction\n * @param query The query to execute\n * @param params Optional parameters for the query\n * @returns The result of the query\n */\n async #runQuery<T>(\n query: string,\n params: any[] = [],\n options?: QueryOptions,\n ): Promise<Results<T>> {\n return await this._runExclusiveQuery(async () => {\n // We need to parse, bind and execute a query with parameters\n this.#log('runQuery', query, params, options)\n await this._handleBlob(options?.blob)\n\n let results = []\n\n try {\n const parseResults = await this.#execProtocolNoSync(\n serializeProtocol.parse({ text: query, types: options?.paramTypes }),\n options,\n )\n\n const dataTypeIDs = parseDescribeStatementResults(\n await this.#execProtocolNoSync(\n serializeProtocol.describe({ type: 'S' }),\n options,\n ),\n )\n\n const values = params.map((param, i) => {\n const oid = dataTypeIDs[i]\n if (param === null || param === undefined) {\n return null\n }\n const serialize = options?.serializers?.[oid] ?? this.serializers[oid]\n if (serialize) {\n return serialize(param)\n } else {\n return param.toString()\n }\n })\n\n results = [\n ...parseResults,\n ...(await this.#execProtocolNoSync(\n serializeProtocol.bind({\n values,\n }),\n options,\n )),\n ...(await this.#execProtocolNoSync(\n serializeProtocol.describe({ type: 'P' }),\n options,\n )),\n ...(await this.#execProtocolNoSync(\n serializeProtocol.execute({}),\n options,\n )),\n ]\n } catch (e) {\n if (e instanceof DatabaseError) {\n const pgError = makePGliteError({ e, options, params, query })\n throw pgError\n }\n throw e\n } finally {\n results.push(\n ...(await this.#execProtocolNoSync(\n serializeProtocol.sync(),\n options,\n )),\n )\n }\n\n await this._cleanupBlob()\n if (!this.#inTransaction) {\n await this.syncToFs()\n }\n const blob = await this._getWrittenBlob()\n return parseResults(results, this.parsers, options, blob)[0] as Results<T>\n })\n }\n\n /**\n * Internal method to execute a query\n * Not protected by the transaction mutex, so it can be used inside a transaction\n * @param query The query to execute\n * @param params Optional parameters for the query\n * @returns The result of the query\n */\n async #runExec(\n query: string,\n options?: QueryOptions,\n ): Promise<Array<Results>> {\n return await this._runExclusiveQuery(async () => {\n // No params so we can just send the query\n this.#log('runExec', query, options)\n await this._handleBlob(options?.blob)\n let results = []\n try {\n results = await this.#execProtocolNoSync(\n serializeProtocol.query(query),\n options,\n )\n } catch (e) {\n if (e instanceof DatabaseError) {\n const pgError = makePGliteError({\n e,\n options,\n params: undefined,\n query,\n })\n throw pgError\n }\n throw e\n } finally {\n results.push(\n ...(await this.#execProtocolNoSync(\n serializeProtocol.sync(),\n options,\n )),\n )\n }\n this._cleanupBlob()\n if (!this.#inTransaction) {\n await this.syncToFs()\n }\n const blob = await this._getWrittenBlob()\n return parseResults(\n results,\n this.parsers,\n options,\n blob,\n ) as Array<Results>\n })\n }\n\n /**\n * Describe a query\n * @param query The query to describe\n * @returns A description of the result types for the query\n */\n async describeQuery(\n query: string,\n options?: QueryOptions,\n ): Promise<DescribeQueryResult> {\n let messages = []\n try {\n await this.#execProtocolNoSync(\n serializeProtocol.parse({ text: query, types: options?.paramTypes }),\n options,\n )\n\n messages = await this.#execProtocolNoSync(\n serializeProtocol.describe({ type: 'S' }),\n options,\n )\n } catch (e) {\n if (e instanceof DatabaseError) {\n const pgError = makePGliteError({\n e,\n options,\n params: undefined,\n query,\n })\n throw pgError\n }\n throw e\n } finally {\n messages.push(\n ...(await this.#execProtocolNoSync(serializeProtocol.sync(), options)),\n )\n }\n\n const paramDescription = messages.find(\n (msg): msg is ParameterDescriptionMessage =>\n msg.name === 'parameterDescription',\n )\n const resultDescription = messages.find(\n (msg): msg is RowDescriptionMessage => msg.name === 'rowDescription',\n )\n\n const queryParams =\n paramDescription?.dataTypeIDs.map((dataTypeID) => ({\n dataTypeID,\n serializer: this.serializers[dataTypeID],\n })) ?? []\n\n const resultFields =\n resultDescription?.fields.map((field) => ({\n name: field.name,\n dataTypeID: field.dataTypeID,\n parser: this.parsers[field.dataTypeID],\n })) ?? []\n\n return { queryParams, resultFields }\n }\n\n /**\n * Execute a transaction\n * @param callback A callback function that takes a transaction object\n * @returns The result of the transaction\n */\n async transaction<T>(callback: (tx: Transaction) => Promise<T>): Promise<T> {\n await this._checkReady()\n return await this._runExclusiveTransaction(async () => {\n await this.#runExec('BEGIN')\n this.#inTransaction = true\n\n // Once a transaction is closed, we throw an error if it's used again\n let closed = false\n const checkClosed = () => {\n if (closed) {\n throw new Error('Transaction is closed')\n }\n }\n\n const tx: Transaction = {\n query: async <T>(\n query: string,\n params?: any[],\n options?: QueryOptions,\n ): Promise<Results<T>> => {\n checkClosed()\n return await this.#runQuery(query, params, options)\n },\n sql: async <T>(\n sqlStrings: TemplateStringsArray,\n ...params: any[]\n ): Promise<Results<T>> => {\n const { query, params: actualParams } = queryTemplate(\n sqlStrings,\n ...params,\n )\n return await this.#runQuery(query, actualParams)\n },\n exec: async (\n query: string,\n options?: QueryOptions,\n ): Promise<Array<Results>> => {\n checkClosed()\n return await this.#runExec(query, options)\n },\n rollback: async () => {\n checkClosed()\n // Rollback and set the closed flag to prevent further use of this\n // transaction\n await this.#runExec('ROLLBACK')\n closed = true\n },\n listen: async (\n channel: string,\n callback: (payload: string) => void,\n ) => {\n checkClosed()\n return await this.listen(channel, callback, tx)\n },\n get closed() {\n return closed\n },\n }\n\n try {\n const result = await callback(tx)\n if (!closed) {\n closed = true\n await this.#runExec('COMMIT')\n }\n this.#inTransaction = false\n return result\n } catch (e) {\n if (!closed) {\n await this.#runExec('ROLLBACK')\n }\n this.#inTransaction = false\n throw e\n }\n })\n }\n\n /**\n * Run a function exclusively, no other transactions or queries will be allowed\n * while the function is running.\n * This is useful when working with the execProtocol methods as they are not blocked,\n * and do not block the locks used by transactions and queries.\n * @param fn The function to run\n * @returns The result of the function\n */\n async runExclusive<T>(fn: () => Promise<T>): Promise<T> {\n return await this._runExclusiveQuery(fn)\n }\n\n /**\n * Internal log function\n */\n #log(...args: any[]) {\n if (this.debug > 0) {\n console.log(...args)\n }\n }\n}\n","import { DatabaseError } from '@electric-sql/pg-protocol/messages'\nimport { QueryOptions } from './interface'\n\nexport interface PGliteError extends DatabaseError {\n query: string | undefined\n params: any[] | undefined\n queryOptions: QueryOptions | undefined\n}\n\nexport function makePGliteError(data: {\n e: DatabaseError\n query: string\n params: any[] | undefined\n options: QueryOptions | undefined\n}) {\n const pgError = data.e as PGliteError\n pgError.query = data.query\n pgError.params = data.params\n pgError.queryOptions = data.options\n return pgError\n}\n"],"mappings":"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","names":["init_esm_shims","init_esm_shims","makePGliteError","data","pgError","_arrayTypesInitialized","_inTransaction","_BasePGlite_instances","execProtocolNoSync_fn","runQuery_fn","runExec_fn","log_fn","BasePGlite","__privateAdd","serializers","parsers","force","__privateGet","__privateSet","types","type","x","arraySerializer","arrayParser","query","params","options","__privateMethod","sqlStrings","actualParams","messages","serialize","e","DatabaseError","makePGliteError","paramDescription","msg","resultDescription","queryParams","dataTypeID","resultFields","field","callback","closed","checkClosed","tx","channel","result","fn","message","results","parseResults","dataTypeIDs","parseDescribeStatementResults","values","param","i","oid","blob","args"]}
@@ -1,2 +1,2 @@
1
- import{a as T,c as mr,j as m}from"./chunk-VCBR6USK.js";var w=T(($r,l)=>{"use strict";m();var B=9007199254740991,q=(function(r){return r})();function dr(r){return r===q}function Y(r){return typeof r=="string"||Object.prototype.toString.call(r)=="[object String]"}function lr(r){return Object.prototype.toString.call(r)=="[object Date]"}function U(r){return r!==null&&typeof r=="object"}function N(r){return typeof r=="function"}function fr(r){return typeof r=="number"&&r>-1&&r%1==0&&r<=B}function yr(r){return Object.prototype.toString.call(r)=="[object Array]"}function W(r){return U(r)&&!N(r)&&fr(r.length)}function C(r){return Object.prototype.toString.call(r)=="[object ArrayBuffer]"}function gr(r,e){return Array.prototype.map.call(r,e)}function hr(r,e){var t=q;return N(e)&&Array.prototype.every.call(r,function(s,o,n){var a=e(s,o,n);return a&&(t=s),!a}),t}function Sr(r){return Object.assign.apply(null,arguments)}function X(r){var e,t,s;if(Y(r)){for(t=r.length,s=new Uint8Array(t),e=0;e<t;e++)s[e]=r.charCodeAt(e)&255;return s}return C(r)?new Uint8Array(r):U(r)&&C(r.buffer)?new Uint8Array(r.buffer):W(r)?new Uint8Array(r):U(r)&&N(r.toString)?X(r.toString()):new Uint8Array}l.exports.MAX_SAFE_INTEGER=B;l.exports.isUndefined=dr;l.exports.isString=Y;l.exports.isObject=U;l.exports.isDateTime=lr;l.exports.isFunction=N;l.exports.isArray=yr;l.exports.isArrayLike=W;l.exports.isArrayBuffer=C;l.exports.map=gr;l.exports.find=hr;l.exports.extend=Sr;l.exports.toUint8Array=X});var x=T((Qr,K)=>{"use strict";m();var O="\0";K.exports={NULL_CHAR:O,TMAGIC:"ustar"+O+"00",OLDGNU_MAGIC:"ustar "+O,REGTYPE:0,LNKTYPE:1,SYMTYPE:2,CHRTYPE:3,BLKTYPE:4,DIRTYPE:5,FIFOTYPE:6,CONTTYPE:7,TSUID:parseInt("4000",8),TSGID:parseInt("2000",8),TSVTX:parseInt("1000",8),TUREAD:parseInt("0400",8),TUWRITE:parseInt("0200",8),TUEXEC:parseInt("0100",8),TGREAD:parseInt("0040",8),TGWRITE:parseInt("0020",8),TGEXEC:parseInt("0010",8),TOREAD:parseInt("0004",8),TOWRITE:parseInt("0002",8),TOEXEC:parseInt("0001",8),TPERMALL:parseInt("0777",8),TPERMMASK:parseInt("0777",8)}});var L=T((ee,f)=>{"use strict";m();var V=w(),p=x(),br=512,I=p.TPERMALL,Z=0,$=0,_=[["name",100,0,function(r,e){return v(r[e[0]],e[1])},function(r,e,t){return E(r.slice(e,e+t[1]))}],["mode",8,100,function(r,e){var t=r[e[0]]||I;return t=t&p.TPERMMASK,P(t,e[1],I)},function(r,e,t){var s=S(r.slice(e,e+t[1]));return s&=p.TPERMMASK,s}],["uid",8,108,function(r,e){return P(r[e[0]],e[1],Z)},function(r,e,t){return S(r.slice(e,e+t[1]))}],["gid",8,116,function(r,e){return P(r[e[0]],e[1],$)},function(r,e,t){return S(r.slice(e,e+t[1]))}],["size",12,124,function(r,e){return P(r.data.length,e[1])},function(r,e,t){return S(r.slice(e,e+t[1]))}],["modifyTime",12,136,function(r,e){return k(r[e[0]],e[1])},function(r,e,t){return D(r.slice(e,e+t[1]))}],["checksum",8,148,function(r,e){return" "},function(r,e,t){return S(r.slice(e,e+t[1]))}],["type",1,156,function(r,e){return""+(parseInt(r[e[0]],10)||0)%8},function(r,e,t){return(parseInt(String.fromCharCode(r[e]),10)||0)%8}],["linkName",100,157,function(r,e){return""},function(r,e,t){return E(r.slice(e,e+t[1]))}],["ustar",8,257,function(r,e){return p.TMAGIC},function(r,e,t){return Fr(E(r.slice(e,e+t[1]),!0))},function(r,e){return r[e[0]]==p.TMAGIC||r[e[0]]==p.OLDGNU_MAGIC}],["owner",32,265,function(r,e){return v(r[e[0]],e[1])},function(r,e,t){return E(r.slice(e,e+t[1]))}],["group",32,297,function(r,e){return v(r[e[0]],e[1])},function(r,e,t){return E(r.slice(e,e+t[1]))}],["majorNumber",8,329,function(r,e){return""},function(r,e,t){return S(r.slice(e,e+t[1]))}],["minorNumber",8,337,function(r,e){return""},function(r,e,t){return S(r.slice(e,e+t[1]))}],["prefix",131,345,function(r,e){return v(r[e[0]],e[1])},function(r,e,t){return E(r.slice(e,e+t[1]))}],["accessTime",12,476,function(r,e){return k(r[e[0]],e[1])},function(r,e,t){return D(r.slice(e,e+t[1]))}],["createTime",12,488,function(r,e){return k(r[e[0]],e[1])},function(r,e,t){return D(r.slice(e,e+t[1]))}]],J=(function(r){var e=r[r.length-1];return e[2]+e[1]})(_);function Fr(r){if(r.length==8){var e=r.split("");if(e[5]==p.NULL_CHAR)return(e[6]==" "||e[6]==p.NULL_CHAR)&&(e[6]="0"),(e[7]==" "||e[7]==p.NULL_CHAR)&&(e[7]="0"),e=e.join(""),e==p.TMAGIC?e:r;if(e[7]==p.NULL_CHAR)return e[5]==p.NULL_CHAR&&(e[5]=" "),e[6]==p.NULL_CHAR&&(e[6]=" "),e==p.OLDGNU_MAGIC?e:r}return r}function v(r,e){return e-=1,V.isUndefined(r)&&(r=""),r=(""+r).substr(0,e),r+p.NULL_CHAR}function P(r,e,t){for(t=parseInt(t)||0,e-=1,r=(parseInt(r)||t).toString(8).substr(-e,e);r.length<e;)r="0"+r;return r+p.NULL_CHAR}function k(r,e){if(V.isDateTime(r))r=Math.floor(1*r/1e3);else if(r=parseInt(r,10),isFinite(r)){if(r<=0)return""}else r=Math.floor(1*new Date/1e3);return P(r,e,0)}function E(r,e){var t=String.fromCharCode.apply(null,r);if(e)return t;var s=t.indexOf(p.NULL_CHAR);return s>=0?t.substr(0,s):t}function S(r){var e=String.fromCharCode.apply(null,r);return parseInt(e.replace(/^0+$/g,""),8)||0}function D(r){return r.length==0||r[0]==0?null:new Date(1e3*S(r))}function Ar(r,e,t){var s=parseInt(e,10)||0,o=Math.min(s+J,r.length),n=0,a=0,i=0;t&&_.every(function(d){return d[0]=="checksum"?(a=s+d[2],i=a+d[1],!1):!0});for(var u=32,c=s;c<o;c++){var y=c>=a&&c<i?u:r[c];n=(n+y)%262144}return n}f.exports.recordSize=br;f.exports.defaultFileMode=I;f.exports.defaultUid=Z;f.exports.defaultGid=$;f.exports.posixHeader=_;f.exports.effectiveHeaderSize=J;f.exports.calculateChecksum=Ar;f.exports.formatTarString=v;f.exports.formatTarNumber=P;f.exports.formatTarDateTime=k;f.exports.parseTarString=E;f.exports.parseTarNumber=S;f.exports.parseTarDateTime=D});var tr=T((ne,er)=>{"use strict";m();var Er=x(),z=w(),b=L();function Q(r){return b.recordSize}function rr(r){return Math.ceil(r.data.length/b.recordSize)*b.recordSize}function Tr(r){var e=0;return r.forEach(function(t){e+=Q(t)+rr(t)}),e+=b.recordSize*2,new Uint8Array(e)}function Pr(r,e,t){t=parseInt(t)||0;var s=t;b.posixHeader.forEach(function(u){for(var c=u[3](e,u),y=c.length,d=0;d<y;d+=1)r[s+d]=c.charCodeAt(d)&255;s+=u[1]});var o=z.find(b.posixHeader,function(u){return u[0]=="checksum"});if(o){var n=b.calculateChecksum(r,t,!0),a=b.formatTarNumber(n,o[1]-2)+Er.NULL_CHAR+" ";s=t+o[2];for(var i=0;i<a.length;i+=1)r[s]=a.charCodeAt(i)&255,s++}return t+Q(e)}function wr(r,e,t){return t=parseInt(t,10)||0,r.set(e.data,t),t+rr(e)}function xr(r){r=z.map(r,function(s){return z.extend({},s,{data:z.toUint8Array(s.data)})});var e=Tr(r),t=0;return r.forEach(function(s){t=Pr(e,s,t),t=wr(e,s,t)}),e}er.exports.tar=xr});var ir=T((oe,nr)=>{"use strict";m();var vr=x(),G=w(),h=L(),Ur={extractData:!0,checkHeader:!0,checkChecksum:!0,checkFileSize:!0},Nr={size:!0,checksum:!0,ustar:!0},R={unexpectedEndOfFile:"Unexpected end of file.",fileCorrupted:"File is corrupted.",checksumCheckFailed:"Checksum check failed."};function kr(r){return h.recordSize}function Dr(r){return Math.ceil(r/h.recordSize)*h.recordSize}function zr(r,e){for(var t=e,s=Math.min(r.length,e+h.recordSize*2),o=t;o<s;o++)if(r[o]!=0)return!1;return!0}function Mr(r,e,t){if(r.length-e<h.recordSize){if(t.checkFileSize)throw new Error(R.unexpectedEndOfFile);return null}e=parseInt(e)||0;var s={},o=e;if(h.posixHeader.forEach(function(i){s[i[0]]=i[4](r,o,i),o+=i[1]}),s.type!=0&&(s.size=0),t.checkHeader&&h.posixHeader.forEach(function(i){if(G.isFunction(i[5])&&!i[5](s,i)){var u=new Error(R.fileCorrupted);throw u.data={offset:e+i[2],field:i[0]},u}}),t.checkChecksum){var n=h.calculateChecksum(r,e,!0);if(n!=s.checksum){var a=new Error(R.checksumCheckFailed);throw a.data={offset:e,header:s,checksum:n},a}}return s}function Cr(r,e,t,s){return s.extractData?t.size<=0?new Uint8Array:r.slice(e,e+t.size):null}function Or(r,e){var t={};return h.posixHeader.forEach(function(s){var o=s[0];Nr[o]||(t[o]=r[o])}),t.isOldGNUFormat=r.ustar==vr.OLDGNU_MAGIC,e&&(t.data=e),t}function Ir(r,e){e=G.extend({},Ur,e);for(var t=[],s=0,o=r.length;o-s>=h.recordSize;){r=G.toUint8Array(r);var n=Mr(r,s,e);if(!n)break;s+=kr(n);var a=Cr(r,s,n,e);if(t.push(Or(n,a)),s+=Dr(n.size),zr(r,s))break}return t}nr.exports.untar=Ir});var ar=T((se,or)=>{"use strict";m();var _r=w(),Lr=x(),Rr=tr(),Gr=ir();_r.extend(or.exports,Rr,Gr,Lr)});m();m();var g=mr(ar(),1);async function H(r,e,t="pgdata",s="auto"){let o=Br(r,e),[n,a]=await qr(o,s),i=t+(a?".tar.gz":".tar"),u=a?"application/x-gzip":"application/x-tar";return typeof File<"u"?new File([n.buffer],i,{type:u}):new Blob([n.buffer],{type:u})}var Hr=["application/x-gtar","application/x-tar+gzip","application/x-gzip","application/gzip"];async function ce(r,e,t){let s=new Uint8Array(await e.arrayBuffer()),o=typeof File<"u"&&e instanceof File?e.name:void 0;(Hr.includes(e.type)||o?.endsWith(".tgz")||o?.endsWith(".tar.gz"))&&(s=await sr(s));let a;try{a=(0,g.untar)(s)}catch(i){if(i instanceof Error&&i.message.includes("File is corrupted"))s=await sr(s),a=(0,g.untar)(s);else throw i}for(let i of a){let u=t+i.name,c=u.split("/").slice(0,-1);for(let y=1;y<=c.length;y++){let d=c.slice(0,y).join("/");r.analyzePath(d).exists||r.mkdir(d)}i.type===g.REGTYPE?(r.writeFile(u,i.data),r.utime(u,ur(i.modifyTime),ur(i.modifyTime))):i.type===g.DIRTYPE&&r.mkdir(u)}}function jr(r,e){let t=[],s=o=>{r.readdir(o).forEach(a=>{if(a==="."||a==="..")return;let i=o+"/"+a,u=r.stat(i),c=r.isFile(u.mode)?r.readFile(i,{encoding:"binary"}):new Uint8Array(0);t.push({name:i.substring(e.length),mode:u.mode,size:u.size,type:r.isFile(u.mode)?g.REGTYPE:g.DIRTYPE,modifyTime:u.mtime,data:c}),r.isDir(u.mode)&&s(i)})};return s(e),t}function Br(r,e){let t=jr(r,e);return(0,g.tar)(t)}async function qr(r,e="auto"){if(e==="none")return[r,!1];if(typeof CompressionStream<"u")return[await Yr(r),!0];if(typeof process<"u"&&process.versions&&process.versions.node)return[await Wr(r),!0];if(e==="auto")return[r,!1];throw new Error("Compression not supported in this environment")}async function Yr(r){let e=new CompressionStream("gzip"),t=e.writable.getWriter(),s=e.readable.getReader();t.write(r.buffer),t.close();let o=[];for(;;){let{value:i,done:u}=await s.read();if(u)break;i&&o.push(i)}let n=new Uint8Array(o.reduce((i,u)=>i+u.length,0)),a=0;return o.forEach(i=>{n.set(i,a),a+=i.length}),n}async function Wr(r){let{promisify:e}=await import("util"),{gzip:t}=await import("zlib");return await e(t)(r)}async function sr(r){if(typeof CompressionStream<"u")return await Xr(r);if(typeof process<"u"&&process.versions&&process.versions.node)return await Kr(r);throw new Error("Unsupported environment for decompression")}async function Xr(r){let e=new DecompressionStream("gzip"),t=e.writable.getWriter(),s=e.readable.getReader();t.write(r.buffer),t.close();let o=[];for(;;){let{value:i,done:u}=await s.read();if(u)break;i&&o.push(i)}let n=new Uint8Array(o.reduce((i,u)=>i+u.length,0)),a=0;return o.forEach(i=>{n.set(i,a),a+=i.length}),n}async function Kr(r){let{promisify:e}=await import("util"),{gunzip:t}=await import("zlib");return await e(t)(r)}function ur(r){return r?typeof r=="number"?r:Math.floor(r.getTime()/1e3):Math.floor(Date.now()/1e3)}var Vr="/tmp/pglite",M=Vr+"/base",cr=class{constructor(e){this.dataDir=e}async init(e,t){return this.pg=e,{emscriptenOpts:t}}async syncToFs(e){}async initialSyncFs(){}async closeFs(){}async dumpTar(e,t){return H(this.pg.Module.FS,M,e,t)}},pr=class{constructor(e,{debug:t=!1}={}){this.dataDir=e,this.debug=t}async syncToFs(e){}async initialSyncFs(){}async closeFs(){}async dumpTar(e,t){return H(this.pg.Module.FS,M,e,t)}async init(e,t){return this.pg=e,{emscriptenOpts:{...t,preRun:[...t.preRun||[],o=>{let n=Zr(o,this);o.FS.mkdir(M),o.FS.mount(n,{},M)}]}}}},j={EBADF:8,EBADFD:127,EEXIST:20,EINVAL:28,EISDIR:31,ENODEV:43,ENOENT:44,ENOTDIR:54,ENOTEMPTY:55},Zr=(r,e)=>{let t=r.FS,s=e.debug?console.log:null,o={tryFSOperation(n){try{return n()}catch(a){let i=a;throw i.code?i.code===j.EINVAL?new t.ErrnoError(j.EINVAL):new t.ErrnoError(i.code):a}},mount(n){return o.createNode(null,"/",16895,0)},syncfs(n,a,i){},createNode(n,a,i,u){if(!t.isDir(i)&&!t.isFile(i))throw new t.ErrnoError(28);let c=t.createNode(n,a,i);return c.node_ops=o.node_ops,c.stream_ops=o.stream_ops,c},getMode:function(n){return s?.("getMode",n),o.tryFSOperation(()=>e.lstat(n).mode)},realPath:function(n){let a=[];for(;n.parent!==n;)a.push(n.name),n=n.parent;return a.push(n.mount.opts.root),a.reverse(),a.join("/")},node_ops:{getattr(n){s?.("getattr",o.realPath(n));let a=o.realPath(n);return o.tryFSOperation(()=>{let i=e.lstat(a);return{...i,dev:0,ino:n.id,nlink:1,rdev:n.rdev,atime:new Date(i.atime),mtime:new Date(i.mtime),ctime:new Date(i.ctime)}})},setattr(n,a){s?.("setattr",o.realPath(n),a);let i=o.realPath(n);o.tryFSOperation(()=>{a.mode!==void 0&&e.chmod(i,a.mode),a.size!==void 0&&e.truncate(i,a.size),a.timestamp!==void 0&&e.utimes(i,a.timestamp,a.timestamp),a.size!==void 0&&e.truncate(i,a.size)})},lookup(n,a){s?.("lookup",o.realPath(n),a);let i=[o.realPath(n),a].join("/"),u=o.getMode(i);return o.createNode(n,a,u)},mknod(n,a,i,u){s?.("mknod",o.realPath(n),a,i,u);let c=o.createNode(n,a,i,u),y=o.realPath(c);return o.tryFSOperation(()=>(t.isDir(c.mode)?e.mkdir(y,{mode:i}):e.writeFile(y,"",{mode:i}),c))},rename(n,a,i){s?.("rename",o.realPath(n),o.realPath(a),i);let u=o.realPath(n),c=[o.realPath(a),i].join("/");o.tryFSOperation(()=>{e.rename(u,c)}),n.name=i},unlink(n,a){s?.("unlink",o.realPath(n),a);let i=[o.realPath(n),a].join("/");try{e.unlink(i)}catch{}},rmdir(n,a){s?.("rmdir",o.realPath(n),a);let i=[o.realPath(n),a].join("/");return o.tryFSOperation(()=>{e.rmdir(i)})},readdir(n){s?.("readdir",o.realPath(n));let a=o.realPath(n);return o.tryFSOperation(()=>e.readdir(a))},symlink(n,a,i){throw s?.("symlink",o.realPath(n),a,i),new t.ErrnoError(63)},readlink(n){throw s?.("readlink",o.realPath(n)),new t.ErrnoError(63)}},stream_ops:{open(n){s?.("open stream",o.realPath(n.node));let a=o.realPath(n.node);return o.tryFSOperation(()=>{t.isFile(n.node.mode)&&(n.shared.refcount=1,n.nfd=e.open(a))})},close(n){return s?.("close stream",o.realPath(n.node)),o.tryFSOperation(()=>{t.isFile(n.node.mode)&&n.nfd&&--n.shared.refcount===0&&e.close(n.nfd)})},dup(n){s?.("dup stream",o.realPath(n.node)),n.shared.refcount++},read(n,a,i,u,c){return s?.("read stream",o.realPath(n.node),i,u,c),u===0?0:o.tryFSOperation(()=>e.read(n.nfd,a,i,u,c))},write(n,a,i,u,c){return s?.("write stream",o.realPath(n.node),i,u,c),o.tryFSOperation(()=>e.write(n.nfd,a.buffer,i,u,c))},llseek(n,a,i){s?.("llseek stream",o.realPath(n.node),a,i);let u=a;if(i===1?u+=n.position:i===2&&t.isFile(n.node.mode)&&o.tryFSOperation(()=>{let c=e.fstat(n.nfd);u+=c.size}),u<0)throw new t.ErrnoError(28);return u},mmap(n,a,i,u,c){if(s?.("mmap stream",o.realPath(n.node),a,i,u,c),!t.isFile(n.node.mode))throw new t.ErrnoError(j.ENODEV);let d=r.mmapAlloc(a);return o.stream_ops.read(n,r.HEAP8,d,a,i),{ptr:d,allocated:!0}},msync(n,a,i,u,c){return s?.("msync stream",o.realPath(n.node),i,u,c),o.stream_ops.write(n,a,0,u,i),0}}};return o};export{ar as a,ce as b,Vr as c,M as d,cr as e,pr as f,j as g};
2
- //# sourceMappingURL=chunk-XGK36GMM.js.map
1
+ import{a as T,c as mr,j as m}from"./chunk-VCBR6USK.js";var P=T(($r,l)=>{"use strict";m();var B=9007199254740991,q=(function(r){return r})();function dr(r){return r===q}function Y(r){return typeof r=="string"||Object.prototype.toString.call(r)=="[object String]"}function lr(r){return Object.prototype.toString.call(r)=="[object Date]"}function U(r){return r!==null&&typeof r=="object"}function N(r){return typeof r=="function"}function fr(r){return typeof r=="number"&&r>-1&&r%1==0&&r<=B}function yr(r){return Object.prototype.toString.call(r)=="[object Array]"}function W(r){return U(r)&&!N(r)&&fr(r.length)}function O(r){return Object.prototype.toString.call(r)=="[object ArrayBuffer]"}function gr(r,e){return Array.prototype.map.call(r,e)}function hr(r,e){var t=q;return N(e)&&Array.prototype.every.call(r,function(s,o,n){var a=e(s,o,n);return a&&(t=s),!a}),t}function Sr(r){return Object.assign.apply(null,arguments)}function X(r){var e,t,s;if(Y(r)){for(t=r.length,s=new Uint8Array(t),e=0;e<t;e++)s[e]=r.charCodeAt(e)&255;return s}return O(r)?new Uint8Array(r):U(r)&&O(r.buffer)?new Uint8Array(r.buffer):W(r)?new Uint8Array(r):U(r)&&N(r.toString)?X(r.toString()):new Uint8Array}l.exports.MAX_SAFE_INTEGER=B;l.exports.isUndefined=dr;l.exports.isString=Y;l.exports.isObject=U;l.exports.isDateTime=lr;l.exports.isFunction=N;l.exports.isArray=yr;l.exports.isArrayLike=W;l.exports.isArrayBuffer=O;l.exports.map=gr;l.exports.find=hr;l.exports.extend=Sr;l.exports.toUint8Array=X});var x=T((Qr,K)=>{"use strict";m();var C="\0";K.exports={NULL_CHAR:C,TMAGIC:"ustar"+C+"00",OLDGNU_MAGIC:"ustar "+C,REGTYPE:0,LNKTYPE:1,SYMTYPE:2,CHRTYPE:3,BLKTYPE:4,DIRTYPE:5,FIFOTYPE:6,CONTTYPE:7,TSUID:parseInt("4000",8),TSGID:parseInt("2000",8),TSVTX:parseInt("1000",8),TUREAD:parseInt("0400",8),TUWRITE:parseInt("0200",8),TUEXEC:parseInt("0100",8),TGREAD:parseInt("0040",8),TGWRITE:parseInt("0020",8),TGEXEC:parseInt("0010",8),TOREAD:parseInt("0004",8),TOWRITE:parseInt("0002",8),TOEXEC:parseInt("0001",8),TPERMALL:parseInt("0777",8),TPERMMASK:parseInt("0777",8)}});var L=T((ee,f)=>{"use strict";m();var V=P(),p=x(),br=512,I=p.TPERMALL,Z=0,$=0,_=[["name",100,0,function(r,e){return v(r[e[0]],e[1])},function(r,e,t){return A(r.slice(e,e+t[1]))}],["mode",8,100,function(r,e){var t=r[e[0]]||I;return t=t&p.TPERMMASK,w(t,e[1],I)},function(r,e,t){var s=S(r.slice(e,e+t[1]));return s&=p.TPERMMASK,s}],["uid",8,108,function(r,e){return w(r[e[0]],e[1],Z)},function(r,e,t){return S(r.slice(e,e+t[1]))}],["gid",8,116,function(r,e){return w(r[e[0]],e[1],$)},function(r,e,t){return S(r.slice(e,e+t[1]))}],["size",12,124,function(r,e){return w(r.data.length,e[1])},function(r,e,t){return S(r.slice(e,e+t[1]))}],["modifyTime",12,136,function(r,e){return k(r[e[0]],e[1])},function(r,e,t){return D(r.slice(e,e+t[1]))}],["checksum",8,148,function(r,e){return" "},function(r,e,t){return S(r.slice(e,e+t[1]))}],["type",1,156,function(r,e){return""+(parseInt(r[e[0]],10)||0)%8},function(r,e,t){return(parseInt(String.fromCharCode(r[e]),10)||0)%8}],["linkName",100,157,function(r,e){return""},function(r,e,t){return A(r.slice(e,e+t[1]))}],["ustar",8,257,function(r,e){return p.TMAGIC},function(r,e,t){return Fr(A(r.slice(e,e+t[1]),!0))},function(r,e){return r[e[0]]==p.TMAGIC||r[e[0]]==p.OLDGNU_MAGIC}],["owner",32,265,function(r,e){return v(r[e[0]],e[1])},function(r,e,t){return A(r.slice(e,e+t[1]))}],["group",32,297,function(r,e){return v(r[e[0]],e[1])},function(r,e,t){return A(r.slice(e,e+t[1]))}],["majorNumber",8,329,function(r,e){return""},function(r,e,t){return S(r.slice(e,e+t[1]))}],["minorNumber",8,337,function(r,e){return""},function(r,e,t){return S(r.slice(e,e+t[1]))}],["prefix",131,345,function(r,e){return v(r[e[0]],e[1])},function(r,e,t){return A(r.slice(e,e+t[1]))}],["accessTime",12,476,function(r,e){return k(r[e[0]],e[1])},function(r,e,t){return D(r.slice(e,e+t[1]))}],["createTime",12,488,function(r,e){return k(r[e[0]],e[1])},function(r,e,t){return D(r.slice(e,e+t[1]))}]],J=(function(r){var e=r[r.length-1];return e[2]+e[1]})(_);function Fr(r){if(r.length==8){var e=r.split("");if(e[5]==p.NULL_CHAR)return(e[6]==" "||e[6]==p.NULL_CHAR)&&(e[6]="0"),(e[7]==" "||e[7]==p.NULL_CHAR)&&(e[7]="0"),e=e.join(""),e==p.TMAGIC?e:r;if(e[7]==p.NULL_CHAR)return e[5]==p.NULL_CHAR&&(e[5]=" "),e[6]==p.NULL_CHAR&&(e[6]=" "),e==p.OLDGNU_MAGIC?e:r}return r}function v(r,e){return e-=1,V.isUndefined(r)&&(r=""),r=(""+r).substr(0,e),r+p.NULL_CHAR}function w(r,e,t){for(t=parseInt(t)||0,e-=1,r=(parseInt(r)||t).toString(8).substr(-e,e);r.length<e;)r="0"+r;return r+p.NULL_CHAR}function k(r,e){if(V.isDateTime(r))r=Math.floor(1*r/1e3);else if(r=parseInt(r,10),isFinite(r)){if(r<=0)return""}else r=Math.floor(1*new Date/1e3);return w(r,e,0)}function A(r,e){var t=String.fromCharCode.apply(null,r);if(e)return t;var s=t.indexOf(p.NULL_CHAR);return s>=0?t.substr(0,s):t}function S(r){var e=String.fromCharCode.apply(null,r);return parseInt(e.replace(/^0+$/g,""),8)||0}function D(r){return r.length==0||r[0]==0?null:new Date(1e3*S(r))}function Er(r,e,t){var s=parseInt(e,10)||0,o=Math.min(s+J,r.length),n=0,a=0,i=0;t&&_.every(function(d){return d[0]=="checksum"?(a=s+d[2],i=a+d[1],!1):!0});for(var u=32,c=s;c<o;c++){var y=c>=a&&c<i?u:r[c];n=(n+y)%262144}return n}f.exports.recordSize=br;f.exports.defaultFileMode=I;f.exports.defaultUid=Z;f.exports.defaultGid=$;f.exports.posixHeader=_;f.exports.effectiveHeaderSize=J;f.exports.calculateChecksum=Er;f.exports.formatTarString=v;f.exports.formatTarNumber=w;f.exports.formatTarDateTime=k;f.exports.parseTarString=A;f.exports.parseTarNumber=S;f.exports.parseTarDateTime=D});var tr=T((ne,er)=>{"use strict";m();var Ar=x(),z=P(),b=L();function Q(r){return b.recordSize}function rr(r){return Math.ceil(r.data.length/b.recordSize)*b.recordSize}function Tr(r){var e=0;return r.forEach(function(t){e+=Q(t)+rr(t)}),e+=b.recordSize*2,new Uint8Array(e)}function wr(r,e,t){t=parseInt(t)||0;var s=t;b.posixHeader.forEach(function(u){for(var c=u[3](e,u),y=c.length,d=0;d<y;d+=1)r[s+d]=c.charCodeAt(d)&255;s+=u[1]});var o=z.find(b.posixHeader,function(u){return u[0]=="checksum"});if(o){var n=b.calculateChecksum(r,t,!0),a=b.formatTarNumber(n,o[1]-2)+Ar.NULL_CHAR+" ";s=t+o[2];for(var i=0;i<a.length;i+=1)r[s]=a.charCodeAt(i)&255,s++}return t+Q(e)}function Pr(r,e,t){return t=parseInt(t,10)||0,r.set(e.data,t),t+rr(e)}function xr(r){r=z.map(r,function(s){return z.extend({},s,{data:z.toUint8Array(s.data)})});var e=Tr(r),t=0;return r.forEach(function(s){t=wr(e,s,t),t=Pr(e,s,t)}),e}er.exports.tar=xr});var ir=T((oe,nr)=>{"use strict";m();var vr=x(),G=P(),h=L(),Ur={extractData:!0,checkHeader:!0,checkChecksum:!0,checkFileSize:!0},Nr={size:!0,checksum:!0,ustar:!0},R={unexpectedEndOfFile:"Unexpected end of file.",fileCorrupted:"File is corrupted.",checksumCheckFailed:"Checksum check failed."};function kr(r){return h.recordSize}function Dr(r){return Math.ceil(r/h.recordSize)*h.recordSize}function zr(r,e){for(var t=e,s=Math.min(r.length,e+h.recordSize*2),o=t;o<s;o++)if(r[o]!=0)return!1;return!0}function Mr(r,e,t){if(r.length-e<h.recordSize){if(t.checkFileSize)throw new Error(R.unexpectedEndOfFile);return null}e=parseInt(e)||0;var s={},o=e;if(h.posixHeader.forEach(function(i){s[i[0]]=i[4](r,o,i),o+=i[1]}),s.type!=0&&(s.size=0),t.checkHeader&&h.posixHeader.forEach(function(i){if(G.isFunction(i[5])&&!i[5](s,i)){var u=new Error(R.fileCorrupted);throw u.data={offset:e+i[2],field:i[0]},u}}),t.checkChecksum){var n=h.calculateChecksum(r,e,!0);if(n!=s.checksum){var a=new Error(R.checksumCheckFailed);throw a.data={offset:e,header:s,checksum:n},a}}return s}function Or(r,e,t,s){return s.extractData?t.size<=0?new Uint8Array:r.slice(e,e+t.size):null}function Cr(r,e){var t={};return h.posixHeader.forEach(function(s){var o=s[0];Nr[o]||(t[o]=r[o])}),t.isOldGNUFormat=r.ustar==vr.OLDGNU_MAGIC,e&&(t.data=e),t}function Ir(r,e){e=G.extend({},Ur,e);for(var t=[],s=0,o=r.length;o-s>=h.recordSize;){r=G.toUint8Array(r);var n=Mr(r,s,e);if(!n)break;s+=kr(n);var a=Or(r,s,n,e);if(t.push(Cr(n,a)),s+=Dr(n.size),zr(r,s))break}return t}nr.exports.untar=Ir});var ar=T((se,or)=>{"use strict";m();var _r=P(),Lr=x(),Rr=tr(),Gr=ir();_r.extend(or.exports,Rr,Gr,Lr)});m();m();var g=mr(ar(),1);async function H(r,e,t="pgdata",s="auto"){let o=Br(r,e),[n,a]=await qr(o,s),i=t+(a?".tar.gz":".tar"),u=a?"application/x-gzip":"application/x-tar";return typeof File<"u"?new File([n.buffer],i,{type:u}):new Blob([n.buffer],{type:u})}var Hr=["application/x-gtar","application/x-tar+gzip","application/x-gzip","application/gzip"];async function ce(r,e,t){let s=new Uint8Array(await e.arrayBuffer()),o=typeof File<"u"&&e instanceof File?e.name:void 0;(Hr.includes(e.type)||o?.endsWith(".tgz")||o?.endsWith(".tar.gz"))&&(s=await sr(s));let a;try{a=(0,g.untar)(s)}catch(i){if(i instanceof Error&&i.message.includes("File is corrupted"))s=await sr(s),a=(0,g.untar)(s);else throw i}for(let i of a){let u=t+i.name,c=u.split("/").slice(0,-1);for(let y=1;y<=c.length;y++){let d=c.slice(0,y).join("/");r.analyzePath(d).exists||r.mkdir(d)}i.type===g.REGTYPE?(r.writeFile(u,i.data),r.utime(u,ur(i.modifyTime),ur(i.modifyTime))):i.type===g.DIRTYPE&&r.mkdir(u)}}function jr(r,e){let t=[],s=o=>{r.readdir(o).forEach(a=>{if(a==="."||a==="..")return;let i=o+"/"+a,u=r.stat(i),c=r.isFile(u.mode)?r.readFile(i,{encoding:"binary"}):new Uint8Array(0);t.push({name:i.substring(e.length),mode:u.mode,size:u.size,type:r.isFile(u.mode)?g.REGTYPE:g.DIRTYPE,modifyTime:u.mtime,data:c}),r.isDir(u.mode)&&s(i)})};return s(e),t}function Br(r,e){let t=jr(r,e);return(0,g.tar)(t)}async function qr(r,e="auto"){if(e==="none")return[r,!1];if(typeof CompressionStream<"u")return[await Yr(r),!0];if(typeof process<"u"&&process.versions&&process.versions.node)return[await Wr(r),!0];if(e==="auto")return[r,!1];throw new Error("Compression not supported in this environment")}async function Yr(r){let e=new CompressionStream("gzip"),t=e.writable.getWriter(),s=e.readable.getReader();t.write(r.buffer),t.close();let o=[];for(;;){let{value:i,done:u}=await s.read();if(u)break;i&&o.push(i)}let n=new Uint8Array(o.reduce((i,u)=>i+u.length,0)),a=0;return o.forEach(i=>{n.set(i,a),a+=i.length}),n}async function Wr(r){let{promisify:e}=await import("util"),{gzip:t}=await import("zlib");return await e(t)(r)}async function sr(r){if(typeof CompressionStream<"u")return await Xr(r);if(typeof process<"u"&&process.versions&&process.versions.node)return await Kr(r);throw new Error("Unsupported environment for decompression")}async function Xr(r){let e=new DecompressionStream("gzip"),t=e.writable.getWriter(),s=e.readable.getReader();t.write(r.buffer),t.close();let o=[];for(;;){let{value:i,done:u}=await s.read();if(u)break;i&&o.push(i)}let n=new Uint8Array(o.reduce((i,u)=>i+u.length,0)),a=0;return o.forEach(i=>{n.set(i,a),a+=i.length}),n}async function Kr(r){let{promisify:e}=await import("util"),{gunzip:t}=await import("zlib");return await e(t)(r)}function ur(r){return r?typeof r=="number"?r:Math.floor(r.getTime()/1e3):Math.floor(Date.now()/1e3)}var Vr="/tmp/pglite",M=Vr+"/base",cr=class{constructor(e){this.dataDir=e}async init(e,t){return this.pg=e,{emscriptenOpts:t}}async syncToFs(e){}async initialSyncFs(){}async closeFs(){}async dumpTar(e,t){return H(this.pg.Module.FS,M,e,t)}},pr=class{constructor(e,{debug:t=!1}={}){this.dataDir=e,this.debug=t}async syncToFs(e){}async initialSyncFs(){}async closeFs(){}async dumpTar(e,t){return H(this.pg.Module.FS,M,e,t)}async init(e,t){return this.pg=e,{emscriptenOpts:{...t,preRun:[...t.preRun||[],o=>{let n=Zr(o,this);o.FS.mkdir(M),o.FS.mount(n,{},M)}]}}}},j={EBADF:8,EBADFD:127,EEXIST:20,EINVAL:28,EISDIR:31,ENODEV:43,ENOENT:44,ENOTDIR:54,ENOTEMPTY:55},Zr=(r,e)=>{let t=r.FS,s=e.debug?console.log:null,o={tryFSOperation(n){try{return n()}catch(a){let i=a;throw i.code?i.code===j.EINVAL?new t.ErrnoError(j.EINVAL):new t.ErrnoError(i.code):a}},mount(n){return o.createNode(null,"/",16895,0)},syncfs(n,a,i){},createNode(n,a,i,u){if(!t.isDir(i)&&!t.isFile(i))throw new t.ErrnoError(28);let c=t.createNode(n,a,i);return c.node_ops=o.node_ops,c.stream_ops=o.stream_ops,c},getMode:function(n){return s?.("getMode",n),o.tryFSOperation(()=>e.lstat(n).mode)},realPath:function(n){let a=[];for(;n.parent!==n;)a.push(n.name),n=n.parent;return a.push(n.mount.opts.root),a.reverse(),a.join("/")},node_ops:{getattr(n){s?.("getattr",o.realPath(n));let a=o.realPath(n);return o.tryFSOperation(()=>{let i=e.lstat(a);return{...i,dev:0,ino:n.id,nlink:1,rdev:n.rdev,atime:new Date(i.atime),mtime:new Date(i.mtime),ctime:new Date(i.ctime)}})},setattr(n,a){s?.("setattr",o.realPath(n),a);let i=o.realPath(n);o.tryFSOperation(()=>{a.mode!==void 0&&e.chmod(i,a.mode),a.size!==void 0&&e.truncate(i,a.size),a.timestamp!==void 0&&e.utimes(i,a.timestamp,a.timestamp),a.size!==void 0&&e.truncate(i,a.size)})},lookup(n,a){s?.("lookup",o.realPath(n),a);let i=[o.realPath(n),a].join("/"),u=o.getMode(i);return o.createNode(n,a,u)},mknod(n,a,i,u){s?.("mknod",o.realPath(n),a,i,u);let c=o.createNode(n,a,i,u),y=o.realPath(c);return o.tryFSOperation(()=>(t.isDir(c.mode)?e.mkdir(y,{mode:i}):e.writeFile(y,"",{mode:i}),c))},rename(n,a,i){s?.("rename",o.realPath(n),o.realPath(a),i);let u=o.realPath(n),c=[o.realPath(a),i].join("/");o.tryFSOperation(()=>{e.rename(u,c)}),n.name=i},unlink(n,a){s?.("unlink",o.realPath(n),a);let i=[o.realPath(n),a].join("/");try{e.unlink(i)}catch{}},rmdir(n,a){s?.("rmdir",o.realPath(n),a);let i=[o.realPath(n),a].join("/");return o.tryFSOperation(()=>{e.rmdir(i)})},readdir(n){s?.("readdir",o.realPath(n));let a=o.realPath(n);return o.tryFSOperation(()=>e.readdir(a))},symlink(n,a,i){throw s?.("symlink",o.realPath(n),a,i),new t.ErrnoError(63)},readlink(n){throw s?.("readlink",o.realPath(n)),new t.ErrnoError(63)}},stream_ops:{open(n){s?.("open stream",o.realPath(n.node));let a=o.realPath(n.node);return o.tryFSOperation(()=>{t.isFile(n.node.mode)&&(n.shared.refcount=1,n.nfd=e.open(a))})},close(n){return s?.("close stream",o.realPath(n.node)),o.tryFSOperation(()=>{t.isFile(n.node.mode)&&n.nfd&&--n.shared.refcount===0&&e.close(n.nfd)})},dup(n){s?.("dup stream",o.realPath(n.node)),n.shared.refcount++},read(n,a,i,u,c){return s?.("read stream",o.realPath(n.node),i,u,c),u===0?0:o.tryFSOperation(()=>e.read(n.nfd,a,i,u,c))},write(n,a,i,u,c){return s?.("write stream",o.realPath(n.node),i,u,c),o.tryFSOperation(()=>e.write(n.nfd,a.buffer,i,u,c))},llseek(n,a,i){s?.("llseek stream",o.realPath(n.node),a,i);let u=a;if(i===1?u+=n.position:i===2&&t.isFile(n.node.mode)&&o.tryFSOperation(()=>{let c=e.fstat(n.nfd);u+=c.size}),u<0)throw new t.ErrnoError(28);return u},mmap(n,a,i,u,c){if(s?.("mmap stream",o.realPath(n.node),a,i,u,c),!t.isFile(n.node.mode))throw new t.ErrnoError(j.ENODEV);let d=r.mmapAlloc(a);return o.stream_ops.read(n,r.HEAP8,d,a,i),{ptr:d,allocated:!0}},msync(n,a,i,u,c){return s?.("msync stream",o.realPath(n.node),i,u,c),o.stream_ops.write(n,a,0,u,i),0}}};return o};export{ar as a,ce as b,Vr as c,M as d,cr as e,pr as f,j as g};
2
+ //# sourceMappingURL=chunk-J77SUHST.js.map