tinybase 5.2.0-beta.4 → 5.2.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 (511) hide show
  1. package/@types/mergeable-store/index.d.cts +114 -11
  2. package/@types/mergeable-store/index.d.ts +114 -11
  3. package/@types/mergeable-store/with-schemas/index.d.cts +192 -11
  4. package/@types/mergeable-store/with-schemas/index.d.ts +192 -11
  5. package/@types/persisters/index.d.cts +177 -16
  6. package/@types/persisters/index.d.ts +177 -16
  7. package/@types/persisters/persister-cr-sqlite-wasm/index.d.cts +1 -1
  8. package/@types/persisters/persister-cr-sqlite-wasm/index.d.ts +1 -1
  9. package/@types/persisters/persister-cr-sqlite-wasm/with-schemas/index.d.cts +2 -2
  10. package/@types/persisters/persister-cr-sqlite-wasm/with-schemas/index.d.ts +2 -2
  11. package/@types/persisters/persister-electric-sql/index.d.cts +1 -1
  12. package/@types/persisters/persister-electric-sql/index.d.ts +1 -1
  13. package/@types/persisters/persister-electric-sql/with-schemas/index.d.cts +2 -2
  14. package/@types/persisters/persister-electric-sql/with-schemas/index.d.ts +2 -2
  15. package/@types/persisters/persister-expo-sqlite/index.d.cts +1 -1
  16. package/@types/persisters/persister-expo-sqlite/index.d.ts +1 -1
  17. package/@types/persisters/persister-expo-sqlite/with-schemas/index.d.cts +2 -2
  18. package/@types/persisters/persister-expo-sqlite/with-schemas/index.d.ts +2 -2
  19. package/@types/persisters/persister-libsql/index.d.cts +1 -1
  20. package/@types/persisters/persister-libsql/index.d.ts +1 -1
  21. package/@types/persisters/persister-libsql/with-schemas/index.d.cts +2 -2
  22. package/@types/persisters/persister-libsql/with-schemas/index.d.ts +2 -2
  23. package/@types/persisters/persister-pglite/index.d.cts +1 -1
  24. package/@types/persisters/persister-pglite/index.d.ts +1 -1
  25. package/@types/persisters/persister-pglite/with-schemas/index.d.cts +2 -2
  26. package/@types/persisters/persister-pglite/with-schemas/index.d.ts +2 -2
  27. package/@types/persisters/persister-postgres/index.d.cts +1 -1
  28. package/@types/persisters/persister-postgres/index.d.ts +1 -1
  29. package/@types/persisters/persister-postgres/with-schemas/index.d.cts +2 -2
  30. package/@types/persisters/persister-postgres/with-schemas/index.d.ts +2 -2
  31. package/@types/persisters/persister-powersync/index.d.cts +1 -1
  32. package/@types/persisters/persister-powersync/index.d.ts +1 -1
  33. package/@types/persisters/persister-powersync/with-schemas/index.d.cts +2 -2
  34. package/@types/persisters/persister-powersync/with-schemas/index.d.ts +2 -2
  35. package/@types/persisters/persister-sqlite-wasm/index.d.cts +1 -1
  36. package/@types/persisters/persister-sqlite-wasm/index.d.ts +1 -1
  37. package/@types/persisters/persister-sqlite-wasm/with-schemas/index.d.cts +2 -2
  38. package/@types/persisters/persister-sqlite-wasm/with-schemas/index.d.ts +2 -2
  39. package/@types/persisters/persister-sqlite3/index.d.cts +1 -1
  40. package/@types/persisters/persister-sqlite3/index.d.ts +1 -1
  41. package/@types/persisters/persister-sqlite3/with-schemas/index.d.cts +2 -2
  42. package/@types/persisters/persister-sqlite3/with-schemas/index.d.ts +2 -2
  43. package/@types/persisters/with-schemas/index.d.cts +227 -19
  44. package/@types/persisters/with-schemas/index.d.ts +227 -19
  45. package/@types/synchronizers/index.d.cts +2 -5
  46. package/@types/synchronizers/index.d.ts +2 -5
  47. package/@types/synchronizers/synchronizer-ws-server/index.d.cts +7 -7
  48. package/@types/synchronizers/synchronizer-ws-server/index.d.ts +7 -7
  49. package/@types/synchronizers/synchronizer-ws-server/with-schemas/index.d.cts +7 -7
  50. package/@types/synchronizers/synchronizer-ws-server/with-schemas/index.d.ts +7 -7
  51. package/@types/synchronizers/with-schemas/index.d.cts +2 -5
  52. package/@types/synchronizers/with-schemas/index.d.ts +2 -5
  53. package/cjs/es6/index.cjs +54 -566
  54. package/cjs/es6/mergeable-store/index.cjs +9 -6
  55. package/cjs/es6/mergeable-store/with-schemas/index.cjs +9 -6
  56. package/cjs/es6/min/index.cjs +1 -1
  57. package/cjs/es6/min/index.cjs.gz +0 -0
  58. package/cjs/es6/min/persisters/index.cjs +1 -1
  59. package/cjs/es6/min/persisters/index.cjs.gz +0 -0
  60. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  61. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  62. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  63. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  64. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs +1 -1
  65. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  66. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  67. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  68. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  69. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  70. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  71. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  72. package/cjs/es6/min/persisters/persister-libsql/index.cjs +1 -1
  73. package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
  74. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  75. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  76. package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
  77. package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
  78. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  79. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  80. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  81. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  82. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  83. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  84. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
  85. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  86. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  87. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  88. package/cjs/es6/min/persisters/with-schemas/index.cjs +1 -1
  89. package/cjs/es6/min/persisters/with-schemas/index.cjs.gz +0 -0
  90. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  91. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  92. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  93. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  94. package/cjs/es6/min/with-schemas/index.cjs +1 -1
  95. package/cjs/es6/min/with-schemas/index.cjs.gz +0 -0
  96. package/cjs/es6/persisters/index.cjs +1095 -10
  97. package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +58 -49
  98. package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +58 -49
  99. package/cjs/es6/persisters/persister-electric-sql/index.cjs +56 -47
  100. package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +56 -47
  101. package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +58 -49
  102. package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +58 -49
  103. package/cjs/es6/persisters/persister-indexed-db/index.cjs +2 -2
  104. package/cjs/es6/persisters/persister-indexed-db/with-schemas/index.cjs +2 -2
  105. package/cjs/es6/persisters/persister-libsql/index.cjs +56 -47
  106. package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +56 -47
  107. package/cjs/es6/persisters/persister-pglite/index.cjs +61 -54
  108. package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +61 -54
  109. package/cjs/es6/persisters/persister-postgres/index.cjs +63 -56
  110. package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +63 -56
  111. package/cjs/es6/persisters/persister-powersync/index.cjs +58 -49
  112. package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +58 -49
  113. package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +62 -49
  114. package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +62 -49
  115. package/cjs/es6/persisters/persister-sqlite3/index.cjs +58 -49
  116. package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +58 -49
  117. package/cjs/es6/persisters/with-schemas/index.cjs +1095 -10
  118. package/cjs/es6/synchronizers/index.cjs +9 -6
  119. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/index.cjs +9 -6
  120. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +9 -6
  121. package/cjs/es6/synchronizers/synchronizer-local/index.cjs +9 -6
  122. package/cjs/es6/synchronizers/synchronizer-local/with-schemas/index.cjs +9 -6
  123. package/cjs/es6/synchronizers/synchronizer-ws-client/index.cjs +9 -6
  124. package/cjs/es6/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +9 -6
  125. package/cjs/es6/synchronizers/synchronizer-ws-server/index.cjs +17 -14
  126. package/cjs/es6/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +17 -14
  127. package/cjs/es6/synchronizers/with-schemas/index.cjs +9 -6
  128. package/cjs/es6/with-schemas/index.cjs +54 -566
  129. package/cjs/index.cjs +45 -447
  130. package/cjs/mergeable-store/index.cjs +1 -0
  131. package/cjs/mergeable-store/with-schemas/index.cjs +1 -0
  132. package/cjs/min/index.cjs +1 -1
  133. package/cjs/min/index.cjs.gz +0 -0
  134. package/cjs/min/persisters/index.cjs +1 -1
  135. package/cjs/min/persisters/index.cjs.gz +0 -0
  136. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  137. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  138. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  139. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  140. package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
  141. package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  142. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  143. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  144. package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  145. package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  146. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  147. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  148. package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
  149. package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
  150. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  151. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  152. package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
  153. package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
  154. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  155. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  156. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  157. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  158. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  159. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  160. package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
  161. package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  162. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  163. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  164. package/cjs/min/persisters/with-schemas/index.cjs +1 -1
  165. package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
  166. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  167. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  168. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  169. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  170. package/cjs/min/with-schemas/index.cjs +1 -1
  171. package/cjs/min/with-schemas/index.cjs.gz +0 -0
  172. package/cjs/persisters/index.cjs +833 -0
  173. package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +57 -48
  174. package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +57 -48
  175. package/cjs/persisters/persister-electric-sql/index.cjs +56 -47
  176. package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +56 -47
  177. package/cjs/persisters/persister-expo-sqlite/index.cjs +57 -48
  178. package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +57 -48
  179. package/cjs/persisters/persister-indexed-db/index.cjs +2 -2
  180. package/cjs/persisters/persister-indexed-db/with-schemas/index.cjs +2 -2
  181. package/cjs/persisters/persister-libsql/index.cjs +56 -47
  182. package/cjs/persisters/persister-libsql/with-schemas/index.cjs +56 -47
  183. package/cjs/persisters/persister-pglite/index.cjs +59 -52
  184. package/cjs/persisters/persister-pglite/with-schemas/index.cjs +59 -52
  185. package/cjs/persisters/persister-postgres/index.cjs +61 -54
  186. package/cjs/persisters/persister-postgres/with-schemas/index.cjs +61 -54
  187. package/cjs/persisters/persister-powersync/index.cjs +60 -49
  188. package/cjs/persisters/persister-powersync/with-schemas/index.cjs +60 -49
  189. package/cjs/persisters/persister-sqlite-wasm/index.cjs +58 -49
  190. package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +58 -49
  191. package/cjs/persisters/persister-sqlite3/index.cjs +58 -49
  192. package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +58 -49
  193. package/cjs/persisters/with-schemas/index.cjs +833 -0
  194. package/cjs/synchronizers/index.cjs +1 -0
  195. package/cjs/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -0
  196. package/cjs/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -0
  197. package/cjs/synchronizers/synchronizer-local/index.cjs +1 -0
  198. package/cjs/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -0
  199. package/cjs/synchronizers/synchronizer-ws-client/index.cjs +1 -0
  200. package/cjs/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -0
  201. package/cjs/synchronizers/synchronizer-ws-server/index.cjs +9 -8
  202. package/cjs/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +9 -8
  203. package/cjs/synchronizers/with-schemas/index.cjs +1 -0
  204. package/cjs/with-schemas/index.cjs +45 -447
  205. package/es6/index.js +54 -566
  206. package/es6/mergeable-store/index.js +9 -6
  207. package/es6/mergeable-store/with-schemas/index.js +9 -6
  208. package/es6/min/index.js +1 -1
  209. package/es6/min/index.js.gz +0 -0
  210. package/es6/min/persisters/index.js +1 -1
  211. package/es6/min/persisters/index.js.gz +0 -0
  212. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  213. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  214. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  215. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  216. package/es6/min/persisters/persister-electric-sql/index.js +1 -1
  217. package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  218. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  219. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  220. package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  221. package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  222. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  223. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  224. package/es6/min/persisters/persister-libsql/index.js +1 -1
  225. package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  226. package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  227. package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  228. package/es6/min/persisters/persister-powersync/index.js +1 -1
  229. package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  230. package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  231. package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  232. package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  233. package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  234. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  235. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  236. package/es6/min/persisters/persister-sqlite3/index.js +1 -1
  237. package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  238. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  239. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  240. package/es6/min/persisters/with-schemas/index.js +1 -1
  241. package/es6/min/persisters/with-schemas/index.js.gz +0 -0
  242. package/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  243. package/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  244. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  245. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  246. package/es6/min/with-schemas/index.js +1 -1
  247. package/es6/min/with-schemas/index.js.gz +0 -0
  248. package/es6/persisters/index.js +1099 -11
  249. package/es6/persisters/persister-cr-sqlite-wasm/index.js +58 -49
  250. package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +58 -49
  251. package/es6/persisters/persister-electric-sql/index.js +56 -47
  252. package/es6/persisters/persister-electric-sql/with-schemas/index.js +56 -47
  253. package/es6/persisters/persister-expo-sqlite/index.js +58 -49
  254. package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +58 -49
  255. package/es6/persisters/persister-indexed-db/index.js +2 -2
  256. package/es6/persisters/persister-indexed-db/with-schemas/index.js +2 -2
  257. package/es6/persisters/persister-libsql/index.js +56 -47
  258. package/es6/persisters/persister-libsql/with-schemas/index.js +56 -47
  259. package/es6/persisters/persister-pglite/index.js +61 -54
  260. package/es6/persisters/persister-pglite/with-schemas/index.js +61 -54
  261. package/es6/persisters/persister-postgres/index.js +63 -56
  262. package/es6/persisters/persister-postgres/with-schemas/index.js +63 -56
  263. package/es6/persisters/persister-powersync/index.js +58 -49
  264. package/es6/persisters/persister-powersync/with-schemas/index.js +58 -49
  265. package/es6/persisters/persister-sqlite-wasm/index.js +62 -49
  266. package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +62 -49
  267. package/es6/persisters/persister-sqlite3/index.js +58 -49
  268. package/es6/persisters/persister-sqlite3/with-schemas/index.js +58 -49
  269. package/es6/persisters/with-schemas/index.js +1099 -11
  270. package/es6/synchronizers/index.js +9 -6
  271. package/es6/synchronizers/synchronizer-broadcast-channel/index.js +9 -6
  272. package/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +9 -6
  273. package/es6/synchronizers/synchronizer-local/index.js +9 -6
  274. package/es6/synchronizers/synchronizer-local/with-schemas/index.js +9 -6
  275. package/es6/synchronizers/synchronizer-ws-client/index.js +9 -6
  276. package/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +9 -6
  277. package/es6/synchronizers/synchronizer-ws-server/index.js +17 -14
  278. package/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +17 -14
  279. package/es6/synchronizers/with-schemas/index.js +9 -6
  280. package/es6/with-schemas/index.js +54 -566
  281. package/index.js +45 -447
  282. package/mergeable-store/index.js +1 -0
  283. package/mergeable-store/with-schemas/index.js +1 -0
  284. package/min/index.js +1 -1
  285. package/min/index.js.gz +0 -0
  286. package/min/persisters/index.js +1 -1
  287. package/min/persisters/index.js.gz +0 -0
  288. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  289. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  290. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  291. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  292. package/min/persisters/persister-electric-sql/index.js +1 -1
  293. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  294. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  295. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  296. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  297. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  298. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  299. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  300. package/min/persisters/persister-libsql/index.js +1 -1
  301. package/min/persisters/persister-libsql/index.js.gz +0 -0
  302. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  303. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  304. package/min/persisters/persister-powersync/index.js +1 -1
  305. package/min/persisters/persister-powersync/index.js.gz +0 -0
  306. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  307. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  308. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  309. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  310. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  311. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  312. package/min/persisters/persister-sqlite3/index.js +1 -1
  313. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  314. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  315. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  316. package/min/persisters/with-schemas/index.js +1 -1
  317. package/min/persisters/with-schemas/index.js.gz +0 -0
  318. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  319. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  320. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  321. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  322. package/min/with-schemas/index.js +1 -1
  323. package/min/with-schemas/index.js.gz +0 -0
  324. package/package.json +212 -212
  325. package/persisters/index.js +837 -1
  326. package/persisters/persister-cr-sqlite-wasm/index.js +57 -48
  327. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +57 -48
  328. package/persisters/persister-electric-sql/index.js +56 -47
  329. package/persisters/persister-electric-sql/with-schemas/index.js +56 -47
  330. package/persisters/persister-expo-sqlite/index.js +57 -48
  331. package/persisters/persister-expo-sqlite/with-schemas/index.js +57 -48
  332. package/persisters/persister-indexed-db/index.js +2 -2
  333. package/persisters/persister-indexed-db/with-schemas/index.js +2 -2
  334. package/persisters/persister-libsql/index.js +56 -47
  335. package/persisters/persister-libsql/with-schemas/index.js +56 -47
  336. package/persisters/persister-pglite/index.js +59 -52
  337. package/persisters/persister-pglite/with-schemas/index.js +59 -52
  338. package/persisters/persister-postgres/index.js +61 -54
  339. package/persisters/persister-postgres/with-schemas/index.js +61 -54
  340. package/persisters/persister-powersync/index.js +60 -49
  341. package/persisters/persister-powersync/with-schemas/index.js +60 -49
  342. package/persisters/persister-sqlite-wasm/index.js +58 -49
  343. package/persisters/persister-sqlite-wasm/with-schemas/index.js +58 -49
  344. package/persisters/persister-sqlite3/index.js +58 -49
  345. package/persisters/persister-sqlite3/with-schemas/index.js +58 -49
  346. package/persisters/with-schemas/index.js +837 -1
  347. package/readme.md +14 -14
  348. package/releases.md +27 -23
  349. package/synchronizers/index.js +1 -0
  350. package/synchronizers/synchronizer-broadcast-channel/index.js +1 -0
  351. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -0
  352. package/synchronizers/synchronizer-local/index.js +1 -0
  353. package/synchronizers/synchronizer-local/with-schemas/index.js +1 -0
  354. package/synchronizers/synchronizer-ws-client/index.js +1 -0
  355. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -0
  356. package/synchronizers/synchronizer-ws-server/index.js +9 -8
  357. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +9 -8
  358. package/synchronizers/with-schemas/index.js +1 -0
  359. package/umd/es6/index.js +54 -577
  360. package/umd/es6/mergeable-store/index.js +9 -6
  361. package/umd/es6/mergeable-store/with-schemas/index.js +9 -6
  362. package/umd/es6/min/index.js +1 -1
  363. package/umd/es6/min/index.js.gz +0 -0
  364. package/umd/es6/min/persisters/index.js +1 -1
  365. package/umd/es6/min/persisters/index.js.gz +0 -0
  366. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  367. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  368. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  369. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  370. package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
  371. package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  372. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  373. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  374. package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  375. package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  376. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  377. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  378. package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
  379. package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  380. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  381. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  382. package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
  383. package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  384. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  385. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  386. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  387. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  388. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  389. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  390. package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
  391. package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  392. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  393. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  394. package/umd/es6/min/persisters/with-schemas/index.js +1 -1
  395. package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
  396. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  397. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  398. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  399. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  400. package/umd/es6/min/with-schemas/index.js +1 -1
  401. package/umd/es6/min/with-schemas/index.js.gz +0 -0
  402. package/umd/es6/persisters/index.js +1106 -10
  403. package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +58 -49
  404. package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +58 -49
  405. package/umd/es6/persisters/persister-electric-sql/index.js +56 -47
  406. package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +56 -47
  407. package/umd/es6/persisters/persister-expo-sqlite/index.js +58 -49
  408. package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +58 -49
  409. package/umd/es6/persisters/persister-indexed-db/index.js +2 -2
  410. package/umd/es6/persisters/persister-indexed-db/with-schemas/index.js +2 -2
  411. package/umd/es6/persisters/persister-libsql/index.js +56 -47
  412. package/umd/es6/persisters/persister-libsql/with-schemas/index.js +56 -47
  413. package/umd/es6/persisters/persister-pglite/index.js +61 -54
  414. package/umd/es6/persisters/persister-pglite/with-schemas/index.js +61 -54
  415. package/umd/es6/persisters/persister-postgres/index.js +66 -56
  416. package/umd/es6/persisters/persister-postgres/with-schemas/index.js +66 -56
  417. package/umd/es6/persisters/persister-powersync/index.js +58 -49
  418. package/umd/es6/persisters/persister-powersync/with-schemas/index.js +58 -49
  419. package/umd/es6/persisters/persister-sqlite-wasm/index.js +58 -49
  420. package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +58 -49
  421. package/umd/es6/persisters/persister-sqlite3/index.js +58 -49
  422. package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +58 -49
  423. package/umd/es6/persisters/with-schemas/index.js +1106 -10
  424. package/umd/es6/synchronizers/index.js +9 -6
  425. package/umd/es6/synchronizers/synchronizer-broadcast-channel/index.js +9 -6
  426. package/umd/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +9 -6
  427. package/umd/es6/synchronizers/synchronizer-local/index.js +9 -6
  428. package/umd/es6/synchronizers/synchronizer-local/with-schemas/index.js +9 -6
  429. package/umd/es6/synchronizers/synchronizer-ws-client/index.js +9 -6
  430. package/umd/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +9 -6
  431. package/umd/es6/synchronizers/synchronizer-ws-server/index.js +17 -14
  432. package/umd/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +17 -14
  433. package/umd/es6/synchronizers/with-schemas/index.js +9 -6
  434. package/umd/es6/with-schemas/index.js +54 -577
  435. package/umd/index.js +45 -454
  436. package/umd/mergeable-store/index.js +1 -0
  437. package/umd/mergeable-store/with-schemas/index.js +1 -0
  438. package/umd/min/index.js +1 -1
  439. package/umd/min/index.js.gz +0 -0
  440. package/umd/min/persisters/index.js +1 -1
  441. package/umd/min/persisters/index.js.gz +0 -0
  442. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  443. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  444. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  445. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  446. package/umd/min/persisters/persister-electric-sql/index.js +1 -1
  447. package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
  448. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  449. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  450. package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
  451. package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  452. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  453. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  454. package/umd/min/persisters/persister-libsql/index.js +1 -1
  455. package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
  456. package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  457. package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  458. package/umd/min/persisters/persister-powersync/index.js +1 -1
  459. package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
  460. package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  461. package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  462. package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
  463. package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  464. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  465. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  466. package/umd/min/persisters/persister-sqlite3/index.js +1 -1
  467. package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
  468. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  469. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  470. package/umd/min/persisters/with-schemas/index.js +1 -1
  471. package/umd/min/persisters/with-schemas/index.js.gz +0 -0
  472. package/umd/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  473. package/umd/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  474. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  475. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  476. package/umd/min/with-schemas/index.js +1 -1
  477. package/umd/min/with-schemas/index.js.gz +0 -0
  478. package/umd/persisters/index.js +835 -0
  479. package/umd/persisters/persister-cr-sqlite-wasm/index.js +57 -48
  480. package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +57 -48
  481. package/umd/persisters/persister-electric-sql/index.js +56 -47
  482. package/umd/persisters/persister-electric-sql/with-schemas/index.js +56 -47
  483. package/umd/persisters/persister-expo-sqlite/index.js +57 -48
  484. package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +57 -48
  485. package/umd/persisters/persister-indexed-db/index.js +2 -2
  486. package/umd/persisters/persister-indexed-db/with-schemas/index.js +2 -2
  487. package/umd/persisters/persister-libsql/index.js +56 -47
  488. package/umd/persisters/persister-libsql/with-schemas/index.js +56 -47
  489. package/umd/persisters/persister-pglite/index.js +59 -52
  490. package/umd/persisters/persister-pglite/with-schemas/index.js +59 -52
  491. package/umd/persisters/persister-postgres/index.js +61 -54
  492. package/umd/persisters/persister-postgres/with-schemas/index.js +61 -54
  493. package/umd/persisters/persister-powersync/index.js +58 -49
  494. package/umd/persisters/persister-powersync/with-schemas/index.js +58 -49
  495. package/umd/persisters/persister-sqlite-wasm/index.js +62 -49
  496. package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +62 -49
  497. package/umd/persisters/persister-sqlite3/index.js +58 -49
  498. package/umd/persisters/persister-sqlite3/with-schemas/index.js +58 -49
  499. package/umd/persisters/with-schemas/index.js +835 -0
  500. package/umd/synchronizers/index.js +1 -0
  501. package/umd/synchronizers/synchronizer-broadcast-channel/index.js +1 -0
  502. package/umd/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -0
  503. package/umd/synchronizers/synchronizer-local/index.js +1 -0
  504. package/umd/synchronizers/synchronizer-local/with-schemas/index.js +1 -0
  505. package/umd/synchronizers/synchronizer-ws-client/index.js +1 -0
  506. package/umd/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -0
  507. package/umd/synchronizers/synchronizer-ws-server/index.js +9 -8
  508. package/umd/synchronizers/synchronizer-ws-server/with-schemas/index.js +9 -8
  509. package/umd/synchronizers/with-schemas/index.js +1 -0
  510. package/umd/with-schemas/index.js +45 -454
  511. package/with-schemas/index.js +45 -447
