tinybase 7.0.0-beta.2 → 7.0.0

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 (292) hide show
  1. package/@types/common/index.d.ts +1 -1
  2. package/@types/mergeable-store/index.d.ts +1 -1
  3. package/@types/mergeable-store/with-schemas/index.d.ts +1 -1
  4. package/@types/persisters/persister-cr-sqlite-wasm/index.d.ts +4 -0
  5. package/@types/persisters/persister-cr-sqlite-wasm/with-schemas/index.d.ts +4 -0
  6. package/@types/persisters/persister-durable-object-sql-storage/index.d.ts +4 -0
  7. package/@types/persisters/persister-durable-object-sql-storage/with-schemas/index.d.ts +4 -0
  8. package/@types/persisters/persister-electric-sql/index.d.ts +4 -0
  9. package/@types/persisters/persister-electric-sql/with-schemas/index.d.ts +4 -0
  10. package/@types/persisters/persister-expo-sqlite/index.d.ts +4 -0
  11. package/@types/persisters/persister-expo-sqlite/with-schemas/index.d.ts +4 -0
  12. package/@types/persisters/persister-libsql/index.d.ts +4 -0
  13. package/@types/persisters/persister-libsql/with-schemas/index.d.ts +4 -0
  14. package/@types/persisters/persister-pglite/index.d.ts +5 -1
  15. package/@types/persisters/persister-pglite/with-schemas/index.d.ts +5 -1
  16. package/@types/persisters/persister-postgres/index.d.ts +4 -0
  17. package/@types/persisters/persister-postgres/with-schemas/index.d.ts +4 -0
  18. package/@types/persisters/persister-powersync/index.d.ts +4 -0
  19. package/@types/persisters/persister-powersync/with-schemas/index.d.ts +4 -0
  20. package/@types/persisters/persister-react-native-sqlite/index.d.ts +4 -0
  21. package/@types/persisters/persister-react-native-sqlite/with-schemas/index.d.ts +4 -0
  22. package/@types/persisters/persister-sqlite-bun/index.d.ts +4 -0
  23. package/@types/persisters/persister-sqlite-bun/with-schemas/index.d.ts +4 -0
  24. package/@types/persisters/persister-sqlite-wasm/index.d.ts +4 -0
  25. package/@types/persisters/persister-sqlite-wasm/with-schemas/index.d.ts +4 -0
  26. package/@types/persisters/persister-sqlite3/index.d.ts +4 -0
  27. package/@types/persisters/persister-sqlite3/with-schemas/index.d.ts +4 -0
  28. package/@types/queries/index.d.ts +1 -1
  29. package/@types/store/index.d.ts +21 -19
  30. package/@types/store/with-schemas/index.d.ts +15 -13
  31. package/agents.md +62 -0
  32. package/checkpoints/index.js +8 -6
  33. package/checkpoints/with-schemas/index.js +8 -6
  34. package/common/index.js +4 -3
  35. package/common/with-schemas/index.js +4 -3
  36. package/index.js +60 -30
  37. package/indexes/index.js +7 -5
  38. package/indexes/with-schemas/index.js +7 -5
  39. package/mergeable-store/index.js +51 -21
  40. package/mergeable-store/with-schemas/index.js +51 -21
  41. package/metrics/index.js +7 -5
  42. package/metrics/with-schemas/index.js +7 -5
  43. package/min/checkpoints/index.js +1 -1
  44. package/min/checkpoints/index.js.gz +0 -0
  45. package/min/checkpoints/with-schemas/index.js +1 -1
  46. package/min/checkpoints/with-schemas/index.js.gz +0 -0
  47. package/min/common/index.js +1 -1
  48. package/min/common/index.js.gz +0 -0
  49. package/min/common/with-schemas/index.js +1 -1
  50. package/min/common/with-schemas/index.js.gz +0 -0
  51. package/min/index.js +1 -1
  52. package/min/index.js.gz +0 -0
  53. package/min/indexes/index.js +1 -1
  54. package/min/indexes/index.js.gz +0 -0
  55. package/min/indexes/with-schemas/index.js +1 -1
  56. package/min/indexes/with-schemas/index.js.gz +0 -0
  57. package/min/mergeable-store/index.js +1 -1
  58. package/min/mergeable-store/index.js.gz +0 -0
  59. package/min/mergeable-store/with-schemas/index.js +1 -1
  60. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  61. package/min/metrics/index.js +1 -1
  62. package/min/metrics/index.js.gz +0 -0
  63. package/min/metrics/with-schemas/index.js +1 -1
  64. package/min/metrics/with-schemas/index.js.gz +0 -0
  65. package/min/omni/index.js +1 -1
  66. package/min/omni/index.js.gz +0 -0
  67. package/min/omni/with-schemas/index.js +1 -1
  68. package/min/omni/with-schemas/index.js.gz +0 -0
  69. package/min/persisters/index.js +1 -1
  70. package/min/persisters/index.js.gz +0 -0
  71. package/min/persisters/persister-automerge/index.js +1 -1
  72. package/min/persisters/persister-automerge/index.js.gz +0 -0
  73. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  74. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  75. package/min/persisters/persister-browser/index.js +1 -1
  76. package/min/persisters/persister-browser/index.js.gz +0 -0
  77. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  78. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  79. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  80. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  81. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  82. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  83. package/min/persisters/persister-durable-object-sql-storage/index.js +1 -1
  84. package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
  85. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -1
  86. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
  87. package/min/persisters/persister-durable-object-storage/index.js +1 -1
  88. package/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  89. package/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -1
  90. package/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  91. package/min/persisters/persister-electric-sql/index.js +1 -1
  92. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  93. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  94. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  95. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  96. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  97. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  98. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  99. package/min/persisters/persister-file/index.js +1 -1
  100. package/min/persisters/persister-file/index.js.gz +0 -0
  101. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  102. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  103. package/min/persisters/persister-indexed-db/index.js +1 -1
  104. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  105. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  106. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  107. package/min/persisters/persister-libsql/index.js +1 -1
  108. package/min/persisters/persister-libsql/index.js.gz +0 -0
  109. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  110. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  111. package/min/persisters/persister-partykit-client/index.js +1 -1
  112. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  113. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  114. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  115. package/min/persisters/persister-partykit-server/index.js +1 -1
  116. package/min/persisters/persister-partykit-server/index.js.gz +0 -0
  117. package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
  118. package/min/persisters/persister-partykit-server/with-schemas/index.js.gz +0 -0
  119. package/min/persisters/persister-pglite/index.js +1 -1
  120. package/min/persisters/persister-pglite/index.js.gz +0 -0
  121. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  122. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  123. package/min/persisters/persister-postgres/index.js +1 -1
  124. package/min/persisters/persister-postgres/index.js.gz +0 -0
  125. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  126. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  127. package/min/persisters/persister-powersync/index.js +1 -1
  128. package/min/persisters/persister-powersync/index.js.gz +0 -0
  129. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  130. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  131. package/min/persisters/persister-react-native-mmkv/index.js +1 -1
  132. package/min/persisters/persister-react-native-mmkv/index.js.gz +0 -0
  133. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js +1 -1
  134. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js.gz +0 -0
  135. package/min/persisters/persister-react-native-sqlite/index.js +1 -1
  136. package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
  137. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
  138. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
  139. package/min/persisters/persister-remote/index.js +1 -1
  140. package/min/persisters/persister-remote/index.js.gz +0 -0
  141. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  142. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  143. package/min/persisters/persister-sqlite-bun/index.js +1 -1
  144. package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
  145. package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
  146. package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
  147. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  148. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  149. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  150. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  151. package/min/persisters/persister-sqlite3/index.js +1 -1
  152. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  153. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  154. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  155. package/min/persisters/persister-yjs/index.js +1 -1
  156. package/min/persisters/persister-yjs/index.js.gz +0 -0
  157. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  158. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  159. package/min/persisters/with-schemas/index.js +1 -1
  160. package/min/persisters/with-schemas/index.js.gz +0 -0
  161. package/min/queries/index.js +1 -1
  162. package/min/queries/index.js.gz +0 -0
  163. package/min/queries/with-schemas/index.js +1 -1
  164. package/min/queries/with-schemas/index.js.gz +0 -0
  165. package/min/relationships/index.js +1 -1
  166. package/min/relationships/index.js.gz +0 -0
  167. package/min/relationships/with-schemas/index.js +1 -1
  168. package/min/relationships/with-schemas/index.js.gz +0 -0
  169. package/min/store/index.js +1 -1
  170. package/min/store/index.js.gz +0 -0
  171. package/min/store/with-schemas/index.js +1 -1
  172. package/min/store/with-schemas/index.js.gz +0 -0
  173. package/min/synchronizers/index.js +1 -1
  174. package/min/synchronizers/index.js.gz +0 -0
  175. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  176. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  177. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  178. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  179. package/min/synchronizers/synchronizer-local/index.js +1 -1
  180. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  181. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  182. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  183. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  184. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  185. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  186. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  187. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  188. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  189. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  190. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  191. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  192. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  193. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  194. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  195. package/min/synchronizers/synchronizer-ws-server-simple/index.js +1 -1
  196. package/min/synchronizers/synchronizer-ws-server-simple/index.js.gz +0 -0
  197. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +1 -1
  198. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js.gz +0 -0
  199. package/min/synchronizers/with-schemas/index.js +1 -1
  200. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  201. package/min/ui-react/index.js +1 -1
  202. package/min/ui-react/index.js.gz +0 -0
  203. package/min/ui-react/with-schemas/index.js +1 -1
  204. package/min/ui-react/with-schemas/index.js.gz +0 -0
  205. package/min/ui-react-dom/index.js +1 -1
  206. package/min/ui-react-dom/index.js.gz +0 -0
  207. package/min/ui-react-dom/with-schemas/index.js +1 -1
  208. package/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  209. package/min/ui-react-inspector/index.js +1 -1
  210. package/min/ui-react-inspector/index.js.gz +0 -0
  211. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  212. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  213. package/min/with-schemas/index.js +1 -1
  214. package/min/with-schemas/index.js.gz +0 -0
  215. package/omni/index.js +78 -46
  216. package/omni/with-schemas/index.js +78 -46
  217. package/package.json +3 -3
  218. package/persisters/index.js +14 -10
  219. package/persisters/persister-automerge/index.js +12 -8
  220. package/persisters/persister-automerge/with-schemas/index.js +12 -8
  221. package/persisters/persister-browser/index.js +12 -8
  222. package/persisters/persister-browser/with-schemas/index.js +12 -8
  223. package/persisters/persister-cr-sqlite-wasm/index.js +14 -10
  224. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +14 -10
  225. package/persisters/persister-durable-object-sql-storage/index.js +14 -10
  226. package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +14 -10
  227. package/persisters/persister-durable-object-storage/index.js +12 -8
  228. package/persisters/persister-durable-object-storage/with-schemas/index.js +12 -8
  229. package/persisters/persister-electric-sql/index.js +14 -10
  230. package/persisters/persister-electric-sql/with-schemas/index.js +14 -10
  231. package/persisters/persister-expo-sqlite/index.js +14 -10
  232. package/persisters/persister-expo-sqlite/with-schemas/index.js +14 -10
  233. package/persisters/persister-file/index.js +12 -8
  234. package/persisters/persister-file/with-schemas/index.js +12 -8
  235. package/persisters/persister-indexed-db/index.js +12 -8
  236. package/persisters/persister-indexed-db/with-schemas/index.js +12 -8
  237. package/persisters/persister-libsql/index.js +14 -10
  238. package/persisters/persister-libsql/with-schemas/index.js +14 -10
  239. package/persisters/persister-partykit-client/index.js +12 -8
  240. package/persisters/persister-partykit-client/with-schemas/index.js +12 -8
  241. package/persisters/persister-partykit-server/index.js +4 -3
  242. package/persisters/persister-partykit-server/with-schemas/index.js +4 -3
  243. package/persisters/persister-pglite/index.js +13 -9
  244. package/persisters/persister-pglite/with-schemas/index.js +13 -9
  245. package/persisters/persister-postgres/index.js +13 -9
  246. package/persisters/persister-postgres/with-schemas/index.js +13 -9
  247. package/persisters/persister-powersync/index.js +14 -10
  248. package/persisters/persister-powersync/with-schemas/index.js +14 -10
  249. package/persisters/persister-react-native-mmkv/index.js +12 -8
  250. package/persisters/persister-react-native-mmkv/with-schemas/index.js +12 -8
  251. package/persisters/persister-react-native-sqlite/index.js +14 -10
  252. package/persisters/persister-react-native-sqlite/with-schemas/index.js +14 -10
  253. package/persisters/persister-remote/index.js +14 -10
  254. package/persisters/persister-remote/with-schemas/index.js +14 -10
  255. package/persisters/persister-sqlite-bun/index.js +14 -10
  256. package/persisters/persister-sqlite-bun/with-schemas/index.js +14 -10
  257. package/persisters/persister-sqlite-wasm/index.js +14 -10
  258. package/persisters/persister-sqlite-wasm/with-schemas/index.js +14 -10
  259. package/persisters/persister-sqlite3/index.js +14 -10
  260. package/persisters/persister-sqlite3/with-schemas/index.js +14 -10
  261. package/persisters/persister-yjs/index.js +18 -12
  262. package/persisters/persister-yjs/with-schemas/index.js +18 -12
  263. package/persisters/with-schemas/index.js +14 -10
  264. package/queries/index.js +17 -12
  265. package/queries/with-schemas/index.js +17 -12
  266. package/readme.md +2 -2
  267. package/relationships/index.js +7 -5
  268. package/relationships/with-schemas/index.js +7 -5
  269. package/releases.md +100 -12
  270. package/store/index.js +48 -18
  271. package/store/with-schemas/index.js +48 -18
  272. package/synchronizers/index.js +13 -9
  273. package/synchronizers/synchronizer-broadcast-channel/index.js +14 -10
  274. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +14 -10
  275. package/synchronizers/synchronizer-local/index.js +14 -10
  276. package/synchronizers/synchronizer-local/with-schemas/index.js +14 -10
  277. package/synchronizers/synchronizer-ws-client/index.js +13 -9
  278. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +13 -9
  279. package/synchronizers/synchronizer-ws-server/index.js +13 -9
  280. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +13 -9
  281. package/synchronizers/synchronizer-ws-server-durable-object/index.js +13 -9
  282. package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +13 -9
  283. package/synchronizers/synchronizer-ws-server-simple/index.js +5 -4
  284. package/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +5 -4
  285. package/synchronizers/with-schemas/index.js +13 -9
  286. package/ui-react/index.js +9 -6
  287. package/ui-react/with-schemas/index.js +9 -6
  288. package/ui-react-dom/index.js +14 -7
  289. package/ui-react-dom/with-schemas/index.js +14 -7
  290. package/ui-react-inspector/index.js +53 -23
  291. package/ui-react-inspector/with-schemas/index.js +53 -23
  292. package/with-schemas/index.js +60 -30
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,p=()=>{},v=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),C=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),h=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,x=P+"*"+U,B="pragma_",J="data_version",Y="schema_version",k="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),H=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),q=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,K=Object,Q=a=>K.getPrototypeOf(a),V=K.entries,W=K.keys,X=K.freeze,Z=(a=[])=>K.fromEntries(a),aa=(...a)=>K.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(V(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>K.values(a),ia=a=>g(W(a)),ra=a=>(a=>!l(a)&&w(Q(a),a=>a==K.prototype||l(Q(a)),()=>!0))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>g(t)-2?e:oa),i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ya(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r}),da=a=>new Set(y(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),pa="ColumnName",va="store",Ea="json",Aa=va+"TableName",Na=va+"Id"+pa,ma=va+pa,$a="autoLoadIntervalSeconds",fa="rowId"+pa,Ca="tableId",Ta="tableName",ha="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ta]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,(a,r)=>{const o=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))}),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let p,v,m,$=0,f=0,C=0;ua(Ma,d,()=>0),ua(_a,d,()=>[]);const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,u),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?h(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&T(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=K;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ya(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?T(n,a):null===t[e]?I(a,a=>s(a,e+1)):N([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),b(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},x=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(j(1),f++,await q(async()=>{await A(async()=>{const e=await t();y(e)?x(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),j(0)})),K),J=async a=>(Y(),await B(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(j(1),f++,x(t??a),j(0)):await B()}),r),K),Y=async()=>(v&&(await A(()=>i(v),r),v=void 0),K),k=async a=>(1!=$&&(j(2),C++,await q(async()=>{await A(()=>n(L,a),r),j(0)})),K),z=async()=>(G(),await k(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&k(a)}),K),G=async()=>(m&&(a.delListener(m),m=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,Y]:[Y,G];return await t(),await e(),K},q=async(...a)=>(T(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(p=h(ca(_a,d)));)await A(p,r);wa(Ma,d,0)}})(),K),K={load:B,startAutoLoad:J,stopAutoLoad:Y,isAutoLoading:()=>!l(v),save:k,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,J]:[J,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:q,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:C}),...c};return X(K)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const u=oa();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>ga(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>O(ca(u,a),t))(t,e)?Z(C($(await a(x+G(t)+q(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!ra(t))):{},async(t,e,s,w,y,d=!1,g=i)=>{const p=da();na(s??{},a=>$(W(a??{}),a=>ga(p,a)));const E=D(p);if(!d&&y&&g==i&&f(E)&&O(u,t))return await a("DROP "+_+G(t)),void wa(u,t);const A=ca(u,t),N=da(D(A));if(f(E)||(O(u,t)?await v($([e,...E],async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))})):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,a=>n+G(a)+r))});`),wa(u,t,da([e,...E])))),await v([...!d&&w?$(D(N),async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))}):[]]),d)l(s)?await a(j+G(t)+q(t,g)):await v(ea(s,async(n,s)=>{l(n)?await a(j+G(t)+q(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))O(u,t)&&await a(j+G(t)+q(t,g));else{const n=C(D(ca(u,t)),a=>a!=e),i={},r=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),T(r,t)}),await o(a,t,e,n,i),await a(j+G(t)+q(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,a=>"($"+r[0]+++","+H(a,r)+")"),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,a=>G(a)+"=excluded."+G(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,p)=>{const[v,E,A,N]=Ua(t,w,u,s,g,p),m=Fa(a,()=>N(async()=>{return await v(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await v(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ba=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,p,E,A,N,m,$)=>{const[f,T,h,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>v(la(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await h(e,n,a[o],s,i,t,r)})),D=async(a,t)=>u?await h(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>O(async()=>{await f();const a=await(async()=>Z(C(await v(la(o,async([a,t,e],n)=>[a,await T(n,t,e)])),a=>!ra(a[1]))))(),t=await(async()=>w?(await T(y,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[E]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ja=(a,n,s,r,o,l,w,y,g,p,v="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[C,T,h,b]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??va],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),g=Sa(s,{[Ca]:null,[fa]:R,[ba]:i},Ca,a=>O(y,a),a=>ga(w,a)),p=Sa(r,{[Ta]:null,[fa]:R,[ha]:0,[Oa]:0,[ba]:null},Ta,(a,t)=>O(y,t),(a,t)=>ga(w,t));var v;return v=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(p,(a,t)=>v(0,a)),[0,n,[g,p,c],w]})(n);return(C?xa:Ba)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${J} d,${Y} s,TOTAL_CHANGES() c FROM ${B}${J} JOIN ${B}${Y}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,c(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,y,g,h,D(b),async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${k}list()t,${k}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t),p,v,e,E,a=>!0===a?1:!1===a?0:a,void 0)},Ya=(a,t,e,n,s)=>Ja(a,e,async(a,e=[])=>(await t.execute({sql:a,args:e})).rows,()=>p,a=>a(),n,s,p,1,t,"getClient");export{Ya as createLibSqlPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),g=c(u),v=t=>a(t)==s,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",x="TABLE",B="ALTER "+x,J="FROM",Y="DELETE "+J,k=U+"*"+J,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+x,Q=a=>T(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(h(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>h(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):ga(a,t,e()),ya(a,t)),pa=(a,t,e,n,s=0)=>g((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=pa(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),Ea=a=>new Set(p(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Ta=ma+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[ha]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=E(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),xa=ua(),Ba=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,E,N=0,m=0,T=0;va(ja,w,()=>0),va(xa,w,()=>[]);const h=ua(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[n,i,r,o,c]),Aa(pa(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>g(ya(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?C(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=N&&(N=a,U(h,void 0,N))},B=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();p(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(v&&(await f(()=>i(v),r),v=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(D(ya(xa,w),...a),await(async()=>{if(!ya(ja,w)){for(ga(ja,w,1);!u(d=I(ya(xa,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ya(xa,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return ea(Q)},Ja=(a,t,e,s,r,o=Ya,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(b(h(await a(k+Q(t)+W(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=Ea();oa(s??{},a=>h(ta(a??{}),a=>Aa(v,a)));const p=R(v);if(!d&&y&&g==i&&O(p)&&S(w,t))return await a("DROP "+x+Q(t)),void ga(w,t);const E=ya(w,t),A=Ea(R(E));if(O(p)||(S(w,t)?await m(h([e,...p],async(n,s)=>{M(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Aa(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(p,a=>n+Q(a)+r))});`),ga(w,t,Ea([e,...p])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)u(s)?await a(Y+Q(t)+W(t,g)):await m(ra(s,async(n,s)=>{u(n)?await a(Y+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(p)||await o(a,t,e,ta(n),{[s]:c?h(ca(n),c):ca(n)},E)}));else if(O(p))S(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(ya(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(Y+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Ya=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(h(a,Q),n))(e,...s)+")VALUES"+T(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(h(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[p,E,A,N]=Ja(t,w,u,s,g,v),m=Ba(a,()=>N(async()=>{return await p(),a=(await E(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,p,E,A,N,$)=>{const[f,C,T,h]=Ja(t,d,g,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(y,F,{[_]:a},!0,!0,t):null,I=Ba(a,()=>h(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await C(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ga=(a,n,s,r,o,c,u,y,d,g,p="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,h,O,b]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[ha];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Ta]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var g;return g=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(T?ka:za)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*h),n=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,O,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>(await t.execute({sql:a,args:e})).rows,()=>N,a=>a(),n,s,N,1,t,"getClient");export{Ha as createLibSqlPersister};
@@ -1 +1 @@
1
- const t=t=>typeof t,e="",a=t(e),s="message",n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=e=>t(e)==a,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},y=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),p=Object,w=t=>p.getPrototypeOf(t),h=p.keys,v=p.freeze,f=t=>(t=>!n(t)&&o(w(t),t=>t==p.prototype||n(w(t)),()=>!0))(t)&&0==(t=>c(h(t)))(t),C=JSON.stringify,S=JSON.parse,A=t=>C(t,(t,e)=>e instanceof Map?p.fromEntries([...e]):e),L=t=>n(t)||0==(t=>t?.size??0)(t),P=(t,e)=>t?.forEach(e),b=(t,e)=>t?.delete(e),m=t=>new Map(t),M=(t,e)=>t?.get(e),E=(t,e,a)=>n(a)?(b(t,e),t):t?.set(e,a),O=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):E(t,e,a()),M(t,e)},T=(t,e,a,s,n=0)=>o((a?O:M)(t,e[n],n>c(e)-2?a:m),o=>{if(n>c(e)-2)return s?.(o)&&E(t,e[n]),o;const r=T(o,e,a,s,n+1);return L(o)&&E(t,e[n]),r}),j=/^\d+$/,k=t=>new Set(i(t)||n(t)?t:[t]),x=m(),z=m(),D=(t,a,s,r,p,w,h,C={},S=0,A=[])=>{let D,J,N,F=0,U=0,W=0;O(x,A,()=>0),O(z,A,()=>[]);const $=m(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:d("Store type not supported by this Persister"))(h,t,S),[K,Q,R]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?g(t):null)??e+a++,e=>{j.test(e)&&c(t)<1e3&&l(t,e)}]})(),r=m();return[(s,n,o,i=[],c=()=>[])=>{t??=ot;const d=a(1);var y,u;return E(r,d,[s,n,o,i,c]),y=T(n,o??[e],k),u=d,y?.add(u),d},(a,s,...n)=>u(((t,a=[e])=>{const s=[],n=(t,e)=>e==c(a)?l(s,t):null===a[e]?P(t,t=>n(t,e+1)):u([a[e],null],a=>n(M(t,a),e+1));return n(t,0),s})(a,s),e=>P(e,e=>M(r,e)[0](t,...s??[],...n))),t=>o(M(r,t),([,a,n])=>(T(a,n??[e],void 0,e=>(b(e,t),L(e)?1:0)),E(r,t),s(t),n)),e=>o(M(r,e),([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?u(s[d]?.(...i)??[],t=>r(...i,t)):r(...i,a[d])};r()})]})(),V=t=>{t!=F&&(F=t,Q($,void 0,F))},X=e=>{(q&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Y=async t=>(2!=F&&(V(1),U++,await nt(async()=>{await y(async()=>{const e=await a();i(e)?X(e):t?I(t):d("Content is not an array: "+e)},()=>{t&&I(t)}),V(0)})),ot),Z=async t=>(_(),await Y(t),await y(async()=>J=await r(async(t,e)=>{e||t?2!=F&&(V(1),U++,X(e??t),V(0)):await Y()}),w),ot),_=async()=>(J&&(await y(()=>p(J),w),J=void 0),ot),tt=async t=>(1!=F&&(V(2),W++,await nt(async()=>{await y(()=>s(B,t),w),V(0)})),ot),et=async()=>(at(),await tt(),N=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&tt(t)}),ot),at=async()=>(N&&(t.delListener(N),N=void 0),ot),st=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),ot},nt=async(...t)=>(l(M(z,A),...t),await(async()=>{if(!M(x,A)){for(E(x,A,1);!n(D=g(M(z,A)));)await y(D,w);E(x,A,0)}})(),ot),ot={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!n(J),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!n(N),startAutoPersisting:async(t,e=!1)=>{const[a,s]=e?[et,Z]:[Z,et];return await a(t),await s(t),ot},stopAutoPersisting:st,getStatus:()=>F,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(M(z,A).splice(0,void 0),st()),getStats:()=>({loads:U,saves:W}),...C};return v(ot)},J="/store",N=(t,a,n,i)=>{const{host:d,room:y}=a.partySocketOptions,{storeProtocol:u="https",storePath:l=J,messagePrefix:g=e}={...r(n)?{storeProtocol:n}:n},p=u+"://"+d+"/parties/"+a.name+"/"+y+l,w=async t=>await(await fetch(p,{...t?{method:"PUT",body:A(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,w,async(t,e)=>{var s;e?a.send(g+"s"+(r(s=e)?s:A(s))):await w(t())},t=>{const e=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],S((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(g,e.data),([e,a])=>{"s"==e&&t(void 0,a)});return a.addEventListener(s,e),e},t=>{a.removeEventListener(s,t)},i,1,{getConnection:()=>a})};export{N as createPartyKitPersister};
1
+ const t=t=>typeof t,e="",a=t(e),s="message",n=t=>(e,a,s)=>t(e)?s?.():a(e),o=t=>null==t,r=t=>void 0===t,i=n(o),c=n(r),d=e=>t(e)==a,y=t=>Array.isArray(t),u=t=>t.length,l=t=>{throw Error(t)},g=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},p=(t,e)=>t.forEach(e),w=(t,...e)=>t.push(...e),h=t=>t.shift(),v=Object,f=t=>v.getPrototypeOf(t),C=v.keys,S=v.freeze,A=t=>(t=>!o(t)&&i(f(t),t=>t==v.prototype||o(f(t)),()=>!0))(t)&&0==(t=>u(C(t)))(t),L=JSON.stringify,P=JSON.parse,b=t=>L(t,(t,e)=>e instanceof Map?v.fromEntries([...e]):e),m=t=>r(t)||0==(t=>t?.size??0)(t),M=(t,e)=>t?.forEach(e),E=(t,e)=>t?.delete(e),O=t=>new Map(t),T=(t,e)=>t?.get(e),j=(t,e,a)=>void 0===a?(E(t,e),t):t?.set(e,a),k=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(T(t,e)):j(t,e,a()),T(t,e)},x=(t,e,a,s,n=0)=>c((a?k:T)(t,e[n],n>u(e)-2?a:O),o=>{if(n>u(e)-2)return s?.(o)&&j(t,e[n]),o;const r=x(o,e,a,s,n+1);return m(o)&&j(t,e[n]),r}),z=/^\d+$/,D=t=>new Set(y(t)||r(t)?t:[t]),J=O(),N=O(),F=(t,a,s,n,o,i,d,v={},f=0,C=[])=>{let L,P,b,F=0,U=0,W=0;k(J,C,()=>0),k(N,C,()=>[]);const $=O(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!A(t)||!A(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!A(t)||!A(e),e.setContent]:l("Store type not supported by this Persister"))(d,t,f),[K,Q,R]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?h(t):null)??e+a++,e=>{z.test(e)&&u(t)<1e3&&w(t,e)}]})(),n=O();return[(s,o,r,i=[],c=()=>[])=>{t??=ot;const d=a(1);var y,u;return j(n,d,[s,o,r,i,c]),y=x(o,r??[e],D),u=d,y?.add(u),d},(a,s,...o)=>p(((t,a=[e])=>{const s=[],n=(t,e)=>e==u(a)?w(s,t):null===a[e]?M(t,t=>n(t,e+1)):p([a[e],null],a=>n(T(t,a),e+1));return n(t,0),s})(a,s),e=>M(e,e=>T(n,e)[0](t,...s??[],...o))),t=>c(T(n,t),([,a,o])=>(x(a,o??[e],void 0,e=>(E(e,t),m(e)?1:0)),j(n,t),s(t),o)),e=>c(T(n,e),([e,,a=[],s,n])=>{const o=(...r)=>{const i=u(r);i==u(a)?e(t,...r,...n(r)):(t=>null===t)(a[i])?p(s[i]?.(...r)??[],t=>o(...r,t)):o(...r,a[i])};o()})]})(),V=t=>{t!=F&&(F=t,Q($,void 0,F))},X=e=>{(q&&y(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Y=async t=>(2!=F&&(V(1),U++,await nt(async()=>{await g(async()=>{const e=await a();y(e)?X(e):t?I(t):l("Content is not an array: "+e)},()=>{t&&I(t)}),V(0)})),ot),Z=async t=>(_(),await Y(t),await g(async()=>P=await n(async(t,e)=>{e||t?2!=F&&(V(1),U++,X(e??t),V(0)):await Y()}),i),ot),_=async()=>(P&&(await g(()=>o(P),i),P=void 0),ot),tt=async t=>(1!=F&&(V(2),W++,await nt(async()=>{await g(()=>s(B,t),i),V(0)})),ot),et=async()=>(at(),await tt(),b=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&tt(t)}),ot),at=async()=>(b&&(t.delListener(b),b=void 0),ot),st=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),ot},nt=async(...t)=>(w(T(N,C),...t),await(async()=>{if(!T(J,C)){for(j(J,C,1);!r(L=h(T(N,C)));)await g(L,i);j(J,C,0)}})(),ot),ot={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!r(P),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!r(b),startAutoPersisting:async(t,e=!1)=>{const[a,s]=e?[et,Z]:[Z,et];return await a(t),await s(t),ot},stopAutoPersisting:st,getStatus:()=>F,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(T(N,C).splice(0,void 0),st()),getStats:()=>({loads:U,saves:W}),...v};return S(ot)},U="/store",W=(t,a,n,o)=>{const{host:r,room:i}=a.partySocketOptions,{storeProtocol:y="https",storePath:l=U,messagePrefix:g=e}={...d(n)?{storeProtocol:n}:n},p=y+"://"+r+"/parties/"+a.name+"/"+i+l,w=async t=>await(await fetch(p,{...t?{method:"PUT",body:b(t)}:{},mode:"cors",cache:"no-store"})).json();return F(t,w,async(t,e)=>{var s;e?a.send(g+"s"+(d(s=e)?s:b(s))):await w(t())},t=>{const e=e=>c(((t,e)=>{const a=u(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],P((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(g,e.data),([e,a])=>{"s"==e&&t(void 0,a)});return a.addEventListener(s,e),e},t=>{a.removeEventListener(s,t)},o,1,{getConnection:()=>a})};export{W as createPartyKitPersister};
@@ -1 +1 @@
1
- const t=t=>typeof t,e="",a=t(e),s="message",n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=e=>t(e)==a,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},y=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),p=Object,w=t=>p.getPrototypeOf(t),h=p.keys,v=p.freeze,f=t=>(t=>!n(t)&&o(w(t),t=>t==p.prototype||n(w(t)),()=>!0))(t)&&0==(t=>c(h(t)))(t),C=JSON.stringify,S=JSON.parse,A=t=>C(t,(t,e)=>e instanceof Map?p.fromEntries([...e]):e),L=t=>n(t)||0==(t=>t?.size??0)(t),P=(t,e)=>t?.forEach(e),b=(t,e)=>t?.delete(e),m=t=>new Map(t),M=(t,e)=>t?.get(e),E=(t,e,a)=>n(a)?(b(t,e),t):t?.set(e,a),O=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):E(t,e,a()),M(t,e)},T=(t,e,a,s,n=0)=>o((a?O:M)(t,e[n],n>c(e)-2?a:m),o=>{if(n>c(e)-2)return s?.(o)&&E(t,e[n]),o;const r=T(o,e,a,s,n+1);return L(o)&&E(t,e[n]),r}),j=/^\d+$/,k=t=>new Set(i(t)||n(t)?t:[t]),x=m(),z=m(),D=(t,a,s,r,p,w,h,C={},S=0,A=[])=>{let D,J,N,F=0,U=0,W=0;O(x,A,()=>0),O(z,A,()=>[]);const $=m(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:d("Store type not supported by this Persister"))(h,t,S),[K,Q,R]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?g(t):null)??e+a++,e=>{j.test(e)&&c(t)<1e3&&l(t,e)}]})(),r=m();return[(s,n,o,i=[],c=()=>[])=>{t??=ot;const d=a(1);var y,u;return E(r,d,[s,n,o,i,c]),y=T(n,o??[e],k),u=d,y?.add(u),d},(a,s,...n)=>u(((t,a=[e])=>{const s=[],n=(t,e)=>e==c(a)?l(s,t):null===a[e]?P(t,t=>n(t,e+1)):u([a[e],null],a=>n(M(t,a),e+1));return n(t,0),s})(a,s),e=>P(e,e=>M(r,e)[0](t,...s??[],...n))),t=>o(M(r,t),([,a,n])=>(T(a,n??[e],void 0,e=>(b(e,t),L(e)?1:0)),E(r,t),s(t),n)),e=>o(M(r,e),([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?u(s[d]?.(...i)??[],t=>r(...i,t)):r(...i,a[d])};r()})]})(),V=t=>{t!=F&&(F=t,Q($,void 0,F))},X=e=>{(q&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Y=async t=>(2!=F&&(V(1),U++,await nt(async()=>{await y(async()=>{const e=await a();i(e)?X(e):t?I(t):d("Content is not an array: "+e)},()=>{t&&I(t)}),V(0)})),ot),Z=async t=>(_(),await Y(t),await y(async()=>J=await r(async(t,e)=>{e||t?2!=F&&(V(1),U++,X(e??t),V(0)):await Y()}),w),ot),_=async()=>(J&&(await y(()=>p(J),w),J=void 0),ot),tt=async t=>(1!=F&&(V(2),W++,await nt(async()=>{await y(()=>s(B,t),w),V(0)})),ot),et=async()=>(at(),await tt(),N=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&tt(t)}),ot),at=async()=>(N&&(t.delListener(N),N=void 0),ot),st=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),ot},nt=async(...t)=>(l(M(z,A),...t),await(async()=>{if(!M(x,A)){for(E(x,A,1);!n(D=g(M(z,A)));)await y(D,w);E(x,A,0)}})(),ot),ot={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!n(J),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!n(N),startAutoPersisting:async(t,e=!1)=>{const[a,s]=e?[et,Z]:[Z,et];return await a(t),await s(t),ot},stopAutoPersisting:st,getStatus:()=>F,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(M(z,A).splice(0,void 0),st()),getStats:()=>({loads:U,saves:W}),...C};return v(ot)},J="/store",N=(t,a,n,i)=>{const{host:d,room:y}=a.partySocketOptions,{storeProtocol:u="https",storePath:l=J,messagePrefix:g=e}={...r(n)?{storeProtocol:n}:n},p=u+"://"+d+"/parties/"+a.name+"/"+y+l,w=async t=>await(await fetch(p,{...t?{method:"PUT",body:A(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,w,async(t,e)=>{var s;e?a.send(g+"s"+(r(s=e)?s:A(s))):await w(t())},t=>{const e=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],S((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(g,e.data),([e,a])=>{"s"==e&&t(void 0,a)});return a.addEventListener(s,e),e},t=>{a.removeEventListener(s,t)},i,1,{getConnection:()=>a})};export{N as createPartyKitPersister};
1
+ const t=t=>typeof t,e="",a=t(e),s="message",n=t=>(e,a,s)=>t(e)?s?.():a(e),o=t=>null==t,r=t=>void 0===t,i=n(o),c=n(r),d=e=>t(e)==a,y=t=>Array.isArray(t),u=t=>t.length,l=t=>{throw Error(t)},g=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},p=(t,e)=>t.forEach(e),w=(t,...e)=>t.push(...e),h=t=>t.shift(),v=Object,f=t=>v.getPrototypeOf(t),C=v.keys,S=v.freeze,A=t=>(t=>!o(t)&&i(f(t),t=>t==v.prototype||o(f(t)),()=>!0))(t)&&0==(t=>u(C(t)))(t),L=JSON.stringify,P=JSON.parse,b=t=>L(t,(t,e)=>e instanceof Map?v.fromEntries([...e]):e),m=t=>r(t)||0==(t=>t?.size??0)(t),M=(t,e)=>t?.forEach(e),E=(t,e)=>t?.delete(e),O=t=>new Map(t),T=(t,e)=>t?.get(e),j=(t,e,a)=>void 0===a?(E(t,e),t):t?.set(e,a),k=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(T(t,e)):j(t,e,a()),T(t,e)},x=(t,e,a,s,n=0)=>c((a?k:T)(t,e[n],n>u(e)-2?a:O),o=>{if(n>u(e)-2)return s?.(o)&&j(t,e[n]),o;const r=x(o,e,a,s,n+1);return m(o)&&j(t,e[n]),r}),z=/^\d+$/,D=t=>new Set(y(t)||r(t)?t:[t]),J=O(),N=O(),F=(t,a,s,n,o,i,d,v={},f=0,C=[])=>{let L,P,b,F=0,U=0,W=0;k(J,C,()=>0),k(N,C,()=>[]);const $=O(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!A(t)||!A(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!A(t)||!A(e),e.setContent]:l("Store type not supported by this Persister"))(d,t,f),[K,Q,R]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?h(t):null)??e+a++,e=>{z.test(e)&&u(t)<1e3&&w(t,e)}]})(),n=O();return[(s,o,r,i=[],c=()=>[])=>{t??=ot;const d=a(1);var y,u;return j(n,d,[s,o,r,i,c]),y=x(o,r??[e],D),u=d,y?.add(u),d},(a,s,...o)=>p(((t,a=[e])=>{const s=[],n=(t,e)=>e==u(a)?w(s,t):null===a[e]?M(t,t=>n(t,e+1)):p([a[e],null],a=>n(T(t,a),e+1));return n(t,0),s})(a,s),e=>M(e,e=>T(n,e)[0](t,...s??[],...o))),t=>c(T(n,t),([,a,o])=>(x(a,o??[e],void 0,e=>(E(e,t),m(e)?1:0)),j(n,t),s(t),o)),e=>c(T(n,e),([e,,a=[],s,n])=>{const o=(...r)=>{const i=u(r);i==u(a)?e(t,...r,...n(r)):(t=>null===t)(a[i])?p(s[i]?.(...r)??[],t=>o(...r,t)):o(...r,a[i])};o()})]})(),V=t=>{t!=F&&(F=t,Q($,void 0,F))},X=e=>{(q&&y(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Y=async t=>(2!=F&&(V(1),U++,await nt(async()=>{await g(async()=>{const e=await a();y(e)?X(e):t?I(t):l("Content is not an array: "+e)},()=>{t&&I(t)}),V(0)})),ot),Z=async t=>(_(),await Y(t),await g(async()=>P=await n(async(t,e)=>{e||t?2!=F&&(V(1),U++,X(e??t),V(0)):await Y()}),i),ot),_=async()=>(P&&(await g(()=>o(P),i),P=void 0),ot),tt=async t=>(1!=F&&(V(2),W++,await nt(async()=>{await g(()=>s(B,t),i),V(0)})),ot),et=async()=>(at(),await tt(),b=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&tt(t)}),ot),at=async()=>(b&&(t.delListener(b),b=void 0),ot),st=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),ot},nt=async(...t)=>(w(T(N,C),...t),await(async()=>{if(!T(J,C)){for(j(J,C,1);!r(L=h(T(N,C)));)await g(L,i);j(J,C,0)}})(),ot),ot={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!r(P),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!r(b),startAutoPersisting:async(t,e=!1)=>{const[a,s]=e?[et,Z]:[Z,et];return await a(t),await s(t),ot},stopAutoPersisting:st,getStatus:()=>F,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(T(N,C).splice(0,void 0),st()),getStats:()=>({loads:U,saves:W}),...v};return S(ot)},U="/store",W=(t,a,n,o)=>{const{host:r,room:i}=a.partySocketOptions,{storeProtocol:y="https",storePath:l=U,messagePrefix:g=e}={...d(n)?{storeProtocol:n}:n},p=y+"://"+r+"/parties/"+a.name+"/"+i+l,w=async t=>await(await fetch(p,{...t?{method:"PUT",body:b(t)}:{},mode:"cors",cache:"no-store"})).json();return F(t,w,async(t,e)=>{var s;e?a.send(g+"s"+(d(s=e)?s:b(s))):await w(t())},t=>{const e=e=>c(((t,e)=>{const a=u(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],P((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(g,e.data),([e,a])=>{"s"==e&&t(void 0,a)});return a.addEventListener(s,e),e},t=>{a.removeEventListener(s,t)},o,1,{getConnection:()=>a})};export{W as createPartyKitPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="",e=a(t),s="t",n=(a,t)=>a.startsWith(t),i=Promise,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),o=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>i.all(a),y=(a,t)=>a.map(t),g=(a,...t)=>a.push(...t),h=Object,f=h.entries,u=(a=[])=>h.fromEntries(a),p=(a,t)=>y(f(a),([a,e])=>t(e,a)),S=(a,t,e)=>(((a,t)=>t in a)(a,t)||(a[t]=e()),a[t]),d=JSON.stringify,P=JSON.parse,m=a=>d(a,(a,t)=>t instanceof Map?h.fromEntries([...t]):t),x=(a,t)=>((a,t)=>a?.forEach(t))(a,(a,e)=>t(e,a)),D="/store",R=(t,s,n)=>t+s+(a(n)==e?n:m(n)),b=(a,t,e)=>{const s=l(a);return n(t,a)?[t[s],(e?P:String)(o(t,s+1))]:void 0},C="hasStore",T=u(y(["Origin","Methods","Headers"],a=>["Access-Control-Allow-"+a,"*"])),v=async(a,e=t)=>!!await a.get(e+C),O=async(a,e=t)=>{const n={},i={};return x(await a.list(),(a,t)=>c(b(e,a),([a,e])=>{if(a==s){const[a,s,i]=P("["+e+"]");S(S(n,a,u),s,u)[i]=t}else"v"==a&&(i[e]=t)})),[n,i]},V=async(a,e,s)=>a.party.broadcast(R(a.config.messagePrefix??t,"s",e),s),E=async(a,e,i,c)=>{const o=a.party.storage,y=a.config.storagePrefix??t,h={[y+C]:1},f=[],u=[];await w(p(e[0],async(t,e)=>r(t)?!i&&await a.canDelTable(e,c)&&((a,...t)=>a.unshift(...t))(u,H(y,s,e)):await a.canSetTable(e,i,c)&&await w(p(t,async(t,n)=>r(t)?!i&&await a.canDelRow(e,n,c)&&g(u,H(y,s,e,n)):await a.canSetRow(e,n,i,c)&&await w(p(t,async(t,l)=>{const w=[e,n,l],u=H(y,s,...w);r(t)?!i&&await a.canDelCell(...w,c)&&g(f,u):await a.canSetCell(...w,t,i,c,await o.get(u))&&(h[u]=t)})))))),await w(p(e[1],async(t,e)=>{const s=y+"v"+e;r(t)?!i&&await a.canDelValue(e,c)&&g(f,s):await a.canSetValue(e,t,i,c,await o.get(s))&&(h[s]=t)})),0!=l(u)&&x(await o.list(),a=>u.every(t=>!n(a,t)||g(f,a)&&0)),await o.delete(f),await o.put(h)},H=(a,t,...e)=>R(a,t,o(m(e),1,-1)),M=async(a,t,e=null)=>new Response(e,{status:t,headers:a.config.responseHeaders});class A{constructor(a){this.party=a,this.config.storePath??=D,this.config.messagePrefix??=t,this.config.storagePrefix??=t,this.config.responseHeaders??=T}config={};async onRequest(a){const{party:{storage:e},config:{storePath:s=D,storagePrefix:n}}=this;if(new URL(a.url).pathname.endsWith(s)){const s=await v(e,n),i=await a.text();return"PUT"==a.method?s?M(this,205):(await E(this,P(i),!0,a),M(this,201)):M(this,200,s?m(await O(e,n)):t)}return M(this,404)}async onMessage(a,e){const{config:{messagePrefix:s=t,storagePrefix:n}}=this;await c(b(s,a,1),async([a,t])=>{"s"==a&&await v(this.party.storage,n)&&(await E(this,t,!1,e),V(this,t,[e.id]))})}async canSetTable(a,t,e){return!0}async canDelTable(a,t){return!0}async canSetRow(a,t,e,s){return!0}async canDelRow(a,t,e){return!0}async canSetCell(a,t,e,s,n,i,r){return!0}async canDelCell(a,t,e,s){return!0}async canSetValue(a,t,e,s,n){return!0}async canDelValue(a,t){return!0}}export{A as TinyBasePartyKitServer,V as broadcastChanges,v as hasStoreInStorage,O as loadStoreFromStorage};
1
+ const a=a=>typeof a,t="",e=a(t),s="t",n=(a,t)=>a.startsWith(t),i=Promise,r=a=>void 0===a,c=(o=r,(a,t,e)=>o(a)?e?.():t(a));var o;const l=(a,t,e)=>a.slice(t,e),w=a=>a.length,y=async a=>i.all(a),g=(a,t)=>a.map(t),h=(a,...t)=>a.push(...t),f=Object,u=f.entries,p=(a=[])=>f.fromEntries(a),d=(a,t)=>g(u(a),([a,e])=>t(e,a)),S=(a,t,e)=>(((a,t)=>t in a)(a,t)||(a[t]=e()),a[t]),P=JSON.stringify,m=JSON.parse,x=a=>P(a,(a,t)=>t instanceof Map?f.fromEntries([...t]):t),D=(a,t)=>((a,t)=>a?.forEach(t))(a,(a,e)=>t(e,a)),R="/store",b=(t,s,n)=>t+s+(a(n)==e?n:x(n)),v=(a,t,e)=>{const s=w(a);return n(t,a)?[t[s],(e?m:String)(l(t,s+1))]:void 0},C="hasStore",T=p(g(["Origin","Methods","Headers"],a=>["Access-Control-Allow-"+a,"*"])),O=async(a,e=t)=>!!await a.get(e+C),V=async(a,e=t)=>{const n={},i={};return D(await a.list(),(a,t)=>c(v(e,a),([a,e])=>{if(a==s){const[a,s,i]=m("["+e+"]");S(S(n,a,p),s,p)[i]=t}else"v"==a&&(i[e]=t)})),[n,i]},E=async(a,e,s)=>a.party.broadcast(b(a.config.messagePrefix??t,"s",e),s),H=async(a,e,i,c)=>{const o=a.party.storage,l=a.config.storagePrefix??t,g={[l+C]:1},f=[],u=[];await y(d(e[0],async(t,e)=>r(t)?!i&&await a.canDelTable(e,c)&&((a,...t)=>a.unshift(...t))(u,M(l,s,e)):await a.canSetTable(e,i,c)&&await y(d(t,async(t,n)=>r(t)?!i&&await a.canDelRow(e,n,c)&&h(u,M(l,s,e,n)):await a.canSetRow(e,n,i,c)&&await y(d(t,async(t,w)=>{const y=[e,n,w],u=M(l,s,...y);r(t)?!i&&await a.canDelCell(...y,c)&&h(f,u):await a.canSetCell(...y,t,i,c,await o.get(u))&&(g[u]=t)})))))),await y(d(e[1],async(t,e)=>{const s=l+"v"+e;r(t)?!i&&await a.canDelValue(e,c)&&h(f,s):await a.canSetValue(e,t,i,c,await o.get(s))&&(g[s]=t)})),0!=w(u)&&D(await o.list(),a=>u.every(t=>!n(a,t)||h(f,a)&&0)),await o.delete(f),await o.put(g)},M=(a,t,...e)=>b(a,t,l(x(e),1,-1)),A=async(a,t,e=null)=>new Response(e,{status:t,headers:a.config.responseHeaders});class J{constructor(a){this.party=a,this.config.storePath??=R,this.config.messagePrefix??=t,this.config.storagePrefix??=t,this.config.responseHeaders??=T}config={};async onRequest(a){const{party:{storage:e},config:{storePath:s=R,storagePrefix:n}}=this;if(new URL(a.url).pathname.endsWith(s)){const s=await O(e,n),i=await a.text();return"PUT"==a.method?s?A(this,205):(await H(this,m(i),!0,a),A(this,201)):A(this,200,s?x(await V(e,n)):t)}return A(this,404)}async onMessage(a,e){const{config:{messagePrefix:s=t,storagePrefix:n}}=this;await c(v(s,a,1),async([a,t])=>{"s"==a&&await O(this.party.storage,n)&&(await H(this,t,!1,e),E(this,t,[e.id]))})}async canSetTable(a,t,e){return!0}async canDelTable(a,t){return!0}async canSetRow(a,t,e,s){return!0}async canDelRow(a,t,e){return!0}async canSetCell(a,t,e,s,n,i,r){return!0}async canDelCell(a,t,e,s){return!0}async canSetValue(a,t,e,s,n){return!0}async canDelValue(a,t){return!0}}export{J as TinyBasePartyKitServer,E as broadcastChanges,O as hasStoreInStorage,V as loadStoreFromStorage};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="",e=a(t),s="t",n=(a,t)=>a.startsWith(t),i=Promise,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),o=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>i.all(a),y=(a,t)=>a.map(t),g=(a,...t)=>a.push(...t),h=Object,f=h.entries,u=(a=[])=>h.fromEntries(a),p=(a,t)=>y(f(a),([a,e])=>t(e,a)),S=(a,t,e)=>(((a,t)=>t in a)(a,t)||(a[t]=e()),a[t]),d=JSON.stringify,P=JSON.parse,m=a=>d(a,(a,t)=>t instanceof Map?h.fromEntries([...t]):t),x=(a,t)=>((a,t)=>a?.forEach(t))(a,(a,e)=>t(e,a)),D="/store",R=(t,s,n)=>t+s+(a(n)==e?n:m(n)),b=(a,t,e)=>{const s=l(a);return n(t,a)?[t[s],(e?P:String)(o(t,s+1))]:void 0},C="hasStore",T=u(y(["Origin","Methods","Headers"],a=>["Access-Control-Allow-"+a,"*"])),v=async(a,e=t)=>!!await a.get(e+C),O=async(a,e=t)=>{const n={},i={};return x(await a.list(),(a,t)=>c(b(e,a),([a,e])=>{if(a==s){const[a,s,i]=P("["+e+"]");S(S(n,a,u),s,u)[i]=t}else"v"==a&&(i[e]=t)})),[n,i]},V=async(a,e,s)=>a.party.broadcast(R(a.config.messagePrefix??t,"s",e),s),E=async(a,e,i,c)=>{const o=a.party.storage,y=a.config.storagePrefix??t,h={[y+C]:1},f=[],u=[];await w(p(e[0],async(t,e)=>r(t)?!i&&await a.canDelTable(e,c)&&((a,...t)=>a.unshift(...t))(u,H(y,s,e)):await a.canSetTable(e,i,c)&&await w(p(t,async(t,n)=>r(t)?!i&&await a.canDelRow(e,n,c)&&g(u,H(y,s,e,n)):await a.canSetRow(e,n,i,c)&&await w(p(t,async(t,l)=>{const w=[e,n,l],u=H(y,s,...w);r(t)?!i&&await a.canDelCell(...w,c)&&g(f,u):await a.canSetCell(...w,t,i,c,await o.get(u))&&(h[u]=t)})))))),await w(p(e[1],async(t,e)=>{const s=y+"v"+e;r(t)?!i&&await a.canDelValue(e,c)&&g(f,s):await a.canSetValue(e,t,i,c,await o.get(s))&&(h[s]=t)})),0!=l(u)&&x(await o.list(),a=>u.every(t=>!n(a,t)||g(f,a)&&0)),await o.delete(f),await o.put(h)},H=(a,t,...e)=>R(a,t,o(m(e),1,-1)),M=async(a,t,e=null)=>new Response(e,{status:t,headers:a.config.responseHeaders});class A{constructor(a){this.party=a,this.config.storePath??=D,this.config.messagePrefix??=t,this.config.storagePrefix??=t,this.config.responseHeaders??=T}config={};async onRequest(a){const{party:{storage:e},config:{storePath:s=D,storagePrefix:n}}=this;if(new URL(a.url).pathname.endsWith(s)){const s=await v(e,n),i=await a.text();return"PUT"==a.method?s?M(this,205):(await E(this,P(i),!0,a),M(this,201)):M(this,200,s?m(await O(e,n)):t)}return M(this,404)}async onMessage(a,e){const{config:{messagePrefix:s=t,storagePrefix:n}}=this;await c(b(s,a,1),async([a,t])=>{"s"==a&&await v(this.party.storage,n)&&(await E(this,t,!1,e),V(this,t,[e.id]))})}async canSetTable(a,t,e){return!0}async canDelTable(a,t){return!0}async canSetRow(a,t,e,s){return!0}async canDelRow(a,t,e){return!0}async canSetCell(a,t,e,s,n,i,r){return!0}async canDelCell(a,t,e,s){return!0}async canSetValue(a,t,e,s,n){return!0}async canDelValue(a,t){return!0}}export{A as TinyBasePartyKitServer,V as broadcastChanges,v as hasStoreInStorage,O as loadStoreFromStorage};
1
+ const a=a=>typeof a,t="",e=a(t),s="t",n=(a,t)=>a.startsWith(t),i=Promise,r=a=>void 0===a,c=(o=r,(a,t,e)=>o(a)?e?.():t(a));var o;const l=(a,t,e)=>a.slice(t,e),w=a=>a.length,y=async a=>i.all(a),g=(a,t)=>a.map(t),h=(a,...t)=>a.push(...t),f=Object,u=f.entries,p=(a=[])=>f.fromEntries(a),d=(a,t)=>g(u(a),([a,e])=>t(e,a)),S=(a,t,e)=>(((a,t)=>t in a)(a,t)||(a[t]=e()),a[t]),P=JSON.stringify,m=JSON.parse,x=a=>P(a,(a,t)=>t instanceof Map?f.fromEntries([...t]):t),D=(a,t)=>((a,t)=>a?.forEach(t))(a,(a,e)=>t(e,a)),R="/store",b=(t,s,n)=>t+s+(a(n)==e?n:x(n)),v=(a,t,e)=>{const s=w(a);return n(t,a)?[t[s],(e?m:String)(l(t,s+1))]:void 0},C="hasStore",T=p(g(["Origin","Methods","Headers"],a=>["Access-Control-Allow-"+a,"*"])),O=async(a,e=t)=>!!await a.get(e+C),V=async(a,e=t)=>{const n={},i={};return D(await a.list(),(a,t)=>c(v(e,a),([a,e])=>{if(a==s){const[a,s,i]=m("["+e+"]");S(S(n,a,p),s,p)[i]=t}else"v"==a&&(i[e]=t)})),[n,i]},E=async(a,e,s)=>a.party.broadcast(b(a.config.messagePrefix??t,"s",e),s),H=async(a,e,i,c)=>{const o=a.party.storage,l=a.config.storagePrefix??t,g={[l+C]:1},f=[],u=[];await y(d(e[0],async(t,e)=>r(t)?!i&&await a.canDelTable(e,c)&&((a,...t)=>a.unshift(...t))(u,M(l,s,e)):await a.canSetTable(e,i,c)&&await y(d(t,async(t,n)=>r(t)?!i&&await a.canDelRow(e,n,c)&&h(u,M(l,s,e,n)):await a.canSetRow(e,n,i,c)&&await y(d(t,async(t,w)=>{const y=[e,n,w],u=M(l,s,...y);r(t)?!i&&await a.canDelCell(...y,c)&&h(f,u):await a.canSetCell(...y,t,i,c,await o.get(u))&&(g[u]=t)})))))),await y(d(e[1],async(t,e)=>{const s=l+"v"+e;r(t)?!i&&await a.canDelValue(e,c)&&h(f,s):await a.canSetValue(e,t,i,c,await o.get(s))&&(g[s]=t)})),0!=w(u)&&D(await o.list(),a=>u.every(t=>!n(a,t)||h(f,a)&&0)),await o.delete(f),await o.put(g)},M=(a,t,...e)=>b(a,t,l(x(e),1,-1)),A=async(a,t,e=null)=>new Response(e,{status:t,headers:a.config.responseHeaders});class J{constructor(a){this.party=a,this.config.storePath??=R,this.config.messagePrefix??=t,this.config.storagePrefix??=t,this.config.responseHeaders??=T}config={};async onRequest(a){const{party:{storage:e},config:{storePath:s=R,storagePrefix:n}}=this;if(new URL(a.url).pathname.endsWith(s)){const s=await O(e,n),i=await a.text();return"PUT"==a.method?s?A(this,205):(await H(this,m(i),!0,a),A(this,201)):A(this,200,s?x(await V(e,n)):t)}return A(this,404)}async onMessage(a,e){const{config:{messagePrefix:s=t,storagePrefix:n}}=this;await c(v(s,a,1),async([a,t])=>{"s"==a&&await O(this.party.storage,n)&&(await H(this,t,!1,e),E(this,t,[e.id]))})}async canSetTable(a,t,e){return!0}async canDelTable(a,t){return!0}async canSetRow(a,t,e,s){return!0}async canDelRow(a,t,e){return!0}async canSetCell(a,t,e,s,n,i,r){return!0}async canDelCell(a,t,e,s){return!0}async canSetValue(a,t,e,s,n){return!0}async canDelValue(a,t){return!0}}export{J as TinyBasePartyKitServer,E as broadcastChanges,O as hasStoreInStorage,V as loadStoreFromStorage};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=globalThis,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,d=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),E=a=>a.length,N=()=>{},g=async a=>r.all(a),A=a=>{throw Error(a)},T=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},$=(a,t)=>a.forEach(t),p=(a,t="")=>a.join(t),O=(a,t)=>a.map(t),R=a=>0==E(a),m=(a,t)=>a.filter(t),v=(a,...t)=>a.push(...t),C=a=>a.shift(),I=(a,t)=>a?.has(t)??!1,L=a=>l(a)||0==(a=>a?.size??0)(a),S=a=>[...a?.values()??[]],_=(a,t)=>a?.forEach(t),b=(a,t)=>a?.delete(t),f=Object,D=a=>f.getPrototypeOf(a),P=f.entries,h=f.keys,F=f.freeze,M=(a=[])=>f.fromEntries(a),U=(...a)=>f.assign({},...a),G=(a,t)=>(delete a[t],a),j=(a,t)=>O(P(a),([a,e])=>t(e,a)),x=(a,t)=>M(j(a,(a,e)=>[e,t(a,e)])),W=a=>f.values(a),B=a=>E(h(a)),H=a=>(a=>!l(a)&&w(D(a),a=>a==f.prototype||l(D(a)),()=>!0))(a)&&0==B(a),X=JSON.stringify,Y=JSON.parse,k=a=>X(a,(a,t)=>void 0===t?"":t),q=new c.TextEncoder,z=a=>new Map(a),J=(a,t)=>a?.get(t),K=(a,t)=>O([...a?.entries()??[]],([a,e])=>t(e,a)),V=(a,t,e)=>l(e)?(b(a,t),a):a?.set(t,e),Q=(a,t,e,n)=>(I(a,t)?n?.(J(a,t)):V(a,t,e()),J(a,t)),Z=(a,t,e,n,s=0)=>w((e?Q:J)(a,t[s],s>E(t)-2?e:z),i=>{if(s>E(t)-2)return n?.(i)&&V(a,t[s]),i;const o=Z(i,t,e,n,s+1);return L(i)&&V(a,t[s]),o}),aa="_",ta="_id",ea="SELECT",na="WHERE",sa="TABLE",ia="INSERT",oa="DELETE",ra="UPDATE",ca="ALTER "+sa,la="FROM",wa=oa+" "+la,ya=ea+"*"+la,da="CREATE ",ua=da+sa,Ea="OR REPLACE ",Na="FUNCTION",ga="$tableName",Aa=a=>p(O(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Ta=(...a)=>Aa(p(a,"_")),$a=(a,t=[1])=>p(O(a,()=>"$"+t[0]++),n),pa=(a,t=i)=>na+`(${o(t,ga,Aa(a))})`,Oa=a=>new Set(d(a)||l(a)?a:[a]),Ra=(a,t)=>a?.add(t),ma="ColumnName",va="store",Ca="json",Ia=va+"TableName",La=va+"Id"+ma,Sa=va+ma,_a="autoLoadIntervalSeconds",ba="rowId"+ma,fa="tableId",Da="tableName",Pa="deleteEmptyColumns",ha="deleteEmptyTable",Fa="condition",Ma={mode:Ca,[_a]:1},Ua={load:0,save:0,[Da]:t+"_values"},Ga=(a,t,e,n,s)=>{const i=z();return x(a,(a,o)=>{const r=u(W(U(t,y(a)?{[e]:a}:a)),0,B(t));l(r[0])||n(o,r[0])||(s(o,r[0]),V(i,o,r))}),i},ja=/^\d+$/,xa=z(),Wa=z(),Ba=(a,t,n,s,i,o,r,c={},y=0,u=[])=>{let N,g,p,O=0,R=0,m=0;Q(xa,u,()=>0),Q(Wa,u,()=>[]);const I=z(),[S,f,D,P,h]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!H(a)||!H(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!H(a)||!H(t),t.setContent]:A("Store type not supported by this Persister"))(r,a,y),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{ja.test(t)&&E(a)<1e3&&v(a,t)}]})(),s=z();return[(n,i,o,r=[],c=()=>[])=>{a??=ta;const l=t(1);return V(s,l,[n,i,o,r,c]),Ra(Z(i,o??[e],Oa),l),l},(t,n,...i)=>$(((a,t=[e])=>{const n=[],s=(a,e)=>e==E(t)?v(n,a):null===t[e]?_(a,a=>s(a,e+1)):$([t[e],null],t=>s(J(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>J(s,t)[0](a,...n??[],...i))),a=>w(J(s,a),([,t,i])=>(Z(t,i??[e],void 0,t=>(b(t,a),L(t)?1:0)),V(s,a),n(a),i)),t=>w(J(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=E(o);r==E(e)?t(a,...o,...s(o)):l(e[r])?$(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),j=a=>{a!=O&&(O=a,U(I,void 0,O))},x=t=>{(S&&d(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},W=async a=>(2!=O&&(j(1),R++,await aa(async()=>{await T(async()=>{const e=await t();d(e)?x(e):a?h(a):A("Content is not an array: "+e)},()=>{a&&h(a)}),j(0)})),ta),B=async a=>(X(),await W(a),await T(async()=>g=await s(async(a,t)=>{t||a?2!=O&&(j(1),R++,x(t??a),j(0)):await W()}),o),ta),X=async()=>(g&&(await T(()=>i(g),o),g=void 0),ta),Y=async a=>(1!=O&&(j(2),m++,await aa(async()=>{await T(()=>n(f,a),o),j(0)})),ta),k=async()=>(q(),await Y(),p=a.addDidFinishTransactionListener(()=>{const a=D();P(a)&&Y(a)}),ta),q=async()=>(p&&(a.delListener(p),p=void 0),ta),K=async(a=!1)=>{const[t,e]=a?[q,X]:[X,q];return await t(),await e(),ta},aa=async(...a)=>(v(J(Wa,u),...a),await(async()=>{if(!J(xa,u)){for(V(xa,u,1);!l(N=C(J(Wa,u)));)await T(N,o);V(xa,u,0)}})(),ta),ta={load:W,startAutoLoad:B,stopAutoLoad:X,isAutoLoading:()=>!l(g),save:Y,startAutoSave:k,stopAutoSave:q,isAutoSaving:()=>!l(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,B]:[B,k];return await e(a),await n(a),ta},stopAutoPersisting:K,getStatus:()=>O,addStatusListener:a=>M(a,I),delListener:t=>(G(t),a),schedule:aa,getStore:()=>a,destroy:()=>(J(Wa,u).splice(0,void 0),K()),getStats:()=>({loads:R,saves:m}),...c};return F(ta)},Ha=(a,t,e,s,o,r=Xa,c,w)=>{const y=z();return[async()=>{y.clear(),O(await e(a,t),({tn:a,cn:t})=>Ra(Q(y,a,Oa),t))},async(t,e,n)=>((a,t)=>I(J(y,a),t))(t,e)?M(m(O(await a(ya+Aa(t)+pa(t,n)),a=>[a[e],w?x(G(a,e),w):G(a,e)]),([a,t])=>!l(a)&&!H(t))):{},async(t,e,s,w,d,u=!1,E=i)=>{const N=Oa();x(s??{},a=>O(h(a??{}),a=>Ra(N,a)));const A=S(N);if(!u&&d&&E==i&&R(A)&&I(y,t))return await a("DROP "+sa+Aa(t)),void V(y,t);const T=J(y,t),$=Oa(S(T));if(R(A)||(I(y,t)?await g(O([e,...A],async(n,s)=>{b($,n)||(await a(ca+Aa(t)+"ADD"+Aa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Aa(t)+`(${Aa(e)})`),Ra(T,n))})):(await a(ua+Aa(t)+`(${Aa(e)}${o} PRIMARY KEY${p(O(A,a=>n+Aa(a)+o))});`),V(y,t,Oa([e,...A])))),await g([...!u&&w?O(S($),async n=>{n!=e&&(await a(ca+Aa(t)+"DROP"+Aa(n)),b(T,n))}):[]]),u)l(s)?await a(wa+Aa(t)+pa(t,E)):await g(j(s,async(n,s)=>{l(n)?await a(wa+Aa(t)+pa(t,E)+`AND(${Aa(e)}=$1)`,[s]):R(A)||await r(a,t,e,h(n),{[s]:c?O(W(n),c):W(n)},T)}));else if(R(A))I(y,t)&&await a(wa+Aa(t)+pa(t,E));else{const n=m(S(J(y,t)),a=>a!=e),i={},o=[];x(s??{},(a,t)=>{i[t]=O(n,t=>c?c(a?.[t]):a?.[t]),v(o,t)}),await r(a,t,e,n,i),await a(wa+Aa(t)+pa(t,E)+`AND${Aa(e)}NOT IN(${$a(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await T(async()=>e=await t(),s),await a("END"),e}]},Xa=async(a,t,e,s,i)=>{const o=[1];await a(ia+" INTO"+Aa(t)+"("+((...a)=>p(O(a,Aa),n))(e,...s)+")VALUES"+p(j(i,a=>"($"+o[0]+++","+$a(a,o)+")"),n)+"ON CONFLICT("+Aa(e)+`)DO ${ra} SET`+p(O(s,a=>Aa(a)+"=excluded."+Aa(a)),n),j(i,(a,t)=>[t,...O(a,a=>a??null)]).flat())},Ya=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=Ha(t,w,y,s,E,N),p=Ba(a,()=>$(async()=>{return await g(),a=(await A(r,c))[aa]?.[l]??"null",Y(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(r,c,{[aa]:{[l]:k(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},ka=(a,t,e,n,s,i,o,[r,c,[w,y,d]],u,E,N,A,T,$,p,O)=>{const[R,v,C,I]=Ha(t,u,E,s,T,$,p,O),L=(a,t)=>g(K(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)})),S=async(a,t)=>y?await C(d,ta,{[aa]:a},!0,!0,t):null,_=Ba(a,()=>I(async()=>{await R();const a=await(async()=>M(m(await g(K(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!H(a[1]))))(),t=await(async()=>w?(await v(d,ta))[aa]:{})();return H(a)&&l(t)?void 0:[a,t]}),(a,t)=>I(async()=>{if(await R(),l(t)){const[t,e]=a();await L(t),await S(e)}else await L(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[A]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},qa=/^([cd]:)(.+)/,za=(a,n,s,r,c,l,d,E,N,A,T="getDb")=>{const R=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[m,,v,C]=(a=>{const e=(a=>U(Ma,y(a)?{[Ia]:a}:a??{}))(a),n=e[_a];if(e.mode==Ca){const a=e[Ia]??t;return[1,n,[a,e[La]??ta,e[Sa]??va],Oa(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=u(W(U(Ua,r)),0,B(Ua)),l=c[2],w=Oa(l),d=Oa(l),E=Ga(s,{[fa]:null,[ba]:ta,[Fa]:i},fa,a=>I(d,a),a=>Ra(w,a)),N=Ga(o,{[Da]:null,[ba]:ta,[Pa]:0,[ha]:0,[Fa]:null},Da,(a,t)=>I(d,t),(a,t)=>Ra(w,t));var g;return g=(a,t)=>t[4]??=J(E,t[0])?.[2]??i,_(N,(a,t)=>g(0,a)),[0,n,[E,N,c],w]})(n),L=e+(a=>{let t=2166136261;return $(q.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(k(v)),b=t+"_"+L,f=async(a,e,n="",s="")=>{const i=Ta(t,a,L);return await R(da+Ea+Na+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},D=async(a,t,e,n)=>(await R(da+a+"TRIGGER"+t+e+"EXECUTE "+Na+n+"()"),t),P=a=>`PERFORM pg_notify('${b}',${a});`,h=(a,t)=>m?i:2===t?h(a,0)+" OR "+h(a,1):o(J(v[0],a)?.[2]??i,ga,0==t?"NEW":"OLD"),F=(a,e)=>g(O([ia,oa,ra],(n,s)=>D(Ea,Ta(t,"d",L,a,n),`AFTER ${n} ON${Aa(a)}FOR EACH ROW WHEN(${h(a,s)})`,e)));return(m?Ya:ka)(a,R,async a=>{const e=await f("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${na} command_tag='${ua}' LOOP ${P("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await D("EVENT ",Ta(t,"c",L),`ON ddl_command_end WHEN TAG IN('${ua}')`,e);const n=await f("d",P("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await g(O(S(C),async a=>(await R(ua+` IF NOT EXISTS${Aa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(b,t=>{return w((e=t,s=qa,e?.match(s)),async([,t,e])=>{I(C,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await R(`DROP FUNCTION IF EXISTS${p(t,",")}CASCADE`)},d,E,N,v,S(C),async(a,t)=>await a(ea+` table_name tn,column_name cn FROM information_schema.columns ${na} table_schema='public'AND table_name IN(${$a(t)})`,t),A,T,"text",void 0,a=>X(a),a=>Y(a))},Ja=async(a,t,e,n,s)=>za(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>T(a,s),n,s,N,3,t,"getPglite");export{Ja as createPglitePersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},v=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),F=Object,M=a=>F.getPrototypeOf(a),U=F.entries,G=F.keys,j=F.freeze,x=(a=[])=>F.fromEntries(a),W=(...a)=>F.assign({},...a),B=(a,t)=>(delete a[t],a),H=(a,t)=>C(U(a),([a,e])=>t(e,a)),X=(a,t)=>x(H(a,(a,e)=>[e,t(a,e)])),Y=a=>F.values(a),k=a=>T(G(a)),q=a=>(a=>!w(a)&&u(M(a),a=>a==F.prototype||w(M(a)),()=>!0))(a)&&0==k(a),z=JSON.stringify,J=JSON.parse,K=a=>z(a,(a,t)=>void 0===t?"":t),V=new l.TextEncoder,Q=a=>new Map(a),Z=(a,t)=>a?.get(t),aa=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),ta=(a,t,e)=>void 0===e?(h(a,t),a):a?.set(t,e),ea=(a,t,e,n)=>(b(a,t)?n?.(Z(a,t)):ta(a,t,e()),Z(a,t)),na=(a,t,e,n,s=0)=>E((e?ea:Z)(a,t[s],s>T(t)-2?e:Q),i=>{if(s>T(t)-2)return n?.(i)&&ta(a,t[s]),i;const o=na(i,t,e,n,s+1);return f(i)&&ta(a,t[s]),o}),sa="_",ia="_id",oa="SELECT",ra="WHERE",ca="TABLE",la="INSERT",wa="DELETE",ya="UPDATE",da="ALTER "+ca,ua="FROM",Ea=wa+" "+ua,Na=oa+"*"+ua,ga="CREATE ",Aa=ga+ca,Ta="OR REPLACE ",$a="FUNCTION",pa="$tableName",Oa=a=>m(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Ra=(...a)=>Oa(m(a,"_")),va=(a,t=[1])=>m(C(a,()=>"$"+t[0]++),n),ma=(a,t=i)=>ra+`(${o(t,pa,Oa(a))})`,Ca=a=>new Set(g(a)||y(a)?a:[a]),Ia=(a,t)=>a?.add(t),La="ColumnName",Sa="store",_a="json",ba=Sa+"TableName",fa=Sa+"Id"+La,Da=Sa+La,Pa="autoLoadIntervalSeconds",ha="rowId"+La,Fa="tableId",Ma="tableName",Ua="deleteEmptyColumns",Ga="deleteEmptyTable",ja="condition",xa={mode:_a,[Pa]:1},Wa={load:0,save:0,[Ma]:t+"_values"},Ba=(a,t,e,n,s)=>{const i=Q();return X(a,(a,o)=>{const r=A(Y(W(t,N(a)?{[e]:a}:a)),0,k(t));d(r[0])||n(o,r[0])||(s(o,r[0]),ta(i,o,r))}),i},Ha=/^\d+$/,Xa=Q(),Ya=Q(),ka=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let u,N,A,$=0,p=0,m=0;ea(Xa,w,()=>0),ea(Ya,w,()=>[]);const C=Q(),[I,L,b,D,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:O("Store type not supported by this Persister"))(r,a,l),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?_(a):null)??e+t++,t=>{Ha.test(t)&&T(a)<1e3&&S(a,t)}]})(),s=Q();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return ta(s,l,[n,i,o,r,c]),Ia(na(i,o??[e],Ca),l),l},(t,n,...i)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?S(n,a):null===t[e]?P(a,a=>s(a,e+1)):v([t[e],null],t=>s(Z(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>Z(s,t)[0](a,...n??[],...i))),a=>E(Z(s,a),([,t,i])=>(na(t,i??[e],void 0,t=>(h(t,a),f(t)?1:0)),ta(s,a),n(a),i)),t=>E(Z(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):d(e[r])?v(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(I&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(x(1),p++,await K(async()=>{await R(async()=>{const e=await t();g(e)?W(e):a?F(a):O("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),V),H=async a=>(X(),await B(a),await R(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),p++,W(t??a),x(0)):await B()}),o),V),X=async()=>(N&&(await R(()=>i(N),o),N=void 0),V),Y=async a=>(1!=$&&(x(2),m++,await K(async()=>{await R(()=>n(L,a),o),x(0)})),V),k=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=b();D(a)&&Y(a)}),V),z=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),V},K=async(...a)=>(S(Z(Ya,w),...a),await(async()=>{if(!Z(Xa,w)){for(ta(Xa,w,1);!y(u=_(Z(Ya,w)));)await R(u,o);ta(Xa,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(Z(Ya,w).splice(0,void 0),J()),getStats:()=>({loads:p,saves:m}),...c};return j(V)},qa=(a,t,e,s,o,r=za,c,l)=>{const w=Q();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Ia(ea(w,a,Ca),t))},async(t,e,n)=>((a,t)=>b(Z(w,a),t))(t,e)?x(L(C(await a(Na+Oa(t)+ma(t,n)),a=>[a[e],l?X(B(a,e),l):B(a,e)]),([a,t])=>!y(a)&&!q(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=Ca();X(s??{},a=>C(G(a??{}),a=>Ia(N,a)));const g=D(N);if(!u&&d&&E==i&&I(g)&&b(w,t))return await a("DROP "+ca+Oa(t)),void ta(w,t);const A=Z(w,t),T=Ca(D(A));if(I(g)||(b(w,t)?await p(C([e,...g],async(n,s)=>{h(T,n)||(await a(da+Oa(t)+"ADD"+Oa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Oa(t)+`(${Oa(e)})`),Ia(A,n))})):(await a(Aa+Oa(t)+`(${Oa(e)}${o} PRIMARY KEY${m(C(g,a=>n+Oa(a)+o))});`),ta(w,t,Ca([e,...g])))),await p([...!u&&l?C(D(T),async n=>{n!=e&&(await a(da+Oa(t)+"DROP"+Oa(n)),h(A,n))}):[]]),u)y(s)?await a(Ea+Oa(t)+ma(t,E)):await p(H(s,async(n,s)=>{y(n)?await a(Ea+Oa(t)+ma(t,E)+`AND(${Oa(e)}=$1)`,[s]):I(g)||await r(a,t,e,G(n),{[s]:c?C(Y(n),c):Y(n)},A)}));else if(I(g))b(w,t)&&await a(Ea+Oa(t)+ma(t,E));else{const n=L(D(Z(w,t)),a=>a!=e),i={},o=[];X(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),S(o,t)}),await r(a,t,e,n,i),await a(Ea+Oa(t)+ma(t,E)+`AND${Oa(e)}NOT IN(${va(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await R(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const o=[1];await a(la+" INTO"+Oa(t)+"("+((...a)=>m(C(a,Oa),n))(e,...s)+")VALUES"+m(H(i,a=>"($"+o[0]+++","+va(a,o)+")"),n)+"ON CONFLICT("+Oa(e)+`)DO ${ya} SET`+m(C(s,a=>Oa(a)+"=excluded."+Oa(a)),n),H(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ja=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=qa(t,w,y,s,E,N),p=ka(a,()=>$(async()=>{return await g(),a=(await A(r,c))[sa]?.[l]??"null",J(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(r,c,{[sa]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},Ka=(a,t,e,n,s,i,o,[r,c,[l,w,d]],u,E,N,g,A,T,$,O)=>{const[R,v,m,C]=qa(t,u,E,s,A,T,$,O),I=(a,t)=>p(aa(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await m(e,n,a[r],s,i,t,o)})),S=async(a,t)=>w?await m(d,ia,{[sa]:a},!0,!0,t):null,_=ka(a,()=>C(async()=>{await R();const a=await(async()=>x(L(await p(aa(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await v(d,ia))[sa]:{})();return q(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await S(e)}else await I(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Va=/^([cd]:)(.+)/,Qa=(a,n,s,r,c,l,w,y,d,u,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[$,,O,R]=(a=>{const e=(a=>W(xa,N(a)?{[ba]:a}:a??{}))(a),n=e[Pa];if(e.mode==_a){const a=e[ba]??t;return[1,n,[a,e[fa]??ia,e[Da]??Sa],Ca(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(Y(W(Wa,r)),0,k(Wa)),l=c[2],w=Ca(l),y=Ca(l),d=Ba(s,{[Fa]:null,[ha]:ia,[ja]:i},Fa,a=>b(y,a),a=>Ia(w,a)),u=Ba(o,{[Ma]:null,[ha]:ia,[Ua]:0,[Ga]:0,[ja]:null},Ma,(a,t)=>b(y,t),(a,t)=>Ia(w,t));var E;return E=(a,t)=>t[4]??=Z(d,t[0])?.[2]??i,P(u,(a,t)=>E(0,a)),[0,n,[d,u,c],w]})(n),I=e+(a=>{let t=2166136261;return v(V.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(K(O)),L=t+"_"+I,S=async(a,e,n="",s="")=>{const i=Ra(t,a,I);return await T(ga+Ta+$a+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await T(ga+a+"TRIGGER"+t+e+"EXECUTE "+$a+n+"()"),t),f=a=>`PERFORM pg_notify('${L}',${a});`,h=(a,t)=>$?i:2===t?h(a,0)+" OR "+h(a,1):o(Z(O[0],a)?.[2]??i,pa,0==t?"NEW":"OLD"),F=(a,e)=>p(C([la,wa,ya],(n,s)=>_(Ta,Ra(t,"d",I,a,n),`AFTER ${n} ON${Oa(a)}FOR EACH ROW WHEN(${h(a,s)})`,e)));return($?Ja:Ka)(a,T,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ra} command_tag='${Aa}' LOOP ${f("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",Ra(t,"c",I),`ON ddl_command_end WHEN TAG IN('${Aa}')`,e);const n=await S("d",f("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await p(C(D(R),async a=>(await T(Aa+` IF NOT EXISTS${Oa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(L,t=>{return E((e=t,s=Va,e?.match(s)),async([,t,e])=>{b(R,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,y,d,O,D(R),async(a,t)=>await a(oa+` table_name tn,column_name cn FROM information_schema.columns ${ra} table_schema='public'AND table_name IN(${va(t)})`,t),u,g,"text",void 0,a=>z(a),a=>J(a))},Za=async(a,t,e,n,s)=>Qa(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>R(a,s),n,s,$,3,t,"getPglite");export{Za as createPglitePersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=globalThis,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,d=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),E=a=>a.length,N=()=>{},g=async a=>r.all(a),A=a=>{throw Error(a)},T=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},$=(a,t)=>a.forEach(t),p=(a,t="")=>a.join(t),O=(a,t)=>a.map(t),R=a=>0==E(a),m=(a,t)=>a.filter(t),v=(a,...t)=>a.push(...t),C=a=>a.shift(),I=(a,t)=>a?.has(t)??!1,L=a=>l(a)||0==(a=>a?.size??0)(a),S=a=>[...a?.values()??[]],_=(a,t)=>a?.forEach(t),b=(a,t)=>a?.delete(t),f=Object,D=a=>f.getPrototypeOf(a),P=f.entries,h=f.keys,F=f.freeze,M=(a=[])=>f.fromEntries(a),U=(...a)=>f.assign({},...a),G=(a,t)=>(delete a[t],a),j=(a,t)=>O(P(a),([a,e])=>t(e,a)),x=(a,t)=>M(j(a,(a,e)=>[e,t(a,e)])),W=a=>f.values(a),B=a=>E(h(a)),H=a=>(a=>!l(a)&&w(D(a),a=>a==f.prototype||l(D(a)),()=>!0))(a)&&0==B(a),X=JSON.stringify,Y=JSON.parse,k=a=>X(a,(a,t)=>void 0===t?"":t),q=new c.TextEncoder,z=a=>new Map(a),J=(a,t)=>a?.get(t),K=(a,t)=>O([...a?.entries()??[]],([a,e])=>t(e,a)),V=(a,t,e)=>l(e)?(b(a,t),a):a?.set(t,e),Q=(a,t,e,n)=>(I(a,t)?n?.(J(a,t)):V(a,t,e()),J(a,t)),Z=(a,t,e,n,s=0)=>w((e?Q:J)(a,t[s],s>E(t)-2?e:z),i=>{if(s>E(t)-2)return n?.(i)&&V(a,t[s]),i;const o=Z(i,t,e,n,s+1);return L(i)&&V(a,t[s]),o}),aa="_",ta="_id",ea="SELECT",na="WHERE",sa="TABLE",ia="INSERT",oa="DELETE",ra="UPDATE",ca="ALTER "+sa,la="FROM",wa=oa+" "+la,ya=ea+"*"+la,da="CREATE ",ua=da+sa,Ea="OR REPLACE ",Na="FUNCTION",ga="$tableName",Aa=a=>p(O(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Ta=(...a)=>Aa(p(a,"_")),$a=(a,t=[1])=>p(O(a,()=>"$"+t[0]++),n),pa=(a,t=i)=>na+`(${o(t,ga,Aa(a))})`,Oa=a=>new Set(d(a)||l(a)?a:[a]),Ra=(a,t)=>a?.add(t),ma="ColumnName",va="store",Ca="json",Ia=va+"TableName",La=va+"Id"+ma,Sa=va+ma,_a="autoLoadIntervalSeconds",ba="rowId"+ma,fa="tableId",Da="tableName",Pa="deleteEmptyColumns",ha="deleteEmptyTable",Fa="condition",Ma={mode:Ca,[_a]:1},Ua={load:0,save:0,[Da]:t+"_values"},Ga=(a,t,e,n,s)=>{const i=z();return x(a,(a,o)=>{const r=u(W(U(t,y(a)?{[e]:a}:a)),0,B(t));l(r[0])||n(o,r[0])||(s(o,r[0]),V(i,o,r))}),i},ja=/^\d+$/,xa=z(),Wa=z(),Ba=(a,t,n,s,i,o,r,c={},y=0,u=[])=>{let N,g,p,O=0,R=0,m=0;Q(xa,u,()=>0),Q(Wa,u,()=>[]);const I=z(),[S,f,D,P,h]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!H(a)||!H(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!H(a)||!H(t),t.setContent]:A("Store type not supported by this Persister"))(r,a,y),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{ja.test(t)&&E(a)<1e3&&v(a,t)}]})(),s=z();return[(n,i,o,r=[],c=()=>[])=>{a??=ta;const l=t(1);return V(s,l,[n,i,o,r,c]),Ra(Z(i,o??[e],Oa),l),l},(t,n,...i)=>$(((a,t=[e])=>{const n=[],s=(a,e)=>e==E(t)?v(n,a):null===t[e]?_(a,a=>s(a,e+1)):$([t[e],null],t=>s(J(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>J(s,t)[0](a,...n??[],...i))),a=>w(J(s,a),([,t,i])=>(Z(t,i??[e],void 0,t=>(b(t,a),L(t)?1:0)),V(s,a),n(a),i)),t=>w(J(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=E(o);r==E(e)?t(a,...o,...s(o)):l(e[r])?$(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),j=a=>{a!=O&&(O=a,U(I,void 0,O))},x=t=>{(S&&d(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},W=async a=>(2!=O&&(j(1),R++,await aa(async()=>{await T(async()=>{const e=await t();d(e)?x(e):a?h(a):A("Content is not an array: "+e)},()=>{a&&h(a)}),j(0)})),ta),B=async a=>(X(),await W(a),await T(async()=>g=await s(async(a,t)=>{t||a?2!=O&&(j(1),R++,x(t??a),j(0)):await W()}),o),ta),X=async()=>(g&&(await T(()=>i(g),o),g=void 0),ta),Y=async a=>(1!=O&&(j(2),m++,await aa(async()=>{await T(()=>n(f,a),o),j(0)})),ta),k=async()=>(q(),await Y(),p=a.addDidFinishTransactionListener(()=>{const a=D();P(a)&&Y(a)}),ta),q=async()=>(p&&(a.delListener(p),p=void 0),ta),K=async(a=!1)=>{const[t,e]=a?[q,X]:[X,q];return await t(),await e(),ta},aa=async(...a)=>(v(J(Wa,u),...a),await(async()=>{if(!J(xa,u)){for(V(xa,u,1);!l(N=C(J(Wa,u)));)await T(N,o);V(xa,u,0)}})(),ta),ta={load:W,startAutoLoad:B,stopAutoLoad:X,isAutoLoading:()=>!l(g),save:Y,startAutoSave:k,stopAutoSave:q,isAutoSaving:()=>!l(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,B]:[B,k];return await e(a),await n(a),ta},stopAutoPersisting:K,getStatus:()=>O,addStatusListener:a=>M(a,I),delListener:t=>(G(t),a),schedule:aa,getStore:()=>a,destroy:()=>(J(Wa,u).splice(0,void 0),K()),getStats:()=>({loads:R,saves:m}),...c};return F(ta)},Ha=(a,t,e,s,o,r=Xa,c,w)=>{const y=z();return[async()=>{y.clear(),O(await e(a,t),({tn:a,cn:t})=>Ra(Q(y,a,Oa),t))},async(t,e,n)=>((a,t)=>I(J(y,a),t))(t,e)?M(m(O(await a(ya+Aa(t)+pa(t,n)),a=>[a[e],w?x(G(a,e),w):G(a,e)]),([a,t])=>!l(a)&&!H(t))):{},async(t,e,s,w,d,u=!1,E=i)=>{const N=Oa();x(s??{},a=>O(h(a??{}),a=>Ra(N,a)));const A=S(N);if(!u&&d&&E==i&&R(A)&&I(y,t))return await a("DROP "+sa+Aa(t)),void V(y,t);const T=J(y,t),$=Oa(S(T));if(R(A)||(I(y,t)?await g(O([e,...A],async(n,s)=>{b($,n)||(await a(ca+Aa(t)+"ADD"+Aa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Aa(t)+`(${Aa(e)})`),Ra(T,n))})):(await a(ua+Aa(t)+`(${Aa(e)}${o} PRIMARY KEY${p(O(A,a=>n+Aa(a)+o))});`),V(y,t,Oa([e,...A])))),await g([...!u&&w?O(S($),async n=>{n!=e&&(await a(ca+Aa(t)+"DROP"+Aa(n)),b(T,n))}):[]]),u)l(s)?await a(wa+Aa(t)+pa(t,E)):await g(j(s,async(n,s)=>{l(n)?await a(wa+Aa(t)+pa(t,E)+`AND(${Aa(e)}=$1)`,[s]):R(A)||await r(a,t,e,h(n),{[s]:c?O(W(n),c):W(n)},T)}));else if(R(A))I(y,t)&&await a(wa+Aa(t)+pa(t,E));else{const n=m(S(J(y,t)),a=>a!=e),i={},o=[];x(s??{},(a,t)=>{i[t]=O(n,t=>c?c(a?.[t]):a?.[t]),v(o,t)}),await r(a,t,e,n,i),await a(wa+Aa(t)+pa(t,E)+`AND${Aa(e)}NOT IN(${$a(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await T(async()=>e=await t(),s),await a("END"),e}]},Xa=async(a,t,e,s,i)=>{const o=[1];await a(ia+" INTO"+Aa(t)+"("+((...a)=>p(O(a,Aa),n))(e,...s)+")VALUES"+p(j(i,a=>"($"+o[0]+++","+$a(a,o)+")"),n)+"ON CONFLICT("+Aa(e)+`)DO ${ra} SET`+p(O(s,a=>Aa(a)+"=excluded."+Aa(a)),n),j(i,(a,t)=>[t,...O(a,a=>a??null)]).flat())},Ya=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=Ha(t,w,y,s,E,N),p=Ba(a,()=>$(async()=>{return await g(),a=(await A(r,c))[aa]?.[l]??"null",Y(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(r,c,{[aa]:{[l]:k(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},ka=(a,t,e,n,s,i,o,[r,c,[w,y,d]],u,E,N,A,T,$,p,O)=>{const[R,v,C,I]=Ha(t,u,E,s,T,$,p,O),L=(a,t)=>g(K(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)})),S=async(a,t)=>y?await C(d,ta,{[aa]:a},!0,!0,t):null,_=Ba(a,()=>I(async()=>{await R();const a=await(async()=>M(m(await g(K(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!H(a[1]))))(),t=await(async()=>w?(await v(d,ta))[aa]:{})();return H(a)&&l(t)?void 0:[a,t]}),(a,t)=>I(async()=>{if(await R(),l(t)){const[t,e]=a();await L(t),await S(e)}else await L(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[A]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},qa=/^([cd]:)(.+)/,za=(a,n,s,r,c,l,d,E,N,A,T="getDb")=>{const R=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[m,,v,C]=(a=>{const e=(a=>U(Ma,y(a)?{[Ia]:a}:a??{}))(a),n=e[_a];if(e.mode==Ca){const a=e[Ia]??t;return[1,n,[a,e[La]??ta,e[Sa]??va],Oa(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=u(W(U(Ua,r)),0,B(Ua)),l=c[2],w=Oa(l),d=Oa(l),E=Ga(s,{[fa]:null,[ba]:ta,[Fa]:i},fa,a=>I(d,a),a=>Ra(w,a)),N=Ga(o,{[Da]:null,[ba]:ta,[Pa]:0,[ha]:0,[Fa]:null},Da,(a,t)=>I(d,t),(a,t)=>Ra(w,t));var g;return g=(a,t)=>t[4]??=J(E,t[0])?.[2]??i,_(N,(a,t)=>g(0,a)),[0,n,[E,N,c],w]})(n),L=e+(a=>{let t=2166136261;return $(q.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(k(v)),b=t+"_"+L,f=async(a,e,n="",s="")=>{const i=Ta(t,a,L);return await R(da+Ea+Na+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},D=async(a,t,e,n)=>(await R(da+a+"TRIGGER"+t+e+"EXECUTE "+Na+n+"()"),t),P=a=>`PERFORM pg_notify('${b}',${a});`,h=(a,t)=>m?i:2===t?h(a,0)+" OR "+h(a,1):o(J(v[0],a)?.[2]??i,ga,0==t?"NEW":"OLD"),F=(a,e)=>g(O([ia,oa,ra],(n,s)=>D(Ea,Ta(t,"d",L,a,n),`AFTER ${n} ON${Aa(a)}FOR EACH ROW WHEN(${h(a,s)})`,e)));return(m?Ya:ka)(a,R,async a=>{const e=await f("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${na} command_tag='${ua}' LOOP ${P("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await D("EVENT ",Ta(t,"c",L),`ON ddl_command_end WHEN TAG IN('${ua}')`,e);const n=await f("d",P("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await g(O(S(C),async a=>(await R(ua+` IF NOT EXISTS${Aa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(b,t=>{return w((e=t,s=qa,e?.match(s)),async([,t,e])=>{I(C,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await R(`DROP FUNCTION IF EXISTS${p(t,",")}CASCADE`)},d,E,N,v,S(C),async(a,t)=>await a(ea+` table_name tn,column_name cn FROM information_schema.columns ${na} table_schema='public'AND table_name IN(${$a(t)})`,t),A,T,"text",void 0,a=>X(a),a=>Y(a))},Ja=async(a,t,e,n,s)=>za(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>T(a,s),n,s,N,3,t,"getPglite");export{Ja as createPglitePersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},v=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),F=Object,M=a=>F.getPrototypeOf(a),U=F.entries,G=F.keys,j=F.freeze,x=(a=[])=>F.fromEntries(a),W=(...a)=>F.assign({},...a),B=(a,t)=>(delete a[t],a),H=(a,t)=>C(U(a),([a,e])=>t(e,a)),X=(a,t)=>x(H(a,(a,e)=>[e,t(a,e)])),Y=a=>F.values(a),k=a=>T(G(a)),q=a=>(a=>!w(a)&&u(M(a),a=>a==F.prototype||w(M(a)),()=>!0))(a)&&0==k(a),z=JSON.stringify,J=JSON.parse,K=a=>z(a,(a,t)=>void 0===t?"":t),V=new l.TextEncoder,Q=a=>new Map(a),Z=(a,t)=>a?.get(t),aa=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),ta=(a,t,e)=>void 0===e?(h(a,t),a):a?.set(t,e),ea=(a,t,e,n)=>(b(a,t)?n?.(Z(a,t)):ta(a,t,e()),Z(a,t)),na=(a,t,e,n,s=0)=>E((e?ea:Z)(a,t[s],s>T(t)-2?e:Q),i=>{if(s>T(t)-2)return n?.(i)&&ta(a,t[s]),i;const o=na(i,t,e,n,s+1);return f(i)&&ta(a,t[s]),o}),sa="_",ia="_id",oa="SELECT",ra="WHERE",ca="TABLE",la="INSERT",wa="DELETE",ya="UPDATE",da="ALTER "+ca,ua="FROM",Ea=wa+" "+ua,Na=oa+"*"+ua,ga="CREATE ",Aa=ga+ca,Ta="OR REPLACE ",$a="FUNCTION",pa="$tableName",Oa=a=>m(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Ra=(...a)=>Oa(m(a,"_")),va=(a,t=[1])=>m(C(a,()=>"$"+t[0]++),n),ma=(a,t=i)=>ra+`(${o(t,pa,Oa(a))})`,Ca=a=>new Set(g(a)||y(a)?a:[a]),Ia=(a,t)=>a?.add(t),La="ColumnName",Sa="store",_a="json",ba=Sa+"TableName",fa=Sa+"Id"+La,Da=Sa+La,Pa="autoLoadIntervalSeconds",ha="rowId"+La,Fa="tableId",Ma="tableName",Ua="deleteEmptyColumns",Ga="deleteEmptyTable",ja="condition",xa={mode:_a,[Pa]:1},Wa={load:0,save:0,[Ma]:t+"_values"},Ba=(a,t,e,n,s)=>{const i=Q();return X(a,(a,o)=>{const r=A(Y(W(t,N(a)?{[e]:a}:a)),0,k(t));d(r[0])||n(o,r[0])||(s(o,r[0]),ta(i,o,r))}),i},Ha=/^\d+$/,Xa=Q(),Ya=Q(),ka=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let u,N,A,$=0,p=0,m=0;ea(Xa,w,()=>0),ea(Ya,w,()=>[]);const C=Q(),[I,L,b,D,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:O("Store type not supported by this Persister"))(r,a,l),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?_(a):null)??e+t++,t=>{Ha.test(t)&&T(a)<1e3&&S(a,t)}]})(),s=Q();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return ta(s,l,[n,i,o,r,c]),Ia(na(i,o??[e],Ca),l),l},(t,n,...i)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?S(n,a):null===t[e]?P(a,a=>s(a,e+1)):v([t[e],null],t=>s(Z(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>Z(s,t)[0](a,...n??[],...i))),a=>E(Z(s,a),([,t,i])=>(na(t,i??[e],void 0,t=>(h(t,a),f(t)?1:0)),ta(s,a),n(a),i)),t=>E(Z(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):d(e[r])?v(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(I&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(x(1),p++,await K(async()=>{await R(async()=>{const e=await t();g(e)?W(e):a?F(a):O("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),V),H=async a=>(X(),await B(a),await R(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),p++,W(t??a),x(0)):await B()}),o),V),X=async()=>(N&&(await R(()=>i(N),o),N=void 0),V),Y=async a=>(1!=$&&(x(2),m++,await K(async()=>{await R(()=>n(L,a),o),x(0)})),V),k=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=b();D(a)&&Y(a)}),V),z=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),V},K=async(...a)=>(S(Z(Ya,w),...a),await(async()=>{if(!Z(Xa,w)){for(ta(Xa,w,1);!y(u=_(Z(Ya,w)));)await R(u,o);ta(Xa,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(Z(Ya,w).splice(0,void 0),J()),getStats:()=>({loads:p,saves:m}),...c};return j(V)},qa=(a,t,e,s,o,r=za,c,l)=>{const w=Q();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Ia(ea(w,a,Ca),t))},async(t,e,n)=>((a,t)=>b(Z(w,a),t))(t,e)?x(L(C(await a(Na+Oa(t)+ma(t,n)),a=>[a[e],l?X(B(a,e),l):B(a,e)]),([a,t])=>!y(a)&&!q(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=Ca();X(s??{},a=>C(G(a??{}),a=>Ia(N,a)));const g=D(N);if(!u&&d&&E==i&&I(g)&&b(w,t))return await a("DROP "+ca+Oa(t)),void ta(w,t);const A=Z(w,t),T=Ca(D(A));if(I(g)||(b(w,t)?await p(C([e,...g],async(n,s)=>{h(T,n)||(await a(da+Oa(t)+"ADD"+Oa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Oa(t)+`(${Oa(e)})`),Ia(A,n))})):(await a(Aa+Oa(t)+`(${Oa(e)}${o} PRIMARY KEY${m(C(g,a=>n+Oa(a)+o))});`),ta(w,t,Ca([e,...g])))),await p([...!u&&l?C(D(T),async n=>{n!=e&&(await a(da+Oa(t)+"DROP"+Oa(n)),h(A,n))}):[]]),u)y(s)?await a(Ea+Oa(t)+ma(t,E)):await p(H(s,async(n,s)=>{y(n)?await a(Ea+Oa(t)+ma(t,E)+`AND(${Oa(e)}=$1)`,[s]):I(g)||await r(a,t,e,G(n),{[s]:c?C(Y(n),c):Y(n)},A)}));else if(I(g))b(w,t)&&await a(Ea+Oa(t)+ma(t,E));else{const n=L(D(Z(w,t)),a=>a!=e),i={},o=[];X(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),S(o,t)}),await r(a,t,e,n,i),await a(Ea+Oa(t)+ma(t,E)+`AND${Oa(e)}NOT IN(${va(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await R(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const o=[1];await a(la+" INTO"+Oa(t)+"("+((...a)=>m(C(a,Oa),n))(e,...s)+")VALUES"+m(H(i,a=>"($"+o[0]+++","+va(a,o)+")"),n)+"ON CONFLICT("+Oa(e)+`)DO ${ya} SET`+m(C(s,a=>Oa(a)+"=excluded."+Oa(a)),n),H(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ja=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=qa(t,w,y,s,E,N),p=ka(a,()=>$(async()=>{return await g(),a=(await A(r,c))[sa]?.[l]??"null",J(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(r,c,{[sa]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},Ka=(a,t,e,n,s,i,o,[r,c,[l,w,d]],u,E,N,g,A,T,$,O)=>{const[R,v,m,C]=qa(t,u,E,s,A,T,$,O),I=(a,t)=>p(aa(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await m(e,n,a[r],s,i,t,o)})),S=async(a,t)=>w?await m(d,ia,{[sa]:a},!0,!0,t):null,_=ka(a,()=>C(async()=>{await R();const a=await(async()=>x(L(await p(aa(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await v(d,ia))[sa]:{})();return q(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await S(e)}else await I(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Va=/^([cd]:)(.+)/,Qa=(a,n,s,r,c,l,w,y,d,u,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[$,,O,R]=(a=>{const e=(a=>W(xa,N(a)?{[ba]:a}:a??{}))(a),n=e[Pa];if(e.mode==_a){const a=e[ba]??t;return[1,n,[a,e[fa]??ia,e[Da]??Sa],Ca(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(Y(W(Wa,r)),0,k(Wa)),l=c[2],w=Ca(l),y=Ca(l),d=Ba(s,{[Fa]:null,[ha]:ia,[ja]:i},Fa,a=>b(y,a),a=>Ia(w,a)),u=Ba(o,{[Ma]:null,[ha]:ia,[Ua]:0,[Ga]:0,[ja]:null},Ma,(a,t)=>b(y,t),(a,t)=>Ia(w,t));var E;return E=(a,t)=>t[4]??=Z(d,t[0])?.[2]??i,P(u,(a,t)=>E(0,a)),[0,n,[d,u,c],w]})(n),I=e+(a=>{let t=2166136261;return v(V.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(K(O)),L=t+"_"+I,S=async(a,e,n="",s="")=>{const i=Ra(t,a,I);return await T(ga+Ta+$a+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await T(ga+a+"TRIGGER"+t+e+"EXECUTE "+$a+n+"()"),t),f=a=>`PERFORM pg_notify('${L}',${a});`,h=(a,t)=>$?i:2===t?h(a,0)+" OR "+h(a,1):o(Z(O[0],a)?.[2]??i,pa,0==t?"NEW":"OLD"),F=(a,e)=>p(C([la,wa,ya],(n,s)=>_(Ta,Ra(t,"d",I,a,n),`AFTER ${n} ON${Oa(a)}FOR EACH ROW WHEN(${h(a,s)})`,e)));return($?Ja:Ka)(a,T,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ra} command_tag='${Aa}' LOOP ${f("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",Ra(t,"c",I),`ON ddl_command_end WHEN TAG IN('${Aa}')`,e);const n=await S("d",f("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await p(C(D(R),async a=>(await T(Aa+` IF NOT EXISTS${Oa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(L,t=>{return E((e=t,s=Va,e?.match(s)),async([,t,e])=>{b(R,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,y,d,O,D(R),async(a,t)=>await a(oa+` table_name tn,column_name cn FROM information_schema.columns ${ra} table_schema='public'AND table_name IN(${va(t)})`,t),u,g,"text",void 0,a=>z(a),a=>J(a))},Za=async(a,t,e,n,s)=>Qa(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>R(a,s),n,s,$,3,t,"getPglite");export{Za as createPglitePersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=globalThis,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,u=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),E=a=>a.length,N=async a=>o.all(a),g=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),$=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),O=a=>0==E(a),R=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),v=a=>a.shift(),C=(a,t)=>a?.has(t)??!1,S=a=>l(a)||0==(a=>a?.size??0)(a),I=a=>[...a?.values()??[]],L=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),b=Object,f=a=>b.getPrototypeOf(a),D=b.entries,h=b.keys,P=b.freeze,F=(a=[])=>b.fromEntries(a),M=(...a)=>b.assign({},...a),U=(a,t)=>(delete a[t],a),G=(a,t)=>p(D(a),([a,e])=>t(e,a)),j=(a,t)=>F(G(a,(a,e)=>[e,t(a,e)])),x=a=>b.values(a),W=a=>E(h(a)),B=a=>(a=>!l(a)&&w(f(a),a=>a==b.prototype||l(f(a)),()=>!0))(a)&&0==W(a),H=JSON.stringify,X=JSON.parse,Y=a=>H(a,(a,t)=>void 0===t?"":t),k=new c.TextEncoder,q=a=>new Map(a),z=(a,t)=>a?.get(t),J=(a,t)=>p([...a?.entries()??[]],([a,e])=>t(e,a)),K=(a,t,e)=>l(e)?(_(a,t),a):a?.set(t,e),V=(a,t,e,n)=>(C(a,t)?n?.(z(a,t)):K(a,t,e()),z(a,t)),Q=(a,t,e,n,s=0)=>w((e?V:z)(a,t[s],s>E(t)-2?e:q),i=>{if(s>E(t)-2)return n?.(i)&&K(a,t[s]),i;const r=Q(i,t,e,n,s+1);return S(i)&&K(a,t[s]),r}),Z="_",aa="_id",ta="SELECT",ea="WHERE",na="TABLE",sa="INSERT",ia="DELETE",ra="UPDATE",oa="ALTER "+na,ca="FROM",la=ia+" "+ca,wa=ta+"*"+ca,ya="CREATE ",ua=ya+na,da="OR REPLACE ",Ea="FUNCTION",Na="$tableName",ga=a=>$(p(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Aa=(...a)=>ga($(a,"_")),Ta=(a,t=[1])=>$(p(a,()=>"$"+t[0]++),n),$a=(a,t=i)=>ea+`(${r(t,Na,ga(a))})`,pa=a=>new Set(u(a)||l(a)?a:[a]),Oa=(a,t)=>a?.add(t),Ra="ColumnName",ma="store",va="json",Ca=ma+"TableName",Sa=ma+"Id"+Ra,Ia=ma+Ra,La="autoLoadIntervalSeconds",_a="rowId"+Ra,ba="tableId",fa="tableName",Da="deleteEmptyColumns",ha="deleteEmptyTable",Pa="condition",Fa={mode:va,[La]:1},Ma={load:0,save:0,[fa]:t+"_values"},Ua=(a,t,e,n,s)=>{const i=q();return j(a,(a,r)=>{const o=d(x(M(t,y(a)?{[e]:a}:a)),0,W(t));l(o[0])||n(r,o[0])||(s(r,o[0]),K(i,r,o))}),i},Ga=/^\d+$/,ja=q(),xa=q(),Wa=(a,t,n,s,i,r,o,c={},y=0,d=[])=>{let N,$,p,O=0,R=0,C=0;V(ja,d,()=>0),V(xa,d,()=>[]);const I=q(),[b,f,D,h,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!B(a)||!B(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!B(a)||!B(t),t.setContent]:g("Store type not supported by this Persister"))(o,a,y),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?v(a):null)??e+t++,t=>{Ga.test(t)&&E(a)<1e3&&m(a,t)}]})(),s=q();return[(n,i,r,o=[],c=()=>[])=>{a??=ta;const l=t(1);return K(s,l,[n,i,r,o,c]),Oa(Q(i,r??[e],pa),l),l},(t,n,...i)=>T(((a,t=[e])=>{const n=[],s=(a,e)=>e==E(t)?m(n,a):null===t[e]?L(a,a=>s(a,e+1)):T([t[e],null],t=>s(z(a,t),e+1));return s(a,0),n})(t,n),t=>L(t,t=>z(s,t)[0](a,...n??[],...i))),a=>w(z(s,a),([,t,i])=>(Q(t,i??[e],void 0,t=>(_(t,a),S(t)?1:0)),K(s,a),n(a),i)),t=>w(z(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=E(r);o==E(e)?t(a,...r,...s(r)):l(e[o])?T(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=O&&(O=a,U(I,void 0,O))},x=t=>{(b&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},W=async a=>(2!=O&&(j(1),R++,await aa(async()=>{await A(async()=>{const e=await t();u(e)?x(e):a?F(a):g("Content is not an array: "+e)},()=>{a&&F(a)}),j(0)})),ta),H=async a=>(X(),await W(a),await A(async()=>$=await s(async(a,t)=>{t||a?2!=O&&(j(1),R++,x(t??a),j(0)):await W()}),r),ta),X=async()=>($&&(await A(()=>i($),r),$=void 0),ta),Y=async a=>(1!=O&&(j(2),C++,await aa(async()=>{await A(()=>n(f,a),r),j(0)})),ta),k=async()=>(J(),await Y(),p=a.addDidFinishTransactionListener(()=>{const a=D();h(a)&&Y(a)}),ta),J=async()=>(p&&(a.delListener(p),p=void 0),ta),Z=async(a=!1)=>{const[t,e]=a?[J,X]:[X,J];return await t(),await e(),ta},aa=async(...a)=>(m(z(xa,d),...a),await(async()=>{if(!z(ja,d)){for(K(ja,d,1);!l(N=v(z(xa,d)));)await A(N,r);K(ja,d,0)}})(),ta),ta={load:W,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!l($),save:Y,startAutoSave:k,stopAutoSave:J,isAutoSaving:()=>!l(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),ta},stopAutoPersisting:Z,getStatus:()=>O,addStatusListener:a=>M(a,I),delListener:t=>(G(t),a),schedule:aa,getStore:()=>a,destroy:()=>(z(xa,d).splice(0,void 0),Z()),getStats:()=>({loads:R,saves:C}),...c};return P(ta)},Ba=(a,t,e,s,r,o=Ha,c,w)=>{const y=q();return[async()=>{y.clear(),p(await e(a,t),({tn:a,cn:t})=>Oa(V(y,a,pa),t))},async(t,e,n)=>((a,t)=>C(z(y,a),t))(t,e)?F(R(p(await a(wa+ga(t)+$a(t,n)),a=>[a[e],w?j(U(a,e),w):U(a,e)]),([a,t])=>!l(a)&&!B(t))):{},async(t,e,s,w,u,d=!1,E=i)=>{const g=pa();j(s??{},a=>p(h(a??{}),a=>Oa(g,a)));const A=I(g);if(!d&&u&&E==i&&O(A)&&C(y,t))return await a("DROP "+na+ga(t)),void K(y,t);const T=z(y,t),v=pa(I(T));if(O(A)||(C(y,t)?await N(p([e,...A],async(n,s)=>{_(v,n)||(await a(oa+ga(t)+"ADD"+ga(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ga(t)+`(${ga(e)})`),Oa(T,n))})):(await a(ua+ga(t)+`(${ga(e)}${r} PRIMARY KEY${$(p(A,a=>n+ga(a)+r))});`),K(y,t,pa([e,...A])))),await N([...!d&&w?p(I(v),async n=>{n!=e&&(await a(oa+ga(t)+"DROP"+ga(n)),_(T,n))}):[]]),d)l(s)?await a(la+ga(t)+$a(t,E)):await N(G(s,async(n,s)=>{l(n)?await a(la+ga(t)+$a(t,E)+`AND(${ga(e)}=$1)`,[s]):O(A)||await o(a,t,e,h(n),{[s]:c?p(x(n),c):x(n)},T)}));else if(O(A))C(y,t)&&await a(la+ga(t)+$a(t,E));else{const n=R(I(z(y,t)),a=>a!=e),i={},r=[];j(s??{},(a,t)=>{i[t]=p(n,t=>c?c(a?.[t]):a?.[t]),m(r,t)}),await o(a,t,e,n,i),await a(la+ga(t)+$a(t,E)+`AND${ga(e)}NOT IN(${Ta(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},Ha=async(a,t,e,s,i)=>{const r=[1];await a(sa+" INTO"+ga(t)+"("+((...a)=>$(p(a,ga),n))(e,...s)+")VALUES"+$(G(i,a=>"($"+r[0]+++","+Ta(a,r)+")"),n)+"ON CONFLICT("+ga(e)+`)DO ${ra} SET`+$(p(s,a=>ga(a)+"=excluded."+ga(a)),n),G(i,(a,t)=>[t,...p(a,a=>a??null)]).flat())},Xa=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=Ba(t,w,y,s,E,N),p=Wa(a,()=>$(async()=>{return await g(),a=(await A(o,c))[Z]?.[l]??"null",X(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(o,c,{[Z]:{[l]:Y(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Ya=(a,t,e,n,s,i,r,[o,c,[w,y,u]],d,E,g,A,T,$,p,O)=>{const[m,v,C,S]=Ba(t,d,E,s,T,$,p,O),I=(a,t)=>N(J(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),L=async(a,t)=>y?await C(u,aa,{[Z]:a},!0,!0,t):null,_=Wa(a,()=>S(async()=>{await m();const a=await(async()=>F(R(await N(J(o,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!B(a[1]))))(),t=await(async()=>w?(await v(u,aa))[Z]:{})();return B(a)&&l(t)?void 0:[a,t]}),(a,t)=>S(async()=>{if(await m(),l(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}),e,n,s,r,{[A]:()=>g,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,g);return _},ka=/^([cd]:)(.+)/,qa=(a,n,s,o,c,l,u,E,g,A,O="getDb")=>{const R=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[m,,v,S]=(a=>{const e=(a=>M(Fa,y(a)?{[Ca]:a}:a??{}))(a),n=e[La];if(e.mode==va){const a=e[Ca]??t;return[1,n,[a,e[Sa]??aa,e[Ia]??ma],pa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(x(M(Ma,o)),0,W(Ma)),l=c[2],w=pa(l),u=pa(l),E=Ua(s,{[ba]:null,[_a]:aa,[Pa]:i},ba,a=>C(u,a),a=>Oa(w,a)),N=Ua(r,{[fa]:null,[_a]:aa,[Da]:0,[ha]:0,[Pa]:null},fa,(a,t)=>C(u,t),(a,t)=>Oa(w,t));var g;return g=(a,t)=>t[4]??=z(E,t[0])?.[2]??i,L(N,(a,t)=>g(0,a)),[0,n,[E,N,c],w]})(n),_=e+(a=>{let t=2166136261;return T(k.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(Y(v)),b=t+"_"+_,f=async(a,e,n="",s="")=>{const i=Aa(t,a,_);return await R(ya+da+Ea+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},D=async(a,t,e,n)=>(await R(ya+a+"TRIGGER"+t+e+"EXECUTE "+Ea+n+"()"),t),h=a=>`PERFORM pg_notify('${b}',${a});`,P=(a,t)=>m?i:2===t?P(a,0)+" OR "+P(a,1):r(z(v[0],a)?.[2]??i,Na,0==t?"NEW":"OLD"),F=(a,e)=>N(p([sa,ia,ra],(n,s)=>D(da,Aa(t,"d",_,a,n),`AFTER ${n} ON${ga(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(m?Xa:Ya)(a,R,async a=>{const e=await f("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ea} command_tag='${ua}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await D("EVENT ",Aa(t,"c",_),`ON ddl_command_end WHEN TAG IN('${ua}')`,e);const n=await f("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await N(p(I(S),async a=>(await R(ua+` IF NOT EXISTS${ga(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await o(b,t=>{return w((e=t,s=ka,e?.match(s)),async([,t,e])=>{C(S,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await R(`DROP FUNCTION IF EXISTS${$(t,",")}CASCADE`)},u,E,g,v,I(S),async(a,t)=>await a(ta+` table_name tn,column_name cn FROM information_schema.columns ${ea} table_schema='public'AND table_name IN(${Ta(t)})`,t),A,O,"text",void 0,a=>H(a),a=>X(a))},za=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return qa(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>A(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{za as createPostgresPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=async a=>r.all(a),p=a=>{throw Error(a)},O=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),m=(a,t)=>a.map(t),C=a=>0==T(a),S=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),L=a=>a.shift(),_=(a,t)=>a?.has(t)??!1,b=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),P=Object,F=a=>P.getPrototypeOf(a),M=P.entries,U=P.keys,G=P.freeze,j=(a=[])=>P.fromEntries(a),x=(...a)=>P.assign({},...a),W=(a,t)=>(delete a[t],a),B=(a,t)=>m(M(a),([a,e])=>t(e,a)),H=(a,t)=>j(B(a,(a,e)=>[e,t(a,e)])),X=a=>P.values(a),Y=a=>T(U(a)),k=a=>(a=>!w(a)&&d(F(a),a=>a==P.prototype||w(F(a)),()=>!0))(a)&&0==Y(a),q=JSON.stringify,z=JSON.parse,J=a=>q(a,(a,t)=>void 0===t?"":t),K=new l.TextEncoder,V=a=>new Map(a),Q=(a,t)=>a?.get(t),Z=(a,t)=>m([...a?.entries()??[]],([a,e])=>t(e,a)),aa=(a,t,e)=>void 0===e?(h(a,t),a):a?.set(t,e),ta=(a,t,e,n)=>(_(a,t)?n?.(Q(a,t)):aa(a,t,e()),Q(a,t)),ea=(a,t,e,n,s=0)=>E((e?ta:Q)(a,t[s],s>T(t)-2?e:V),i=>{if(s>T(t)-2)return n?.(i)&&aa(a,t[s]),i;const o=ea(i,t,e,n,s+1);return b(i)&&aa(a,t[s]),o}),na="_",sa="_id",ia="SELECT",oa="WHERE",ra="TABLE",ca="INSERT",la="DELETE",wa="UPDATE",ya="ALTER "+ra,ua="FROM",da=la+" "+ua,Ea=ia+"*"+ua,Na="CREATE ",ga=Na+ra,Aa="OR REPLACE ",Ta="FUNCTION",$a="$tableName",pa=a=>v(m(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Oa=(...a)=>pa(v(a,"_")),Ra=(a,t=[1])=>v(m(a,()=>"$"+t[0]++),n),va=(a,t=i)=>oa+`(${o(t,$a,pa(a))})`,ma=a=>new Set(g(a)||y(a)?a:[a]),Ca=(a,t)=>a?.add(t),Sa="ColumnName",Ia="store",La="json",_a=Ia+"TableName",ba=Ia+"Id"+Sa,fa=Ia+Sa,Da="autoLoadIntervalSeconds",ha="rowId"+Sa,Pa="tableId",Fa="tableName",Ma="deleteEmptyColumns",Ua="deleteEmptyTable",Ga="condition",ja={mode:La,[Da]:1},xa={load:0,save:0,[Fa]:t+"_values"},Wa=(a,t,e,n,s)=>{const i=V();return H(a,(a,o)=>{const r=A(X(x(t,N(a)?{[e]:a}:a)),0,Y(t));u(r[0])||n(o,r[0])||(s(o,r[0]),aa(i,o,r))}),i},Ba=/^\d+$/,Ha=V(),Xa=V(),Ya=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,N,A,$=0,v=0,m=0;ta(Ha,w,()=>0),ta(Xa,w,()=>[]);const C=V(),[S,_,f,P,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:p("Store type not supported by this Persister"))(r,a,l),[M,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?L(a):null)??e+t++,t=>{Ba.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=V();return[(n,i,o,r=[],c=()=>[])=>{a??=Z;const l=t(1);return aa(s,l,[n,i,o,r,c]),Ca(ea(i,o??[e],ma),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?I(n,a):null===t[e]?D(a,a=>s(a,e+1)):R([t[e],null],t=>s(Q(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>Q(s,t)[0](a,...n??[],...i))),a=>E(Q(s,a),([,t,i])=>(ea(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),aa(s,a),n(a),i)),t=>E(Q(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):u(e[r])?R(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(S&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(x(1),v++,await K(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?F(a):p("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),Z),H=async a=>(X(),await B(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),v++,W(t??a),x(0)):await B()}),o),Z),X=async()=>(N&&(await O(()=>i(N),o),N=void 0),Z),Y=async a=>(1!=$&&(x(2),m++,await K(async()=>{await O(()=>n(_,a),o),x(0)})),Z),q=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&Y(a)}),Z),z=async()=>(A&&(a.delListener(A),A=void 0),Z),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),Z},K=async(...a)=>(I(Q(Xa,w),...a),await(async()=>{if(!Q(Ha,w)){for(aa(Ha,w,1);!y(d=L(Q(Xa,w)));)await O(d,o);aa(Ha,w,0)}})(),Z),Z={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,H]:[H,q];return await e(a),await n(a),Z},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(Q(Xa,w).splice(0,void 0),J()),getStats:()=>({loads:v,saves:m}),...c};return G(Z)},ka=(a,t,e,s,o,r=qa,c,l)=>{const w=V();return[async()=>{w.clear(),m(await e(a,t),({tn:a,cn:t})=>Ca(ta(w,a,ma),t))},async(t,e,n)=>((a,t)=>_(Q(w,a),t))(t,e)?j(S(m(await a(Ea+pa(t)+va(t,n)),a=>[a[e],l?H(W(a,e),l):W(a,e)]),([a,t])=>!y(a)&&!k(t))):{},async(t,e,s,l,u,d=!1,E=i)=>{const N=ma();H(s??{},a=>m(U(a??{}),a=>Ca(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+ra+pa(t)),void aa(w,t);const A=Q(w,t),T=ma(f(A));if(C(g)||(_(w,t)?await $(m([e,...g],async(n,s)=>{h(T,n)||(await a(ya+pa(t)+"ADD"+pa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+pa(t)+`(${pa(e)})`),Ca(A,n))})):(await a(ga+pa(t)+`(${pa(e)}${o} PRIMARY KEY${v(m(g,a=>n+pa(a)+o))});`),aa(w,t,ma([e,...g])))),await $([...!d&&l?m(f(T),async n=>{n!=e&&(await a(ya+pa(t)+"DROP"+pa(n)),h(A,n))}):[]]),d)y(s)?await a(da+pa(t)+va(t,E)):await $(B(s,async(n,s)=>{y(n)?await a(da+pa(t)+va(t,E)+`AND(${pa(e)}=$1)`,[s]):C(g)||await r(a,t,e,U(n),{[s]:c?m(X(n),c):X(n)},A)}));else if(C(g))_(w,t)&&await a(da+pa(t)+va(t,E));else{const n=S(f(Q(w,t)),a=>a!=e),i={},o=[];H(s??{},(a,t)=>{i[t]=m(n,t=>c?c(a?.[t]):a?.[t]),I(o,t)}),await r(a,t,e,n,i),await a(da+pa(t)+va(t,E)+`AND${pa(e)}NOT IN(${Ra(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},qa=async(a,t,e,s,i)=>{const o=[1];await a(ca+" INTO"+pa(t)+"("+((...a)=>v(m(a,pa),n))(e,...s)+")VALUES"+v(B(i,a=>"($"+o[0]+++","+Ra(a,o)+")"),n)+"ON CONFLICT("+pa(e)+`)DO ${wa} SET`+v(m(s,a=>pa(a)+"=excluded."+pa(a)),n),B(i,(a,t)=>[t,...m(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=ka(t,w,y,s,E,N),p=Ya(a,()=>$(async()=>{return await g(),a=(await A(r,c))[na]?.[l]??"null",z(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(r,c,{[na]:{[l]:J(a()??null)}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Ja=(a,t,e,n,s,i,o,[r,c,[l,w,u]],d,E,N,g,A,T,p,O)=>{const[R,v,m,C]=ka(t,d,E,s,A,T,p,O),I=(a,t)=>$(Z(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await m(e,n,a[r],s,i,t,o)})),L=async(a,t)=>w?await m(u,sa,{[na]:a},!0,!0,t):null,_=Ya(a,()=>C(async()=>{await R();const a=await(async()=>j(S(await $(Z(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!k(a[1]))))(),t=await(async()=>l?(await v(u,sa))[na]:{})();return k(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Ka=/^([cd]:)(.+)/,Va=(a,n,s,r,c,l,w,y,u,d,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[p,,O,C]=(a=>{const e=(a=>x(ja,N(a)?{[_a]:a}:a??{}))(a),n=e[Da];if(e.mode==La){const a=e[_a]??t;return[1,n,[a,e[ba]??sa,e[fa]??Ia],ma(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(X(x(xa,r)),0,Y(xa)),l=c[2],w=ma(l),y=ma(l),u=Wa(s,{[Pa]:null,[ha]:sa,[Ga]:i},Pa,a=>_(y,a),a=>Ca(w,a)),d=Wa(o,{[Fa]:null,[ha]:sa,[Ma]:0,[Ua]:0,[Ga]:null},Fa,(a,t)=>_(y,t),(a,t)=>Ca(w,t));var E;return E=(a,t)=>t[4]??=Q(u,t[0])?.[2]??i,D(d,(a,t)=>E(0,a)),[0,n,[u,d,c],w]})(n),S=e+(a=>{let t=2166136261;return R(K.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(J(O)),I=t+"_"+S,L=async(a,e,n="",s="")=>{const i=Oa(t,a,S);return await T(Na+Aa+Ta+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Na+a+"TRIGGER"+t+e+"EXECUTE "+Ta+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):o(Q(O[0],a)?.[2]??i,$a,0==t?"NEW":"OLD"),F=(a,e)=>$(m([ca,la,wa],(n,s)=>b(Aa,Oa(t,"d",S,a,n),`AFTER ${n} ON${pa(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?za:Ja)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${oa} command_tag='${ga}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Oa(t,"c",S),`ON ddl_command_end WHEN TAG IN('${ga}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(m(f(C),async a=>(await T(ga+` IF NOT EXISTS${pa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(I,t=>{return E((e=t,s=Ka,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${v(t,",")}CASCADE`)},w,y,u,O,f(C),async(a,t)=>await a(ia+` table_name tn,column_name cn FROM information_schema.columns ${oa} table_schema='public'AND table_name IN(${Ra(t)})`,t),d,g,"text",void 0,a=>q(a),a=>z(a))},Qa=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return Va(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{Qa as createPostgresPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=globalThis,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,u=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),E=a=>a.length,N=async a=>o.all(a),g=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),$=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),O=a=>0==E(a),R=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),v=a=>a.shift(),C=(a,t)=>a?.has(t)??!1,S=a=>l(a)||0==(a=>a?.size??0)(a),I=a=>[...a?.values()??[]],L=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),b=Object,f=a=>b.getPrototypeOf(a),D=b.entries,h=b.keys,P=b.freeze,F=(a=[])=>b.fromEntries(a),M=(...a)=>b.assign({},...a),U=(a,t)=>(delete a[t],a),G=(a,t)=>p(D(a),([a,e])=>t(e,a)),j=(a,t)=>F(G(a,(a,e)=>[e,t(a,e)])),x=a=>b.values(a),W=a=>E(h(a)),B=a=>(a=>!l(a)&&w(f(a),a=>a==b.prototype||l(f(a)),()=>!0))(a)&&0==W(a),H=JSON.stringify,X=JSON.parse,Y=a=>H(a,(a,t)=>void 0===t?"":t),k=new c.TextEncoder,q=a=>new Map(a),z=(a,t)=>a?.get(t),J=(a,t)=>p([...a?.entries()??[]],([a,e])=>t(e,a)),K=(a,t,e)=>l(e)?(_(a,t),a):a?.set(t,e),V=(a,t,e,n)=>(C(a,t)?n?.(z(a,t)):K(a,t,e()),z(a,t)),Q=(a,t,e,n,s=0)=>w((e?V:z)(a,t[s],s>E(t)-2?e:q),i=>{if(s>E(t)-2)return n?.(i)&&K(a,t[s]),i;const r=Q(i,t,e,n,s+1);return S(i)&&K(a,t[s]),r}),Z="_",aa="_id",ta="SELECT",ea="WHERE",na="TABLE",sa="INSERT",ia="DELETE",ra="UPDATE",oa="ALTER "+na,ca="FROM",la=ia+" "+ca,wa=ta+"*"+ca,ya="CREATE ",ua=ya+na,da="OR REPLACE ",Ea="FUNCTION",Na="$tableName",ga=a=>$(p(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Aa=(...a)=>ga($(a,"_")),Ta=(a,t=[1])=>$(p(a,()=>"$"+t[0]++),n),$a=(a,t=i)=>ea+`(${r(t,Na,ga(a))})`,pa=a=>new Set(u(a)||l(a)?a:[a]),Oa=(a,t)=>a?.add(t),Ra="ColumnName",ma="store",va="json",Ca=ma+"TableName",Sa=ma+"Id"+Ra,Ia=ma+Ra,La="autoLoadIntervalSeconds",_a="rowId"+Ra,ba="tableId",fa="tableName",Da="deleteEmptyColumns",ha="deleteEmptyTable",Pa="condition",Fa={mode:va,[La]:1},Ma={load:0,save:0,[fa]:t+"_values"},Ua=(a,t,e,n,s)=>{const i=q();return j(a,(a,r)=>{const o=d(x(M(t,y(a)?{[e]:a}:a)),0,W(t));l(o[0])||n(r,o[0])||(s(r,o[0]),K(i,r,o))}),i},Ga=/^\d+$/,ja=q(),xa=q(),Wa=(a,t,n,s,i,r,o,c={},y=0,d=[])=>{let N,$,p,O=0,R=0,C=0;V(ja,d,()=>0),V(xa,d,()=>[]);const I=q(),[b,f,D,h,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!B(a)||!B(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!B(a)||!B(t),t.setContent]:g("Store type not supported by this Persister"))(o,a,y),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?v(a):null)??e+t++,t=>{Ga.test(t)&&E(a)<1e3&&m(a,t)}]})(),s=q();return[(n,i,r,o=[],c=()=>[])=>{a??=ta;const l=t(1);return K(s,l,[n,i,r,o,c]),Oa(Q(i,r??[e],pa),l),l},(t,n,...i)=>T(((a,t=[e])=>{const n=[],s=(a,e)=>e==E(t)?m(n,a):null===t[e]?L(a,a=>s(a,e+1)):T([t[e],null],t=>s(z(a,t),e+1));return s(a,0),n})(t,n),t=>L(t,t=>z(s,t)[0](a,...n??[],...i))),a=>w(z(s,a),([,t,i])=>(Q(t,i??[e],void 0,t=>(_(t,a),S(t)?1:0)),K(s,a),n(a),i)),t=>w(z(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=E(r);o==E(e)?t(a,...r,...s(r)):l(e[o])?T(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=O&&(O=a,U(I,void 0,O))},x=t=>{(b&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},W=async a=>(2!=O&&(j(1),R++,await aa(async()=>{await A(async()=>{const e=await t();u(e)?x(e):a?F(a):g("Content is not an array: "+e)},()=>{a&&F(a)}),j(0)})),ta),H=async a=>(X(),await W(a),await A(async()=>$=await s(async(a,t)=>{t||a?2!=O&&(j(1),R++,x(t??a),j(0)):await W()}),r),ta),X=async()=>($&&(await A(()=>i($),r),$=void 0),ta),Y=async a=>(1!=O&&(j(2),C++,await aa(async()=>{await A(()=>n(f,a),r),j(0)})),ta),k=async()=>(J(),await Y(),p=a.addDidFinishTransactionListener(()=>{const a=D();h(a)&&Y(a)}),ta),J=async()=>(p&&(a.delListener(p),p=void 0),ta),Z=async(a=!1)=>{const[t,e]=a?[J,X]:[X,J];return await t(),await e(),ta},aa=async(...a)=>(m(z(xa,d),...a),await(async()=>{if(!z(ja,d)){for(K(ja,d,1);!l(N=v(z(xa,d)));)await A(N,r);K(ja,d,0)}})(),ta),ta={load:W,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!l($),save:Y,startAutoSave:k,stopAutoSave:J,isAutoSaving:()=>!l(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),ta},stopAutoPersisting:Z,getStatus:()=>O,addStatusListener:a=>M(a,I),delListener:t=>(G(t),a),schedule:aa,getStore:()=>a,destroy:()=>(z(xa,d).splice(0,void 0),Z()),getStats:()=>({loads:R,saves:C}),...c};return P(ta)},Ba=(a,t,e,s,r,o=Ha,c,w)=>{const y=q();return[async()=>{y.clear(),p(await e(a,t),({tn:a,cn:t})=>Oa(V(y,a,pa),t))},async(t,e,n)=>((a,t)=>C(z(y,a),t))(t,e)?F(R(p(await a(wa+ga(t)+$a(t,n)),a=>[a[e],w?j(U(a,e),w):U(a,e)]),([a,t])=>!l(a)&&!B(t))):{},async(t,e,s,w,u,d=!1,E=i)=>{const g=pa();j(s??{},a=>p(h(a??{}),a=>Oa(g,a)));const A=I(g);if(!d&&u&&E==i&&O(A)&&C(y,t))return await a("DROP "+na+ga(t)),void K(y,t);const T=z(y,t),v=pa(I(T));if(O(A)||(C(y,t)?await N(p([e,...A],async(n,s)=>{_(v,n)||(await a(oa+ga(t)+"ADD"+ga(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ga(t)+`(${ga(e)})`),Oa(T,n))})):(await a(ua+ga(t)+`(${ga(e)}${r} PRIMARY KEY${$(p(A,a=>n+ga(a)+r))});`),K(y,t,pa([e,...A])))),await N([...!d&&w?p(I(v),async n=>{n!=e&&(await a(oa+ga(t)+"DROP"+ga(n)),_(T,n))}):[]]),d)l(s)?await a(la+ga(t)+$a(t,E)):await N(G(s,async(n,s)=>{l(n)?await a(la+ga(t)+$a(t,E)+`AND(${ga(e)}=$1)`,[s]):O(A)||await o(a,t,e,h(n),{[s]:c?p(x(n),c):x(n)},T)}));else if(O(A))C(y,t)&&await a(la+ga(t)+$a(t,E));else{const n=R(I(z(y,t)),a=>a!=e),i={},r=[];j(s??{},(a,t)=>{i[t]=p(n,t=>c?c(a?.[t]):a?.[t]),m(r,t)}),await o(a,t,e,n,i),await a(la+ga(t)+$a(t,E)+`AND${ga(e)}NOT IN(${Ta(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},Ha=async(a,t,e,s,i)=>{const r=[1];await a(sa+" INTO"+ga(t)+"("+((...a)=>$(p(a,ga),n))(e,...s)+")VALUES"+$(G(i,a=>"($"+r[0]+++","+Ta(a,r)+")"),n)+"ON CONFLICT("+ga(e)+`)DO ${ra} SET`+$(p(s,a=>ga(a)+"=excluded."+ga(a)),n),G(i,(a,t)=>[t,...p(a,a=>a??null)]).flat())},Xa=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=Ba(t,w,y,s,E,N),p=Wa(a,()=>$(async()=>{return await g(),a=(await A(o,c))[Z]?.[l]??"null",X(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(o,c,{[Z]:{[l]:Y(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Ya=(a,t,e,n,s,i,r,[o,c,[w,y,u]],d,E,g,A,T,$,p,O)=>{const[m,v,C,S]=Ba(t,d,E,s,T,$,p,O),I=(a,t)=>N(J(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),L=async(a,t)=>y?await C(u,aa,{[Z]:a},!0,!0,t):null,_=Wa(a,()=>S(async()=>{await m();const a=await(async()=>F(R(await N(J(o,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!B(a[1]))))(),t=await(async()=>w?(await v(u,aa))[Z]:{})();return B(a)&&l(t)?void 0:[a,t]}),(a,t)=>S(async()=>{if(await m(),l(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}),e,n,s,r,{[A]:()=>g,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,g);return _},ka=/^([cd]:)(.+)/,qa=(a,n,s,o,c,l,u,E,g,A,O="getDb")=>{const R=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[m,,v,S]=(a=>{const e=(a=>M(Fa,y(a)?{[Ca]:a}:a??{}))(a),n=e[La];if(e.mode==va){const a=e[Ca]??t;return[1,n,[a,e[Sa]??aa,e[Ia]??ma],pa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(x(M(Ma,o)),0,W(Ma)),l=c[2],w=pa(l),u=pa(l),E=Ua(s,{[ba]:null,[_a]:aa,[Pa]:i},ba,a=>C(u,a),a=>Oa(w,a)),N=Ua(r,{[fa]:null,[_a]:aa,[Da]:0,[ha]:0,[Pa]:null},fa,(a,t)=>C(u,t),(a,t)=>Oa(w,t));var g;return g=(a,t)=>t[4]??=z(E,t[0])?.[2]??i,L(N,(a,t)=>g(0,a)),[0,n,[E,N,c],w]})(n),_=e+(a=>{let t=2166136261;return T(k.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(Y(v)),b=t+"_"+_,f=async(a,e,n="",s="")=>{const i=Aa(t,a,_);return await R(ya+da+Ea+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},D=async(a,t,e,n)=>(await R(ya+a+"TRIGGER"+t+e+"EXECUTE "+Ea+n+"()"),t),h=a=>`PERFORM pg_notify('${b}',${a});`,P=(a,t)=>m?i:2===t?P(a,0)+" OR "+P(a,1):r(z(v[0],a)?.[2]??i,Na,0==t?"NEW":"OLD"),F=(a,e)=>N(p([sa,ia,ra],(n,s)=>D(da,Aa(t,"d",_,a,n),`AFTER ${n} ON${ga(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(m?Xa:Ya)(a,R,async a=>{const e=await f("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ea} command_tag='${ua}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await D("EVENT ",Aa(t,"c",_),`ON ddl_command_end WHEN TAG IN('${ua}')`,e);const n=await f("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await N(p(I(S),async a=>(await R(ua+` IF NOT EXISTS${ga(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await o(b,t=>{return w((e=t,s=ka,e?.match(s)),async([,t,e])=>{C(S,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await R(`DROP FUNCTION IF EXISTS${$(t,",")}CASCADE`)},u,E,g,v,I(S),async(a,t)=>await a(ta+` table_name tn,column_name cn FROM information_schema.columns ${ea} table_schema='public'AND table_name IN(${Ta(t)})`,t),A,O,"text",void 0,a=>H(a),a=>X(a))},za=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return qa(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>A(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{za as createPostgresPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=async a=>r.all(a),p=a=>{throw Error(a)},O=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),m=(a,t)=>a.map(t),C=a=>0==T(a),S=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),L=a=>a.shift(),_=(a,t)=>a?.has(t)??!1,b=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),P=Object,F=a=>P.getPrototypeOf(a),M=P.entries,U=P.keys,G=P.freeze,j=(a=[])=>P.fromEntries(a),x=(...a)=>P.assign({},...a),W=(a,t)=>(delete a[t],a),B=(a,t)=>m(M(a),([a,e])=>t(e,a)),H=(a,t)=>j(B(a,(a,e)=>[e,t(a,e)])),X=a=>P.values(a),Y=a=>T(U(a)),k=a=>(a=>!w(a)&&d(F(a),a=>a==P.prototype||w(F(a)),()=>!0))(a)&&0==Y(a),q=JSON.stringify,z=JSON.parse,J=a=>q(a,(a,t)=>void 0===t?"":t),K=new l.TextEncoder,V=a=>new Map(a),Q=(a,t)=>a?.get(t),Z=(a,t)=>m([...a?.entries()??[]],([a,e])=>t(e,a)),aa=(a,t,e)=>void 0===e?(h(a,t),a):a?.set(t,e),ta=(a,t,e,n)=>(_(a,t)?n?.(Q(a,t)):aa(a,t,e()),Q(a,t)),ea=(a,t,e,n,s=0)=>E((e?ta:Q)(a,t[s],s>T(t)-2?e:V),i=>{if(s>T(t)-2)return n?.(i)&&aa(a,t[s]),i;const o=ea(i,t,e,n,s+1);return b(i)&&aa(a,t[s]),o}),na="_",sa="_id",ia="SELECT",oa="WHERE",ra="TABLE",ca="INSERT",la="DELETE",wa="UPDATE",ya="ALTER "+ra,ua="FROM",da=la+" "+ua,Ea=ia+"*"+ua,Na="CREATE ",ga=Na+ra,Aa="OR REPLACE ",Ta="FUNCTION",$a="$tableName",pa=a=>v(m(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Oa=(...a)=>pa(v(a,"_")),Ra=(a,t=[1])=>v(m(a,()=>"$"+t[0]++),n),va=(a,t=i)=>oa+`(${o(t,$a,pa(a))})`,ma=a=>new Set(g(a)||y(a)?a:[a]),Ca=(a,t)=>a?.add(t),Sa="ColumnName",Ia="store",La="json",_a=Ia+"TableName",ba=Ia+"Id"+Sa,fa=Ia+Sa,Da="autoLoadIntervalSeconds",ha="rowId"+Sa,Pa="tableId",Fa="tableName",Ma="deleteEmptyColumns",Ua="deleteEmptyTable",Ga="condition",ja={mode:La,[Da]:1},xa={load:0,save:0,[Fa]:t+"_values"},Wa=(a,t,e,n,s)=>{const i=V();return H(a,(a,o)=>{const r=A(X(x(t,N(a)?{[e]:a}:a)),0,Y(t));u(r[0])||n(o,r[0])||(s(o,r[0]),aa(i,o,r))}),i},Ba=/^\d+$/,Ha=V(),Xa=V(),Ya=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,N,A,$=0,v=0,m=0;ta(Ha,w,()=>0),ta(Xa,w,()=>[]);const C=V(),[S,_,f,P,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:p("Store type not supported by this Persister"))(r,a,l),[M,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?L(a):null)??e+t++,t=>{Ba.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=V();return[(n,i,o,r=[],c=()=>[])=>{a??=Z;const l=t(1);return aa(s,l,[n,i,o,r,c]),Ca(ea(i,o??[e],ma),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?I(n,a):null===t[e]?D(a,a=>s(a,e+1)):R([t[e],null],t=>s(Q(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>Q(s,t)[0](a,...n??[],...i))),a=>E(Q(s,a),([,t,i])=>(ea(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),aa(s,a),n(a),i)),t=>E(Q(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):u(e[r])?R(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(S&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(x(1),v++,await K(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?F(a):p("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),Z),H=async a=>(X(),await B(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),v++,W(t??a),x(0)):await B()}),o),Z),X=async()=>(N&&(await O(()=>i(N),o),N=void 0),Z),Y=async a=>(1!=$&&(x(2),m++,await K(async()=>{await O(()=>n(_,a),o),x(0)})),Z),q=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&Y(a)}),Z),z=async()=>(A&&(a.delListener(A),A=void 0),Z),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),Z},K=async(...a)=>(I(Q(Xa,w),...a),await(async()=>{if(!Q(Ha,w)){for(aa(Ha,w,1);!y(d=L(Q(Xa,w)));)await O(d,o);aa(Ha,w,0)}})(),Z),Z={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,H]:[H,q];return await e(a),await n(a),Z},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(Q(Xa,w).splice(0,void 0),J()),getStats:()=>({loads:v,saves:m}),...c};return G(Z)},ka=(a,t,e,s,o,r=qa,c,l)=>{const w=V();return[async()=>{w.clear(),m(await e(a,t),({tn:a,cn:t})=>Ca(ta(w,a,ma),t))},async(t,e,n)=>((a,t)=>_(Q(w,a),t))(t,e)?j(S(m(await a(Ea+pa(t)+va(t,n)),a=>[a[e],l?H(W(a,e),l):W(a,e)]),([a,t])=>!y(a)&&!k(t))):{},async(t,e,s,l,u,d=!1,E=i)=>{const N=ma();H(s??{},a=>m(U(a??{}),a=>Ca(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+ra+pa(t)),void aa(w,t);const A=Q(w,t),T=ma(f(A));if(C(g)||(_(w,t)?await $(m([e,...g],async(n,s)=>{h(T,n)||(await a(ya+pa(t)+"ADD"+pa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+pa(t)+`(${pa(e)})`),Ca(A,n))})):(await a(ga+pa(t)+`(${pa(e)}${o} PRIMARY KEY${v(m(g,a=>n+pa(a)+o))});`),aa(w,t,ma([e,...g])))),await $([...!d&&l?m(f(T),async n=>{n!=e&&(await a(ya+pa(t)+"DROP"+pa(n)),h(A,n))}):[]]),d)y(s)?await a(da+pa(t)+va(t,E)):await $(B(s,async(n,s)=>{y(n)?await a(da+pa(t)+va(t,E)+`AND(${pa(e)}=$1)`,[s]):C(g)||await r(a,t,e,U(n),{[s]:c?m(X(n),c):X(n)},A)}));else if(C(g))_(w,t)&&await a(da+pa(t)+va(t,E));else{const n=S(f(Q(w,t)),a=>a!=e),i={},o=[];H(s??{},(a,t)=>{i[t]=m(n,t=>c?c(a?.[t]):a?.[t]),I(o,t)}),await r(a,t,e,n,i),await a(da+pa(t)+va(t,E)+`AND${pa(e)}NOT IN(${Ra(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},qa=async(a,t,e,s,i)=>{const o=[1];await a(ca+" INTO"+pa(t)+"("+((...a)=>v(m(a,pa),n))(e,...s)+")VALUES"+v(B(i,a=>"($"+o[0]+++","+Ra(a,o)+")"),n)+"ON CONFLICT("+pa(e)+`)DO ${wa} SET`+v(m(s,a=>pa(a)+"=excluded."+pa(a)),n),B(i,(a,t)=>[t,...m(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=ka(t,w,y,s,E,N),p=Ya(a,()=>$(async()=>{return await g(),a=(await A(r,c))[na]?.[l]??"null",z(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(r,c,{[na]:{[l]:J(a()??null)}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Ja=(a,t,e,n,s,i,o,[r,c,[l,w,u]],d,E,N,g,A,T,p,O)=>{const[R,v,m,C]=ka(t,d,E,s,A,T,p,O),I=(a,t)=>$(Z(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await m(e,n,a[r],s,i,t,o)})),L=async(a,t)=>w?await m(u,sa,{[na]:a},!0,!0,t):null,_=Ya(a,()=>C(async()=>{await R();const a=await(async()=>j(S(await $(Z(r,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!k(a[1]))))(),t=await(async()=>l?(await v(u,sa))[na]:{})();return k(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Ka=/^([cd]:)(.+)/,Va=(a,n,s,r,c,l,w,y,u,d,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[p,,O,C]=(a=>{const e=(a=>x(ja,N(a)?{[_a]:a}:a??{}))(a),n=e[Da];if(e.mode==La){const a=e[_a]??t;return[1,n,[a,e[ba]??sa,e[fa]??Ia],ma(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(X(x(xa,r)),0,Y(xa)),l=c[2],w=ma(l),y=ma(l),u=Wa(s,{[Pa]:null,[ha]:sa,[Ga]:i},Pa,a=>_(y,a),a=>Ca(w,a)),d=Wa(o,{[Fa]:null,[ha]:sa,[Ma]:0,[Ua]:0,[Ga]:null},Fa,(a,t)=>_(y,t),(a,t)=>Ca(w,t));var E;return E=(a,t)=>t[4]??=Q(u,t[0])?.[2]??i,D(d,(a,t)=>E(0,a)),[0,n,[u,d,c],w]})(n),S=e+(a=>{let t=2166136261;return R(K.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(J(O)),I=t+"_"+S,L=async(a,e,n="",s="")=>{const i=Oa(t,a,S);return await T(Na+Aa+Ta+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Na+a+"TRIGGER"+t+e+"EXECUTE "+Ta+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):o(Q(O[0],a)?.[2]??i,$a,0==t?"NEW":"OLD"),F=(a,e)=>$(m([ca,la,wa],(n,s)=>b(Aa,Oa(t,"d",S,a,n),`AFTER ${n} ON${pa(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?za:Ja)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${oa} command_tag='${ga}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Oa(t,"c",S),`ON ddl_command_end WHEN TAG IN('${ga}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(m(f(C),async a=>(await T(ga+` IF NOT EXISTS${pa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(I,t=>{return E((e=t,s=Ka,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${v(t,",")}CASCADE`)},w,y,u,O,f(C),async(a,t)=>await a(ia+` table_name tn,column_name cn FROM information_schema.columns ${oa} table_schema='public'AND table_name IN(${Ra(t)})`,t),d,g,"text",void 0,a=>q(a),a=>z(a))},Qa=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return Va(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{Qa as createPostgresPersister};