@@ -45,13 +45,13 @@ const DATA_VERSION = 'data_version';
45
45
  const SCHEMA_VERSION = 'schema_version';
46
46
  const FROM = 'FROM ';
47
47
  const PRAGMA_TABLE = 'pragma_table_';
48
- const getWrappedCommand = (rawCmd, onSqlCommand) =>
48
+ const getWrappedCommand = (executeCommand, onSqlCommand) =>
49
49
  onSqlCommand
50
- ? async (sql, args) => {
51
- onSqlCommand(sql, args);
52
- return await rawCmd(sql, args);
50
+ ? async (sql, params) => {
51
+ onSqlCommand(sql, params);
52
+ return await executeCommand(sql, params);
53
53
  }
54
- : rawCmd;
54
+ : executeCommand;
55
55
  const escapeId = (str) => `"${str.replace(/"/g, '""')}"`;
56
56
  const getPlaceholders = (array) =>
57
57
  arrayJoin(
@@ -314,7 +314,7 @@ const setNew = (entryOrEntries) =>
314
314
  const setAdd = (set, value) => set?.add(value);
315
315
 
316
316
  const getCommandFunctions = (
317
- cmd,
317
+ databaseExecuteCommand,
318
318
  managedTableNames,
319
319
  querySchema,
320
320
  onIgnoredError,
@@ -328,8 +328,9 @@ const getCommandFunctions = (
328
328
  collHas(mapGet(schemaMap, tableName), rowIdColumnName);
329
329
  const refreshSchema = async () => {
330
330
  collClear(schemaMap);
331
- arrayMap(await querySchema(cmd, managedTableNames), ({tn, cn}) =>
332
- setAdd(mapEnsure(schemaMap, tn, setNew), cn),
331
+ arrayMap(
332
+ await querySchema(databaseExecuteCommand, managedTableNames),
333
+ ({tn, cn}) => setAdd(mapEnsure(schemaMap, tn, setNew), cn),
333
334
  );
334
335
  };
335
336
  const loadTable = async (tableName, rowIdColumnName) =>
@@ -337,7 +338,9 @@ const getCommandFunctions = (
337
338
  ? objNew(
338
339
  arrayFilter(
339
340
  arrayMap(
340
- await cmd(SELECT_STAR_FROM + escapeId(tableName)),
341
+ await databaseExecuteCommand(
342
+ SELECT_STAR_FROM + escapeId(tableName),
343
+ ),
341
344
  (row) => [
342
345
  row[rowIdColumnName],
343
346
  decode
@@ -370,7 +373,7 @@ const getCommandFunctions = (
370
373
  arrayIsEmpty(tableColumnNames) &&
371
374
  collHas(schemaMap, tableName)
372
375
  ) {
373
- await cmd('DROP ' + TABLE + escapeId(tableName));
376
+ await databaseExecuteCommand('DROP ' + TABLE + escapeId(tableName));
374
377
  mapSet(schemaMap, tableName);
375
378
  return;
376
379
  }
@@ -378,7 +381,7 @@ const getCommandFunctions = (
378
381
  const currentColumnNames = setNew(collValues(tableSchemaColumns));
379
382
  if (!arrayIsEmpty(tableColumnNames)) {
380
383
  if (!collHas(schemaMap, tableName)) {
381
- await cmd(
384
+ await databaseExecuteCommand(
382
385
  'CREATE ' +
383
386
  TABLE +
384
387
  escapeId(tableName) +
@@ -400,7 +403,7 @@ const getCommandFunctions = (
400
403
  [rowIdColumnName, ...tableColumnNames],
401
404
  async (columnName, index) => {
402
405
  if (!collDel(currentColumnNames, columnName)) {
403
- await cmd(
406
+ await databaseExecuteCommand(
404
407
  ALTER_TABLE +
405
408
  escapeId(tableName) +
406
409
  'ADD' +
@@ -408,7 +411,7 @@ const getCommandFunctions = (
408
411
  columnType,
409
412
  );
410
413
  if (index == 0) {
411
- await cmd(
414
+ await databaseExecuteCommand(
412
415
  'CREATE UNIQUE INDEX pk ON ' +
413
416
  escapeId(tableName) +
414
417
  `(${escapeId(rowIdColumnName)})`,
@@ -425,7 +428,7 @@ const getCommandFunctions = (
425
428
  ...(!partial && deleteEmptyColumns
426
429
  ? arrayMap(collValues(currentColumnNames), async (columnName) => {
427
430
  if (columnName != rowIdColumnName) {
428
- await cmd(
431
+ await databaseExecuteCommand(
429
432
  ALTER_TABLE +
430
433
  escapeId(tableName) +
431
434
  'DROP' +
@@ -438,12 +441,14 @@ const getCommandFunctions = (
438
441
  ]);
439
442
  if (partial) {
440
443
  if (isUndefined(content)) {
441
- await cmd(DELETE_FROM + escapeId(tableName) + WHERE + ' true');
444
+ await databaseExecuteCommand(
445
+ DELETE_FROM + escapeId(tableName) + WHERE + ' true',
446
+ );
442
447
  } else {
443
448
  await promiseAll(
444
449
  objToArray(content, async (row, rowId) => {
445
450
  if (isUndefined(row)) {
446
- await cmd(
451
+ await databaseExecuteCommand(
447
452
  DELETE_FROM +
448
453
  escapeId(tableName) +
449
454
  WHERE +
@@ -453,7 +458,7 @@ const getCommandFunctions = (
453
458
  );
454
459
  } else if (!arrayIsEmpty(tableColumnNames)) {
455
460
  await upsert(
456
- cmd,
461
+ databaseExecuteCommand,
457
462
  tableName,
458
463
  rowIdColumnName,
459
464
  objIds(row),
@@ -475,11 +480,11 @@ const getCommandFunctions = (
475
480
  collValues(mapGet(schemaMap, tableName)),
476
481
  (columnName) => columnName != rowIdColumnName,
477
482
  );
478
- const args = [];
483
+ const params = [];
479
484
  const deleteRowIds = [];
480
485
  objToArray(content ?? {}, (row, rowId) => {
481
486
  arrayPush(
482
- args,
487
+ params,
483
488
  rowId,
484
489
  ...arrayMap(changingColumnNames, (cellId) =>
485
490
  encode ? encode(row?.[cellId]) : row?.[cellId],
@@ -488,14 +493,14 @@ const getCommandFunctions = (
488
493
  arrayPush(deleteRowIds, rowId);
489
494
  });
490
495
  await upsert(
491
- cmd,
496
+ databaseExecuteCommand,
492
497
  tableName,
493
498
  rowIdColumnName,
494
499
  changingColumnNames,
495
- args,
500
+ params,
496
501
  orReplace,
497
502
  );
498
- await cmd(
503
+ await databaseExecuteCommand(
499
504
  DELETE_FROM +
500
505
  escapeId(tableName) +
501
506
  WHERE +
@@ -504,32 +509,34 @@ const getCommandFunctions = (
504
509
  deleteRowIds,
505
510
  );
506
511
  } else if (collHas(schemaMap, tableName)) {
507
- await cmd(DELETE_FROM + escapeId(tableName) + WHERE + ' true');
512
+ await databaseExecuteCommand(
513
+ DELETE_FROM + escapeId(tableName) + WHERE + ' true',
514
+ );
508
515
  }
509
516
  }
510
517
  };
511
518
  const transaction = async (actions) => {
512
519
  let result;
513
- await cmd('BEGIN');
520
+ await databaseExecuteCommand('BEGIN');
514
521
  try {
515
522
  result = await actions();
516
523
  } catch (error) {
517
524
  onIgnoredError?.(error);
518
525
  }
519
- await cmd('END');
526
+ await databaseExecuteCommand('END');
520
527
  return result;
521
528
  };
522
529
  return [refreshSchema, loadTable, saveTable, transaction];
523
530
  };
524
531
  const upsert = async (
525
- cmd,
532
+ executeCommand,
526
533
  tableName,
527
534
  rowIdColumnName,
528
535
  changingColumnNames,
529
- args,
536
+ params,
530
537
  orReplace = 0,
531
538
  ) =>
532
- await cmd(
539
+ await executeCommand(
533
540
  'INSERT ' +
534
541
  (orReplace ? 'OR REPLACE ' : EMPTY_STRING) +
535
542
  'INTO' +
@@ -543,7 +550,7 @@ const upsert = async (
543
550
  ),
544
551
  ) +
545
552
  ')VALUES' +
546
- getUpsertPlaceholders(args, size(changingColumnNames) + 1) +
553
+ getUpsertPlaceholders(params, size(changingColumnNames) + 1) +
547
554
  (orReplace
548
555
  ? EMPTY_STRING
549
556
  : 'ON CONFLICT(' +
@@ -557,7 +564,7 @@ const upsert = async (
557
564
  ),
558
565
  COMMA,
559
566
  )),
560
- arrayMap(args, (arg) => arg ?? null),
567
+ arrayMap(params, (param) => param ?? null),
561
568
  );
562
569
  const getUpsertPlaceholders = (array, columnCount) =>
563
570
  arrayJoin(
@@ -579,7 +586,7 @@ const getUpsertPlaceholders = (array, columnCount) =>
579
586
 
580
587
  const createJsonPersister = (
581
588
  store,
582
- cmd,
589
+ executeCommand,
583
590
  addPersisterListener,
584
591
  delPersisterListener,
585
592
  onIgnoredError,
@@ -595,7 +602,7 @@ const createJsonPersister = (
595
602
  ) => {
596
603
  const [refreshSchema, loadTable, saveTable, transaction] =
597
604
  getCommandFunctions(
598
- cmd,
605
+ executeCommand,
599
606
  managedTableNames,
600
607
  querySchema,
601
608
  onIgnoredError,
@@ -647,7 +654,7 @@ const createJsonPersister = (
647
654
 
648
655
  const createTabularPersister = (
649
656
  store,
650
- cmd,
657
+ executeCommand,
651
658
  addPersisterListener,
652
659
  delPersisterListener,
653
660
  onIgnoredError,
@@ -669,7 +676,7 @@ const createTabularPersister = (
669
676
  ) => {
670
677
  const [refreshSchema, loadTable, saveTable, transaction] =
671
678
  getCommandFunctions(
672
- cmd,
679
+ executeCommand,
673
680
  managedTableNames,
674
681
  querySchema,
675
682
  onIgnoredError,
@@ -875,14 +882,15 @@ const getConfigStructures = (configOrStoreTableName) => {
875
882
  return [0, autoLoadIntervalSeconds, tabularConfig, managedTableNames];
876
883
  };
877
884
 
878
- const createSqlitePersister = (
885
+ const createCustomSqlitePersister = (
879
886
  store,
880
887
  configOrStoreTableName,
881
- rawCmd,
882
- addUpdateListener,
883
- delUpdateListener,
888
+ rawExecuteCommand,
889
+ addChangeListener,
890
+ delChangeListener,
884
891
  onSqlCommand,
885
892
  onIgnoredError,
893
+ destroy,
886
894
  persist,
887
895
  thing,
888
896
  getThing = 'getDb',
@@ -891,7 +899,7 @@ const createSqlitePersister = (
891
899
  let dataVersion;
892
900
  let schemaVersion;
893
901
  let totalChanges;
894
- const cmd = getWrappedCommand(rawCmd, onSqlCommand);
902
+ const executeCommand = getWrappedCommand(rawExecuteCommand, onSqlCommand);
895
903
  const [
896
904
  isJson,
897
905
  autoLoadIntervalSeconds,
@@ -903,7 +911,7 @@ const createSqlitePersister = (
903
911
  const startPolling = () =>
904
912
  (interval = startInterval(async () => {
905
913
  try {
906
- const [{d, s, c}] = await cmd(
914
+ const [{d, s, c}] = await executeCommand(
907
915
  // eslint-disable-next-line max-len
908
916
  `${SELECT} ${DATA_VERSION} d,${SCHEMA_VERSION} s,TOTAL_CHANGES() c FROM ${PRAGMA}${DATA_VERSION} JOIN ${PRAGMA}${SCHEMA_VERSION}`,
909
917
  );
@@ -921,7 +929,7 @@ const createSqlitePersister = (
921
929
  dataVersion = schemaVersion = totalChanges = null;
922
930
  stopInterval(interval);
923
931
  };
924
- const listeningHandle = addUpdateListener((tableName) => {
932
+ const listeningHandle = addChangeListener((tableName) => {
925
933
  if (managedTableNamesSet.has(tableName)) {
926
934
  stopPolling();
927
935
  listener();
@@ -931,23 +939,23 @@ const createSqlitePersister = (
931
939
  startPolling();
932
940
  return () => {
933
941
  stopPolling();
934
- delUpdateListener(listeningHandle);
942
+ delChangeListener(listeningHandle);
935
943
  };
936
944
  };
937
945
  const delPersisterListener = (stopPollingAndDelUpdateListener) =>
938
946
  stopPollingAndDelUpdateListener();
939
947
  return (isJson ? createJsonPersister : createTabularPersister)(
940
948
  store,
941
- cmd,
949
+ executeCommand,
942
950
  addPersisterListener,
943
951
  delPersisterListener,
944
952
  onIgnoredError,
945
- () => 0,
953
+ destroy,
946
954
  persist,
947
955
  defaultedConfig,
948
956
  collValues(managedTableNamesSet),
949
- async (cmd2, managedTableNames) =>
950
- await cmd2(
957
+ async (executeCommand2, managedTableNames) =>
958
+ await executeCommand2(
951
959
  // eslint-disable-next-line max-len
952
960
  `${SELECT} t.name tn,c.name cn ${FROM}${PRAGMA_TABLE}list()t,${PRAGMA_TABLE}info(t.name)c ${WHERE} t.schema='main'AND t.type IN('table','view')AND t.name IN(${getPlaceholders(managedTableNames)})ORDER BY t.name,c.name`,
953
961
  managedTableNames,
@@ -970,12 +978,12 @@ const createSqliteWasmPersister = (
970
978
  onSqlCommand,
971
979
  onIgnoredError,
972
980
  ) =>
973
- createSqlitePersister(
981
+ createCustomSqlitePersister(
974
982
  store,
975
983
  configOrStoreTableName,
976
- async (sql, args = []) =>
984
+ async (sql, params = []) =>
977
985
  db
978
- .exec(sql, {bind: args, rowMode: 'object', returnValue: 'resultRows'})
986
+ .exec(sql, {bind: params, rowMode: 'object', returnValue: 'resultRows'})
979
987
  .map((row) => ({...row})),
980
988
  (listener) =>
981
989
  sqlite3.capi.sqlite3_update_hook(
@@ -986,6 +994,7 @@ const createSqliteWasmPersister = (
986
994
  () => sqlite3.capi.sqlite3_update_hook(db, () => 0, 0),
987
995
  onSqlCommand,
988
996
  onIgnoredError,
997
+ () => 0,
989
998
  3,
990
999
  // StoreOrMergeableStore,
991
1000
  db,
@@ -46,13 +46,13 @@ const DATA_VERSION = 'data_version';
46
46
  const SCHEMA_VERSION = 'schema_version';
47
47
  const FROM = 'FROM ';
48
48
  const PRAGMA_TABLE = 'pragma_table_';
49
- const getWrappedCommand = (rawCmd, onSqlCommand) =>
49
+ const getWrappedCommand = (executeCommand, onSqlCommand) =>
50
50
  onSqlCommand
51
- ? async (sql, args) => {
52
- onSqlCommand(sql, args);
53
- return await rawCmd(sql, args);
51
+ ? async (sql, params) => {
52
+ onSqlCommand(sql, params);
53
+ return await executeCommand(sql, params);
54
54
  }
55
- : rawCmd;
55
+ : executeCommand;
56
56
  const escapeId = (str) => `"${str.replace(/"/g, '""')}"`;
57
57
  const getPlaceholders = (array) =>
58
58
  arrayJoin(
@@ -315,7 +315,7 @@ const setNew = (entryOrEntries) =>
315
315
  const setAdd = (set, value) => set?.add(value);
316
316
 
317
317
  const getCommandFunctions = (
318
- cmd,
318
+ databaseExecuteCommand,
319
319
  managedTableNames,
320
320
  querySchema,
321
321
  onIgnoredError,
@@ -329,8 +329,9 @@ const getCommandFunctions = (
329
329
  collHas(mapGet(schemaMap, tableName), rowIdColumnName);
330
330
  const refreshSchema = async () => {
331
331
  collClear(schemaMap);
332
- arrayMap(await querySchema(cmd, managedTableNames), ({tn, cn}) =>
333
- setAdd(mapEnsure(schemaMap, tn, setNew), cn),
332
+ arrayMap(
333
+ await querySchema(databaseExecuteCommand, managedTableNames),
334
+ ({tn, cn}) => setAdd(mapEnsure(schemaMap, tn, setNew), cn),
334
335
  );
335
336
  };
336
337
  const loadTable = async (tableName, rowIdColumnName) =>
@@ -338,7 +339,9 @@ const getCommandFunctions = (
338
339
  ? objNew(
339
340
  arrayFilter(
340
341
  arrayMap(
341
- await cmd(SELECT_STAR_FROM + escapeId(tableName)),
342
+ await databaseExecuteCommand(
343
+ SELECT_STAR_FROM + escapeId(tableName),
344
+ ),
342
345
  (row) => [
343
346
  row[rowIdColumnName],
344
347
  decode
@@ -371,7 +374,7 @@ const getCommandFunctions = (
371
374
  arrayIsEmpty(tableColumnNames) &&
372
375
  collHas(schemaMap, tableName)
373
376
  ) {
374
- await cmd('DROP ' + TABLE + escapeId(tableName));
377
+ await databaseExecuteCommand('DROP ' + TABLE + escapeId(tableName));
375
378
  mapSet(schemaMap, tableName);
376
379
  return;
377
380
  }
@@ -379,7 +382,7 @@ const getCommandFunctions = (
379
382
  const currentColumnNames = setNew(collValues(tableSchemaColumns));
380
383
  if (!arrayIsEmpty(tableColumnNames)) {
381
384
  if (!collHas(schemaMap, tableName)) {
382
- await cmd(
385
+ await databaseExecuteCommand(
383
386
  'CREATE ' +
384
387
  TABLE +
385
388
  escapeId(tableName) +
@@ -401,7 +404,7 @@ const getCommandFunctions = (
401
404
  [rowIdColumnName, ...tableColumnNames],
402
405
  async (columnName, index) => {
403
406
  if (!collDel(currentColumnNames, columnName)) {
404
- await cmd(
407
+ await databaseExecuteCommand(
405
408
  ALTER_TABLE +
406
409
  escapeId(tableName) +
407
410
  'ADD' +
@@ -409,7 +412,7 @@ const getCommandFunctions = (
409
412
  columnType,
410
413
  );
411
414
  if (index == 0) {
412
- await cmd(
415
+ await databaseExecuteCommand(
413
416
  'CREATE UNIQUE INDEX pk ON ' +
414
417
  escapeId(tableName) +
415
418
  `(${escapeId(rowIdColumnName)})`,
@@ -426,7 +429,7 @@ const getCommandFunctions = (
426
429
  ...(!partial && deleteEmptyColumns
427
430
  ? arrayMap(collValues(currentColumnNames), async (columnName) => {
428
431
  if (columnName != rowIdColumnName) {
429
- await cmd(
432
+ await databaseExecuteCommand(
430
433
  ALTER_TABLE +
431
434
  escapeId(tableName) +
432
435
  'DROP' +
@@ -439,12 +442,14 @@ const getCommandFunctions = (
439
442
  ]);
440
443
  if (partial) {
441
444
  if (isUndefined(content)) {
442
- await cmd(DELETE_FROM + escapeId(tableName) + WHERE + ' true');
445
+ await databaseExecuteCommand(
446
+ DELETE_FROM + escapeId(tableName) + WHERE + ' true',
447
+ );
443
448
  } else {
444
449
  await promiseAll(
445
450
  objToArray(content, async (row, rowId) => {
446
451
  if (isUndefined(row)) {
447
- await cmd(
452
+ await databaseExecuteCommand(
448
453
  DELETE_FROM +
449
454
  escapeId(tableName) +
450
455
  WHERE +
@@ -454,7 +459,7 @@ const getCommandFunctions = (
454
459
  );
455
460
  } else if (!arrayIsEmpty(tableColumnNames)) {
456
461
  await upsert(
457
- cmd,
462
+ databaseExecuteCommand,
458
463
  tableName,
459
464
  rowIdColumnName,
460
465
  objIds(row),
@@ -476,11 +481,11 @@ const getCommandFunctions = (
476
481
  collValues(mapGet(schemaMap, tableName)),
477
482
  (columnName) => columnName != rowIdColumnName,
478
483
  );
479
- const args = [];
484
+ const params = [];
480
485
  const deleteRowIds = [];
481
486
  objToArray(content ?? {}, (row, rowId) => {
482
487
  arrayPush(
483
- args,
488
+ params,
484
489
  rowId,
485
490
  ...arrayMap(changingColumnNames, (cellId) =>
486
491
  encode ? encode(row?.[cellId]) : row?.[cellId],
@@ -489,14 +494,14 @@ const getCommandFunctions = (
489
494
  arrayPush(deleteRowIds, rowId);
490
495
  });
491
496
  await upsert(
492
- cmd,
497
+ databaseExecuteCommand,
493
498
  tableName,
494
499
  rowIdColumnName,
495
500
  changingColumnNames,
496
- args,
501
+ params,
497
502
  orReplace,
498
503
  );
499
- await cmd(
504
+ await databaseExecuteCommand(
500
505
  DELETE_FROM +
501
506
  escapeId(tableName) +
502
507
  WHERE +
@@ -505,32 +510,34 @@ const getCommandFunctions = (
505
510
  deleteRowIds,
506
511
  );
507
512
  } else if (collHas(schemaMap, tableName)) {
508
- await cmd(DELETE_FROM + escapeId(tableName) + WHERE + ' true');
513
+ await databaseExecuteCommand(
514
+ DELETE_FROM + escapeId(tableName) + WHERE + ' true',
515
+ );
509
516
  }
510
517
  }
511
518
  };
512
519
  const transaction = async (actions) => {
513
520
  let result;
514
- await cmd('BEGIN');
521
+ await databaseExecuteCommand('BEGIN');
515
522
  try {
516
523
  result = await actions();
517
524
  } catch (error) {
518
525
  onIgnoredError?.(error);
519
526
  }
520
- await cmd('END');
527
+ await databaseExecuteCommand('END');
521
528
  return result;
522
529
  };
523
530
  return [refreshSchema, loadTable, saveTable, transaction];
524
531
  };
525
532
  const upsert = async (
526
- cmd,
533
+ executeCommand,
527
534
  tableName,
528
535
  rowIdColumnName,
529
536
  changingColumnNames,
530
- args,
537
+ params,
531
538
  orReplace = 0,
532
539
  ) =>
533
- await cmd(
540
+ await executeCommand(
534
541
  'INSERT ' +
535
542
  (orReplace ? 'OR REPLACE ' : EMPTY_STRING) +
536
543
  'INTO' +
@@ -544,7 +551,7 @@ const upsert = async (
544
551
  ),
545
552
  ) +
546
553
  ')VALUES' +
547
- getUpsertPlaceholders(args, size(changingColumnNames) + 1) +
554
+ getUpsertPlaceholders(params, size(changingColumnNames) + 1) +
548
555
  (orReplace
549
556
  ? EMPTY_STRING
550
557
  : 'ON CONFLICT(' +
@@ -558,7 +565,7 @@ const upsert = async (
558
565
  ),
559
566
  COMMA,
560
567
  )),
561
- arrayMap(args, (arg) => arg ?? null),
568
+ arrayMap(params, (param) => param ?? null),
562
569
  );
563
570
  const getUpsertPlaceholders = (array, columnCount) =>
564
571
  arrayJoin(
@@ -580,7 +587,7 @@ const getUpsertPlaceholders = (array, columnCount) =>
580
587
 
581
588
  const createJsonPersister = (
582
589
  store,
583
- cmd,
590
+ executeCommand,
584
591
  addPersisterListener,
585
592
  delPersisterListener,
586
593
  onIgnoredError,
@@ -596,7 +603,7 @@ const createJsonPersister = (
596
603
  ) => {
597
604
  const [refreshSchema, loadTable, saveTable, transaction] =
598
605
  getCommandFunctions(
599
- cmd,
606
+ executeCommand,
600
607
  managedTableNames,
601
608
  querySchema,
602
609
  onIgnoredError,
@@ -648,7 +655,7 @@ const createJsonPersister = (
648
655
 
649
656
  const createTabularPersister = (
650
657
  store,
651
- cmd,
658
+ executeCommand,
652
659
  addPersisterListener,
653
660
  delPersisterListener,
654
661
  onIgnoredError,
@@ -670,7 +677,7 @@ const createTabularPersister = (
670
677
  ) => {
671
678
  const [refreshSchema, loadTable, saveTable, transaction] =
672
679
  getCommandFunctions(
673
- cmd,
680
+ executeCommand,
674
681
  managedTableNames,
675
682
  querySchema,
676
683
  onIgnoredError,
@@ -876,14 +883,15 @@ const getConfigStructures = (configOrStoreTableName) => {
876
883
  return [0, autoLoadIntervalSeconds, tabularConfig, managedTableNames];
877
884
  };
878
885
 
879
- const createSqlitePersister = (
886
+ const createCustomSqlitePersister = (
880
887
  store,
881
888
  configOrStoreTableName,
882
- rawCmd,
883
- addUpdateListener,
884
- delUpdateListener,
889
+ rawExecuteCommand,
890
+ addChangeListener,
891
+ delChangeListener,
885
892
  onSqlCommand,
886
893
  onIgnoredError,
894
+ destroy,
887
895
  persist,
888
896
  thing,
889
897
  getThing = 'getDb',
@@ -892,7 +900,7 @@ const createSqlitePersister = (
892
900
  let dataVersion;
893
901
  let schemaVersion;
894
902
  let totalChanges;
895
- const cmd = getWrappedCommand(rawCmd, onSqlCommand);
903
+ const executeCommand = getWrappedCommand(rawExecuteCommand, onSqlCommand);
896
904
  const [
897
905
  isJson,
898
906
  autoLoadIntervalSeconds,
@@ -904,7 +912,7 @@ const createSqlitePersister = (
904
912
  const startPolling = () =>
905
913
  (interval = startInterval(async () => {
906
914
  try {
907
- const [{d, s, c}] = await cmd(
915
+ const [{d, s, c}] = await executeCommand(
908
916
  // eslint-disable-next-line max-len
909
917
  `${SELECT} ${DATA_VERSION} d,${SCHEMA_VERSION} s,TOTAL_CHANGES() c FROM ${PRAGMA}${DATA_VERSION} JOIN ${PRAGMA}${SCHEMA_VERSION}`,
910
918
  );
@@ -922,7 +930,7 @@ const createSqlitePersister = (
922
930
  dataVersion = schemaVersion = totalChanges = null;
923
931
  stopInterval(interval);
924
932
  };
925
- const listeningHandle = addUpdateListener((tableName) => {
933
+ const listeningHandle = addChangeListener((tableName) => {
926
934
  if (managedTableNamesSet.has(tableName)) {
927
935
  stopPolling();
928
936
  listener();
@@ -932,23 +940,23 @@ const createSqlitePersister = (
932
940
  startPolling();
933
941
  return () => {
934
942
  stopPolling();
935
- delUpdateListener(listeningHandle);
943
+ delChangeListener(listeningHandle);
936
944
  };
937
945
  };
938
946
  const delPersisterListener = (stopPollingAndDelUpdateListener) =>
939
947
  stopPollingAndDelUpdateListener();
940
948
  return (isJson ? createJsonPersister : createTabularPersister)(
941
949
  store,
942
- cmd,
950
+ executeCommand,
943
951
  addPersisterListener,
944
952
  delPersisterListener,
945
953
  onIgnoredError,
946
- () => 0,
954
+ destroy,
947
955
  persist,
948
956
  defaultedConfig,
949
957
  collValues(managedTableNamesSet),
950
- async (cmd2, managedTableNames) =>
951
- await cmd2(
958
+ async (executeCommand2, managedTableNames) =>
959
+ await executeCommand2(
952
960
  // eslint-disable-next-line max-len
953
961
  `${SELECT} t.name tn,c.name cn ${FROM}${PRAGMA_TABLE}list()t,${PRAGMA_TABLE}info(t.name)c ${WHERE} t.schema='main'AND t.type IN('table','view')AND t.name IN(${getPlaceholders(managedTableNames)})ORDER BY t.name,c.name`,
954
962
  managedTableNames,
@@ -971,12 +979,12 @@ const createSqlite3Persister = (
971
979
  onSqlCommand,
972
980
  onIgnoredError,
973
981
  ) =>
974
- createSqlitePersister(
982
+ createCustomSqlitePersister(
975
983
  store,
976
984
  configOrStoreTableName,
977
- async (sql, args = []) =>
985
+ async (sql, params = []) =>
978
986
  await promiseNew((resolve, reject) =>
979
- db.all(sql, args, (error, rows) =>
987
+ db.all(sql, params, (error, rows) =>
980
988
  error ? reject(error) : resolve(rows),
981
989
  ),
982
990
  ),
@@ -988,6 +996,7 @@ const createSqlite3Persister = (
988
996
  (observer) => db.off(CHANGE, observer),
989
997
  onSqlCommand,
990
998
  onIgnoredError,
999
+ () => 0,
991
1000
  3,
992
1001
  // StoreOrMergeableStore,
993
1002
  db,