@verdant-web/store 2.0.1 → 2.0.2

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 (560) hide show
  1. package/dist/cjs/BackoffScheduler.d.ts +19 -19
  2. package/dist/cjs/BackoffScheduler.js +44 -44
  3. package/dist/cjs/DocumentManager.d.ts +28 -28
  4. package/dist/cjs/DocumentManager.js +44 -44
  5. package/dist/cjs/IDBService.d.ts +9 -9
  6. package/dist/cjs/IDBService.js +46 -46
  7. package/dist/cjs/UndoHistory.d.ts +16 -16
  8. package/dist/cjs/UndoHistory.js +50 -50
  9. package/dist/cjs/__tests__/batching.test.d.ts +1 -1
  10. package/dist/cjs/__tests__/batching.test.js +44 -44
  11. package/dist/cjs/__tests__/documents.test.d.ts +1 -1
  12. package/dist/cjs/__tests__/documents.test.js +398 -398
  13. package/dist/cjs/__tests__/fixtures/testStorage.d.ts +118 -118
  14. package/dist/cjs/__tests__/fixtures/testStorage.js +115 -115
  15. package/dist/cjs/__tests__/queries.test.d.ts +1 -1
  16. package/dist/cjs/__tests__/queries.test.js +262 -262
  17. package/dist/cjs/__tests__/setup/indexedDB.d.ts +1 -1
  18. package/dist/cjs/__tests__/setup/indexedDB.js +3 -3
  19. package/dist/cjs/__tests__/undo.test.d.ts +1 -1
  20. package/dist/cjs/__tests__/undo.test.js +86 -86
  21. package/dist/cjs/client/Client.d.ts +86 -86
  22. package/dist/cjs/client/Client.js +226 -226
  23. package/dist/cjs/client/ClientDescriptor.d.ts +62 -62
  24. package/dist/cjs/client/ClientDescriptor.js +108 -108
  25. package/dist/cjs/constants.d.ts +1 -1
  26. package/dist/cjs/constants.js +4 -4
  27. package/dist/cjs/context.d.ts +17 -17
  28. package/dist/cjs/context.js +2 -2
  29. package/dist/cjs/files/EntityFile.d.ts +27 -27
  30. package/dist/cjs/files/EntityFile.js +71 -71
  31. package/dist/cjs/files/FileManager.d.ts +42 -42
  32. package/dist/cjs/files/FileManager.js +145 -145
  33. package/dist/cjs/files/FileStorage.d.ts +27 -27
  34. package/dist/cjs/files/FileStorage.js +93 -93
  35. package/dist/cjs/files/utils.d.ts +8 -8
  36. package/dist/cjs/files/utils.js +55 -55
  37. package/dist/cjs/files/utils.test.d.ts +1 -1
  38. package/dist/cjs/files/utils.test.js +80 -80
  39. package/dist/cjs/idb.d.ts +8 -8
  40. package/dist/cjs/idb.js +87 -87
  41. package/dist/cjs/index.d.ts +19 -19
  42. package/dist/cjs/index.js +20 -20
  43. package/dist/cjs/indexes.d.ts +3 -3
  44. package/dist/cjs/indexes.js +19 -19
  45. package/dist/cjs/metadata/AckInfoStore.d.ts +10 -10
  46. package/dist/cjs/metadata/AckInfoStore.js +25 -25
  47. package/dist/cjs/metadata/BaselinesStore.d.ts +33 -33
  48. package/dist/cjs/metadata/BaselinesStore.js +59 -59
  49. package/dist/cjs/metadata/LocalReplicaStore.d.ts +17 -17
  50. package/dist/cjs/metadata/LocalReplicaStore.js +47 -47
  51. package/dist/cjs/metadata/MessageCreator.d.ts +19 -19
  52. package/dist/cjs/metadata/MessageCreator.js +127 -127
  53. package/dist/cjs/metadata/Metadata.d.ts +106 -106
  54. package/dist/cjs/metadata/Metadata.js +336 -336
  55. package/dist/cjs/metadata/OperationsStore.d.ts +50 -50
  56. package/dist/cjs/metadata/OperationsStore.js +145 -145
  57. package/dist/cjs/metadata/SchemaStore.d.ts +9 -9
  58. package/dist/cjs/metadata/SchemaStore.js +38 -38
  59. package/dist/cjs/metadata/openMetadataDatabase.d.ts +8 -8
  60. package/dist/cjs/metadata/openMetadataDatabase.js +105 -105
  61. package/dist/cjs/openDocumentDatabase.d.ts +12 -12
  62. package/dist/cjs/openDocumentDatabase.js +424 -424
  63. package/dist/cjs/queries2/BaseQuery.d.ts +39 -39
  64. package/dist/cjs/queries2/BaseQuery.js +98 -98
  65. package/dist/cjs/queries2/CollectionQueries.d.ts +55 -55
  66. package/dist/cjs/queries2/CollectionQueries.js +82 -82
  67. package/dist/cjs/queries2/FindAllQuery.d.ts +11 -11
  68. package/dist/cjs/queries2/FindAllQuery.js +33 -33
  69. package/dist/cjs/queries2/FindInfiniteQuery.d.ts +18 -18
  70. package/dist/cjs/queries2/FindInfiniteQuery.js +60 -60
  71. package/dist/cjs/queries2/FindOneQuery.d.ts +11 -11
  72. package/dist/cjs/queries2/FindOneQuery.js +33 -33
  73. package/dist/cjs/queries2/FindPageQuery.d.ts +23 -23
  74. package/dist/cjs/queries2/FindPageQuery.js +67 -67
  75. package/dist/cjs/queries2/GetQuery.d.ts +10 -10
  76. package/dist/cjs/queries2/GetQuery.js +29 -29
  77. package/dist/cjs/queries2/QueryCache.d.ts +16 -16
  78. package/dist/cjs/queries2/QueryCache.js +39 -39
  79. package/dist/cjs/queries2/dbQueries.d.ts +22 -22
  80. package/dist/cjs/queries2/dbQueries.js +125 -125
  81. package/dist/cjs/queries2/keys.d.ts +10 -10
  82. package/dist/cjs/queries2/keys.js +33 -33
  83. package/dist/cjs/queries2/ranges.d.ts +2 -2
  84. package/dist/cjs/queries2/ranges.js +69 -69
  85. package/dist/cjs/queries2/types.d.ts +6 -6
  86. package/dist/cjs/queries2/types.js +2 -2
  87. package/dist/cjs/queries2/utils.d.ts +1 -1
  88. package/dist/cjs/queries2/utils.js +19 -19
  89. package/dist/cjs/reactives/DocumentFamiliyCache.d.ts +47 -47
  90. package/dist/cjs/reactives/DocumentFamiliyCache.js +210 -210
  91. package/dist/cjs/reactives/Entity.d.ts +191 -191
  92. package/dist/cjs/reactives/Entity.js +462 -462
  93. package/dist/cjs/reactives/EntityStore.d.ts +84 -84
  94. package/dist/cjs/reactives/EntityStore.js +421 -421
  95. package/dist/cjs/reactives/FakeWeakRef.d.ts +11 -11
  96. package/dist/cjs/reactives/FakeWeakRef.js +18 -18
  97. package/dist/cjs/sync/FileSync.d.ts +23 -23
  98. package/dist/cjs/sync/FileSync.js +84 -84
  99. package/dist/cjs/sync/Heartbeat.d.ts +24 -24
  100. package/dist/cjs/sync/Heartbeat.js +55 -55
  101. package/dist/cjs/sync/PresenceManager.d.ts +41 -41
  102. package/dist/cjs/sync/PresenceManager.js +107 -107
  103. package/dist/cjs/sync/PushPullSync.d.ts +36 -36
  104. package/dist/cjs/sync/PushPullSync.js +141 -141
  105. package/dist/cjs/sync/ServerSyncEndpointProvider.d.ts +27 -27
  106. package/dist/cjs/sync/ServerSyncEndpointProvider.js +64 -64
  107. package/dist/cjs/sync/Sync.d.ts +127 -127
  108. package/dist/cjs/sync/Sync.js +244 -244
  109. package/dist/cjs/sync/WebSocketSync.d.ts +41 -41
  110. package/dist/cjs/sync/WebSocketSync.js +183 -183
  111. package/dist/cjs/types.d.ts +5 -5
  112. package/dist/cjs/types.js +2 -2
  113. package/dist/cjs/utils/Disposable.d.ts +6 -6
  114. package/dist/cjs/utils/Disposable.js +18 -18
  115. package/dist/cjs/utils/Resolvable.d.ts +8 -8
  116. package/dist/cjs/utils/Resolvable.js +22 -22
  117. package/dist/esm/BackoffScheduler.d.ts +19 -19
  118. package/dist/esm/BackoffScheduler.js +39 -39
  119. package/dist/esm/DocumentManager.d.ts +28 -28
  120. package/dist/esm/DocumentManager.js +40 -40
  121. package/dist/esm/IDBService.d.ts +9 -9
  122. package/dist/esm/IDBService.js +42 -42
  123. package/dist/esm/UndoHistory.d.ts +16 -16
  124. package/dist/esm/UndoHistory.js +46 -46
  125. package/dist/esm/__tests__/batching.test.d.ts +1 -1
  126. package/dist/esm/__tests__/batching.test.js +42 -42
  127. package/dist/esm/__tests__/documents.test.d.ts +1 -1
  128. package/dist/esm/__tests__/documents.test.js +396 -396
  129. package/dist/esm/__tests__/fixtures/testStorage.d.ts +118 -118
  130. package/dist/esm/__tests__/fixtures/testStorage.js +111 -111
  131. package/dist/esm/__tests__/queries.test.d.ts +1 -1
  132. package/dist/esm/__tests__/queries.test.js +260 -260
  133. package/dist/esm/__tests__/setup/indexedDB.d.ts +1 -1
  134. package/dist/esm/__tests__/setup/indexedDB.js +1 -1
  135. package/dist/esm/__tests__/undo.test.d.ts +1 -1
  136. package/dist/esm/__tests__/undo.test.js +84 -84
  137. package/dist/esm/client/Client.d.ts +86 -86
  138. package/dist/esm/client/Client.js +222 -222
  139. package/dist/esm/client/ClientDescriptor.d.ts +62 -62
  140. package/dist/esm/client/ClientDescriptor.js +104 -104
  141. package/dist/esm/constants.d.ts +1 -1
  142. package/dist/esm/constants.js +1 -1
  143. package/dist/esm/context.d.ts +17 -17
  144. package/dist/esm/context.js +1 -1
  145. package/dist/esm/files/EntityFile.d.ts +27 -27
  146. package/dist/esm/files/EntityFile.js +67 -67
  147. package/dist/esm/files/FileManager.d.ts +42 -42
  148. package/dist/esm/files/FileManager.js +141 -141
  149. package/dist/esm/files/FileStorage.d.ts +27 -27
  150. package/dist/esm/files/FileStorage.js +88 -88
  151. package/dist/esm/files/utils.d.ts +8 -8
  152. package/dist/esm/files/utils.js +46 -46
  153. package/dist/esm/files/utils.test.d.ts +1 -1
  154. package/dist/esm/files/utils.test.js +78 -78
  155. package/dist/esm/idb.d.ts +8 -8
  156. package/dist/esm/idb.js +79 -79
  157. package/dist/esm/index.d.ts +19 -19
  158. package/dist/esm/index.js +11 -11
  159. package/dist/esm/indexes.d.ts +3 -3
  160. package/dist/esm/indexes.js +14 -14
  161. package/dist/esm/metadata/AckInfoStore.d.ts +10 -10
  162. package/dist/esm/metadata/AckInfoStore.js +21 -21
  163. package/dist/esm/metadata/BaselinesStore.d.ts +33 -33
  164. package/dist/esm/metadata/BaselinesStore.js +55 -55
  165. package/dist/esm/metadata/LocalReplicaStore.d.ts +17 -17
  166. package/dist/esm/metadata/LocalReplicaStore.js +40 -40
  167. package/dist/esm/metadata/MessageCreator.d.ts +19 -19
  168. package/dist/esm/metadata/MessageCreator.js +123 -123
  169. package/dist/esm/metadata/Metadata.d.ts +106 -106
  170. package/dist/esm/metadata/Metadata.js +332 -332
  171. package/dist/esm/metadata/OperationsStore.d.ts +50 -50
  172. package/dist/esm/metadata/OperationsStore.js +141 -141
  173. package/dist/esm/metadata/SchemaStore.d.ts +9 -9
  174. package/dist/esm/metadata/SchemaStore.js +34 -34
  175. package/dist/esm/metadata/openMetadataDatabase.d.ts +8 -8
  176. package/dist/esm/metadata/openMetadataDatabase.js +101 -101
  177. package/dist/esm/openDocumentDatabase.d.ts +12 -12
  178. package/dist/esm/openDocumentDatabase.js +420 -420
  179. package/dist/esm/queries2/BaseQuery.d.ts +39 -39
  180. package/dist/esm/queries2/BaseQuery.js +94 -94
  181. package/dist/esm/queries2/CollectionQueries.d.ts +55 -55
  182. package/dist/esm/queries2/CollectionQueries.js +78 -78
  183. package/dist/esm/queries2/FindAllQuery.d.ts +11 -11
  184. package/dist/esm/queries2/FindAllQuery.js +29 -29
  185. package/dist/esm/queries2/FindInfiniteQuery.d.ts +18 -18
  186. package/dist/esm/queries2/FindInfiniteQuery.js +56 -56
  187. package/dist/esm/queries2/FindOneQuery.d.ts +11 -11
  188. package/dist/esm/queries2/FindOneQuery.js +29 -29
  189. package/dist/esm/queries2/FindPageQuery.d.ts +23 -23
  190. package/dist/esm/queries2/FindPageQuery.js +63 -63
  191. package/dist/esm/queries2/GetQuery.d.ts +10 -10
  192. package/dist/esm/queries2/GetQuery.js +25 -25
  193. package/dist/esm/queries2/QueryCache.d.ts +16 -16
  194. package/dist/esm/queries2/QueryCache.js +35 -35
  195. package/dist/esm/queries2/dbQueries.d.ts +22 -22
  196. package/dist/esm/queries2/dbQueries.js +119 -119
  197. package/dist/esm/queries2/keys.d.ts +10 -10
  198. package/dist/esm/queries2/keys.js +29 -29
  199. package/dist/esm/queries2/ranges.d.ts +2 -2
  200. package/dist/esm/queries2/ranges.js +65 -65
  201. package/dist/esm/queries2/types.d.ts +6 -6
  202. package/dist/esm/queries2/types.js +1 -1
  203. package/dist/esm/queries2/utils.d.ts +1 -1
  204. package/dist/esm/queries2/utils.js +15 -15
  205. package/dist/esm/reactives/DocumentFamiliyCache.d.ts +47 -47
  206. package/dist/esm/reactives/DocumentFamiliyCache.js +206 -206
  207. package/dist/esm/reactives/Entity.d.ts +191 -191
  208. package/dist/esm/reactives/Entity.js +457 -457
  209. package/dist/esm/reactives/EntityStore.d.ts +84 -84
  210. package/dist/esm/reactives/EntityStore.js +417 -417
  211. package/dist/esm/reactives/FakeWeakRef.d.ts +11 -11
  212. package/dist/esm/reactives/FakeWeakRef.js +14 -14
  213. package/dist/esm/sync/FileSync.d.ts +23 -23
  214. package/dist/esm/sync/FileSync.js +80 -80
  215. package/dist/esm/sync/Heartbeat.d.ts +24 -24
  216. package/dist/esm/sync/Heartbeat.js +51 -51
  217. package/dist/esm/sync/PresenceManager.d.ts +41 -41
  218. package/dist/esm/sync/PresenceManager.js +103 -103
  219. package/dist/esm/sync/PushPullSync.d.ts +36 -36
  220. package/dist/esm/sync/PushPullSync.js +137 -137
  221. package/dist/esm/sync/ServerSyncEndpointProvider.d.ts +27 -27
  222. package/dist/esm/sync/ServerSyncEndpointProvider.js +57 -57
  223. package/dist/esm/sync/Sync.d.ts +127 -127
  224. package/dist/esm/sync/Sync.js +239 -239
  225. package/dist/esm/sync/{WebsocketSync.d.ts → WebSocketSync.d.ts} +41 -41
  226. package/dist/esm/sync/{WebsocketSync.js → WebSocketSync.js} +179 -179
  227. package/dist/esm/types.d.ts +5 -5
  228. package/dist/esm/types.js +1 -1
  229. package/dist/esm/utils/Disposable.d.ts +6 -6
  230. package/dist/esm/utils/Disposable.js +14 -14
  231. package/dist/esm/utils/Resolvable.d.ts +8 -8
  232. package/dist/esm/utils/Resolvable.js +18 -18
  233. package/dist/tsconfig-cjs.tsbuildinfo +1 -1
  234. package/dist/tsconfig.tsbuildinfo +1 -1
  235. package/package.json +2 -2
  236. package/dist/cjs/AckInfoStore.d.ts +0 -10
  237. package/dist/cjs/AckInfoStore.js +0 -26
  238. package/dist/cjs/AckInfoStore.js.map +0 -1
  239. package/dist/cjs/BaselinesStore.d.ts +0 -10
  240. package/dist/cjs/BaselinesStore.js +0 -36
  241. package/dist/cjs/BaselinesStore.js.map +0 -1
  242. package/dist/cjs/Entity.d.ts +0 -96
  243. package/dist/cjs/Entity.js +0 -345
  244. package/dist/cjs/Entity.js.map +0 -1
  245. package/dist/cjs/EntityStore.d.ts +0 -36
  246. package/dist/cjs/EntityStore.js +0 -172
  247. package/dist/cjs/EntityStore.js.map +0 -1
  248. package/dist/cjs/LocalHistoryStore.d.ts +0 -15
  249. package/dist/cjs/LocalHistoryStore.js +0 -53
  250. package/dist/cjs/LocalHistoryStore.js.map +0 -1
  251. package/dist/cjs/LocalReplicaStore.d.ts +0 -13
  252. package/dist/cjs/LocalReplicaStore.js +0 -49
  253. package/dist/cjs/LocalReplicaStore.js.map +0 -1
  254. package/dist/cjs/MessageCreator.d.ts +0 -19
  255. package/dist/cjs/MessageCreator.js +0 -104
  256. package/dist/cjs/MessageCreator.js.map +0 -1
  257. package/dist/cjs/Metadata.d.ts +0 -91
  258. package/dist/cjs/Metadata.js +0 -250
  259. package/dist/cjs/Metadata.js.map +0 -1
  260. package/dist/cjs/OperationsStore.d.ts +0 -38
  261. package/dist/cjs/OperationsStore.js +0 -146
  262. package/dist/cjs/OperationsStore.js.map +0 -1
  263. package/dist/cjs/PresenceManager.d.ts +0 -30
  264. package/dist/cjs/PresenceManager.js +0 -89
  265. package/dist/cjs/PresenceManager.js.map +0 -1
  266. package/dist/cjs/Query.d.ts +0 -26
  267. package/dist/cjs/Query.js +0 -86
  268. package/dist/cjs/Query.js.map +0 -1
  269. package/dist/cjs/QueryMaker.d.ts +0 -18
  270. package/dist/cjs/QueryMaker.js +0 -98
  271. package/dist/cjs/QueryMaker.js.map +0 -1
  272. package/dist/cjs/QueryStore.d.ts +0 -38
  273. package/dist/cjs/QueryStore.js +0 -146
  274. package/dist/cjs/QueryStore.js.map +0 -1
  275. package/dist/cjs/SchemaStore.d.ts +0 -9
  276. package/dist/cjs/SchemaStore.js +0 -35
  277. package/dist/cjs/SchemaStore.js.map +0 -1
  278. package/dist/cjs/Storage.d.ts +0 -147
  279. package/dist/cjs/Storage.js +0 -346
  280. package/dist/cjs/Storage.js.map +0 -1
  281. package/dist/cjs/Sync.d.ts +0 -117
  282. package/dist/cjs/Sync.js +0 -561
  283. package/dist/cjs/Sync.js.map +0 -1
  284. package/dist/cjs/SyncHarness.d.ts +0 -45
  285. package/dist/cjs/SyncHarness.js +0 -110
  286. package/dist/cjs/SyncHarness.js.map +0 -1
  287. package/dist/cjs/metadata/LocalHistoryStore.d.ts +0 -15
  288. package/dist/cjs/metadata/LocalHistoryStore.js +0 -53
  289. package/dist/cjs/metadata/LocalHistoryStore.js.map +0 -1
  290. package/dist/cjs/queries/LiveQuery.d.ts +0 -28
  291. package/dist/cjs/queries/LiveQuery.js +0 -96
  292. package/dist/cjs/queries/LiveQuery.js.map +0 -1
  293. package/dist/cjs/queries/LiveQueryMaker.d.ts +0 -15
  294. package/dist/cjs/queries/LiveQueryMaker.js +0 -42
  295. package/dist/cjs/queries/LiveQueryMaker.js.map +0 -1
  296. package/dist/cjs/queries/LiveQueryStore.d.ts +0 -33
  297. package/dist/cjs/queries/LiveQueryStore.js +0 -85
  298. package/dist/cjs/queries/LiveQueryStore.js.map +0 -1
  299. package/dist/cjs/queries/Query.d.ts +0 -18
  300. package/dist/cjs/queries/Query.js +0 -36
  301. package/dist/cjs/queries/Query.js.map +0 -1
  302. package/dist/cjs/queries/QueryMaker.d.ts +0 -14
  303. package/dist/cjs/queries/QueryMaker.js +0 -42
  304. package/dist/cjs/queries/QueryMaker.js.map +0 -1
  305. package/dist/cjs/queries/QueryStore.d.ts +0 -35
  306. package/dist/cjs/queries/QueryStore.js +0 -130
  307. package/dist/cjs/queries/QueryStore.js.map +0 -1
  308. package/dist/cjs/queries/ranges.d.ts +0 -2
  309. package/dist/cjs/queries/ranges.js +0 -70
  310. package/dist/cjs/queries/ranges.js.map +0 -1
  311. package/dist/cjs/v2/AckInfoStore.d.ts +0 -10
  312. package/dist/cjs/v2/AckInfoStore.js +0 -26
  313. package/dist/cjs/v2/AckInfoStore.js.map +0 -1
  314. package/dist/cjs/v2/BaselinesStore.d.ts +0 -10
  315. package/dist/cjs/v2/BaselinesStore.js +0 -36
  316. package/dist/cjs/v2/BaselinesStore.js.map +0 -1
  317. package/dist/cjs/v2/DocumentManager.d.ts +0 -19
  318. package/dist/cjs/v2/DocumentManager.js +0 -47
  319. package/dist/cjs/v2/DocumentManager.js.map +0 -1
  320. package/dist/cjs/v2/Entity.d.ts +0 -87
  321. package/dist/cjs/v2/Entity.js +0 -305
  322. package/dist/cjs/v2/Entity.js.map +0 -1
  323. package/dist/cjs/v2/EntityStore.d.ts +0 -37
  324. package/dist/cjs/v2/EntityStore.js +0 -165
  325. package/dist/cjs/v2/EntityStore.js.map +0 -1
  326. package/dist/cjs/v2/IDBService.d.ts +0 -7
  327. package/dist/cjs/v2/IDBService.js +0 -26
  328. package/dist/cjs/v2/IDBService.js.map +0 -1
  329. package/dist/cjs/v2/LocalHistoryStore.d.ts +0 -15
  330. package/dist/cjs/v2/LocalHistoryStore.js +0 -53
  331. package/dist/cjs/v2/LocalHistoryStore.js.map +0 -1
  332. package/dist/cjs/v2/LocalReplicaStore.d.ts +0 -14
  333. package/dist/cjs/v2/LocalReplicaStore.js +0 -49
  334. package/dist/cjs/v2/LocalReplicaStore.js.map +0 -1
  335. package/dist/cjs/v2/MessageCreator.d.ts +0 -19
  336. package/dist/cjs/v2/MessageCreator.js +0 -99
  337. package/dist/cjs/v2/MessageCreator.js.map +0 -1
  338. package/dist/cjs/v2/Metadata.d.ts +0 -90
  339. package/dist/cjs/v2/Metadata.js +0 -251
  340. package/dist/cjs/v2/Metadata.js.map +0 -1
  341. package/dist/cjs/v2/OperationsStore.d.ts +0 -38
  342. package/dist/cjs/v2/OperationsStore.js +0 -146
  343. package/dist/cjs/v2/OperationsStore.js.map +0 -1
  344. package/dist/cjs/v2/PresenceManager.d.ts +0 -24
  345. package/dist/cjs/v2/PresenceManager.js +0 -73
  346. package/dist/cjs/v2/PresenceManager.js.map +0 -1
  347. package/dist/cjs/v2/Query.d.ts +0 -24
  348. package/dist/cjs/v2/Query.js +0 -79
  349. package/dist/cjs/v2/Query.js.map +0 -1
  350. package/dist/cjs/v2/QueryMaker.d.ts +0 -16
  351. package/dist/cjs/v2/QueryMaker.js +0 -84
  352. package/dist/cjs/v2/QueryMaker.js.map +0 -1
  353. package/dist/cjs/v2/QueryStore.d.ts +0 -26
  354. package/dist/cjs/v2/QueryStore.js +0 -136
  355. package/dist/cjs/v2/QueryStore.js.map +0 -1
  356. package/dist/cjs/v2/SchemaStore.d.ts +0 -9
  357. package/dist/cjs/v2/SchemaStore.js +0 -35
  358. package/dist/cjs/v2/SchemaStore.js.map +0 -1
  359. package/dist/cjs/v2/Storage.d.ts +0 -80
  360. package/dist/cjs/v2/Storage.js +0 -154
  361. package/dist/cjs/v2/Storage.js.map +0 -1
  362. package/dist/cjs/v2/Sync.d.ts +0 -42
  363. package/dist/cjs/v2/Sync.js +0 -98
  364. package/dist/cjs/v2/Sync.js.map +0 -1
  365. package/dist/cjs/v2/SyncHarness.d.ts +0 -45
  366. package/dist/cjs/v2/SyncHarness.js +0 -110
  367. package/dist/cjs/v2/SyncHarness.js.map +0 -1
  368. package/dist/cjs/v2/__tests__/documents.test.d.ts +0 -1
  369. package/dist/cjs/v2/__tests__/documents.test.js +0 -185
  370. package/dist/cjs/v2/__tests__/documents.test.js.map +0 -1
  371. package/dist/cjs/v2/__tests__/fixtures/testStorage.d.ts +0 -189
  372. package/dist/cjs/v2/__tests__/fixtures/testStorage.js +0 -93
  373. package/dist/cjs/v2/__tests__/fixtures/testStorage.js.map +0 -1
  374. package/dist/cjs/v2/__tests__/queries.test.d.ts +0 -1
  375. package/dist/cjs/v2/__tests__/queries.test.js +0 -92
  376. package/dist/cjs/v2/__tests__/queries.test.js.map +0 -1
  377. package/dist/cjs/v2/__tests__/setup/indexedDB.d.ts +0 -1
  378. package/dist/cjs/v2/__tests__/setup/indexedDB.js +0 -4
  379. package/dist/cjs/v2/__tests__/setup/indexedDB.js.map +0 -1
  380. package/dist/cjs/v2/constants.d.ts +0 -1
  381. package/dist/cjs/v2/constants.js +0 -5
  382. package/dist/cjs/v2/constants.js.map +0 -1
  383. package/dist/cjs/v2/idb.d.ts +0 -6
  384. package/dist/cjs/v2/idb.js +0 -71
  385. package/dist/cjs/v2/idb.js.map +0 -1
  386. package/dist/cjs/v2/index.d.ts +0 -6
  387. package/dist/cjs/v2/index.js +0 -14
  388. package/dist/cjs/v2/index.js.map +0 -1
  389. package/dist/cjs/v2/indexes.d.ts +0 -3
  390. package/dist/cjs/v2/indexes.js +0 -20
  391. package/dist/cjs/v2/indexes.js.map +0 -1
  392. package/dist/cjs/v2/openDocumentDatabase.d.ts +0 -9
  393. package/dist/cjs/v2/openDocumentDatabase.js +0 -100
  394. package/dist/cjs/v2/openDocumentDatabase.js.map +0 -1
  395. package/dist/cjs/v2/types.d.ts +0 -3
  396. package/dist/cjs/v2/types.js +0 -3
  397. package/dist/cjs/v2/types.js.map +0 -1
  398. package/dist/esm/AckInfoStore.d.ts +0 -10
  399. package/dist/esm/AckInfoStore.js +0 -22
  400. package/dist/esm/AckInfoStore.js.map +0 -1
  401. package/dist/esm/BaselinesStore.d.ts +0 -10
  402. package/dist/esm/BaselinesStore.js +0 -32
  403. package/dist/esm/BaselinesStore.js.map +0 -1
  404. package/dist/esm/Entity.d.ts +0 -96
  405. package/dist/esm/Entity.js +0 -337
  406. package/dist/esm/Entity.js.map +0 -1
  407. package/dist/esm/EntityStore.d.ts +0 -36
  408. package/dist/esm/EntityStore.js +0 -168
  409. package/dist/esm/EntityStore.js.map +0 -1
  410. package/dist/esm/LocalHistoryStore.d.ts +0 -15
  411. package/dist/esm/LocalHistoryStore.js +0 -49
  412. package/dist/esm/LocalHistoryStore.js.map +0 -1
  413. package/dist/esm/LocalReplicaStore.d.ts +0 -13
  414. package/dist/esm/LocalReplicaStore.js +0 -42
  415. package/dist/esm/LocalReplicaStore.js.map +0 -1
  416. package/dist/esm/MessageCreator.d.ts +0 -19
  417. package/dist/esm/MessageCreator.js +0 -97
  418. package/dist/esm/MessageCreator.js.map +0 -1
  419. package/dist/esm/Metadata.d.ts +0 -91
  420. package/dist/esm/Metadata.js +0 -245
  421. package/dist/esm/Metadata.js.map +0 -1
  422. package/dist/esm/OperationsStore.d.ts +0 -38
  423. package/dist/esm/OperationsStore.js +0 -142
  424. package/dist/esm/OperationsStore.js.map +0 -1
  425. package/dist/esm/PresenceManager.d.ts +0 -30
  426. package/dist/esm/PresenceManager.js +0 -85
  427. package/dist/esm/PresenceManager.js.map +0 -1
  428. package/dist/esm/Query.d.ts +0 -26
  429. package/dist/esm/Query.js +0 -82
  430. package/dist/esm/Query.js.map +0 -1
  431. package/dist/esm/QueryMaker.d.ts +0 -18
  432. package/dist/esm/QueryMaker.js +0 -94
  433. package/dist/esm/QueryMaker.js.map +0 -1
  434. package/dist/esm/QueryStore.d.ts +0 -38
  435. package/dist/esm/QueryStore.js +0 -142
  436. package/dist/esm/QueryStore.js.map +0 -1
  437. package/dist/esm/SchemaStore.d.ts +0 -9
  438. package/dist/esm/SchemaStore.js +0 -31
  439. package/dist/esm/SchemaStore.js.map +0 -1
  440. package/dist/esm/Storage.d.ts +0 -147
  441. package/dist/esm/Storage.js +0 -341
  442. package/dist/esm/Storage.js.map +0 -1
  443. package/dist/esm/Sync.d.ts +0 -117
  444. package/dist/esm/Sync.js +0 -553
  445. package/dist/esm/Sync.js.map +0 -1
  446. package/dist/esm/SyncHarness.d.ts +0 -45
  447. package/dist/esm/SyncHarness.js +0 -105
  448. package/dist/esm/SyncHarness.js.map +0 -1
  449. package/dist/esm/metadata/LocalHistoryStore.d.ts +0 -15
  450. package/dist/esm/metadata/LocalHistoryStore.js +0 -49
  451. package/dist/esm/metadata/LocalHistoryStore.js.map +0 -1
  452. package/dist/esm/queries/LiveQuery.d.ts +0 -28
  453. package/dist/esm/queries/LiveQuery.js +0 -92
  454. package/dist/esm/queries/LiveQuery.js.map +0 -1
  455. package/dist/esm/queries/LiveQueryMaker.d.ts +0 -15
  456. package/dist/esm/queries/LiveQueryMaker.js +0 -38
  457. package/dist/esm/queries/LiveQueryMaker.js.map +0 -1
  458. package/dist/esm/queries/LiveQueryStore.d.ts +0 -33
  459. package/dist/esm/queries/LiveQueryStore.js +0 -81
  460. package/dist/esm/queries/LiveQueryStore.js.map +0 -1
  461. package/dist/esm/queries/Query.d.ts +0 -18
  462. package/dist/esm/queries/Query.js +0 -32
  463. package/dist/esm/queries/Query.js.map +0 -1
  464. package/dist/esm/queries/QueryMaker.d.ts +0 -14
  465. package/dist/esm/queries/QueryMaker.js +0 -38
  466. package/dist/esm/queries/QueryMaker.js.map +0 -1
  467. package/dist/esm/queries/QueryStore.d.ts +0 -35
  468. package/dist/esm/queries/QueryStore.js +0 -126
  469. package/dist/esm/queries/QueryStore.js.map +0 -1
  470. package/dist/esm/queries/ranges.d.ts +0 -2
  471. package/dist/esm/queries/ranges.js +0 -66
  472. package/dist/esm/queries/ranges.js.map +0 -1
  473. package/dist/esm/v2/AckInfoStore.d.ts +0 -10
  474. package/dist/esm/v2/AckInfoStore.js +0 -22
  475. package/dist/esm/v2/AckInfoStore.js.map +0 -1
  476. package/dist/esm/v2/BaselinesStore.d.ts +0 -10
  477. package/dist/esm/v2/BaselinesStore.js +0 -32
  478. package/dist/esm/v2/BaselinesStore.js.map +0 -1
  479. package/dist/esm/v2/DocumentManager.d.ts +0 -19
  480. package/dist/esm/v2/DocumentManager.js +0 -43
  481. package/dist/esm/v2/DocumentManager.js.map +0 -1
  482. package/dist/esm/v2/Entity.d.ts +0 -91
  483. package/dist/esm/v2/Entity.js +0 -305
  484. package/dist/esm/v2/Entity.js.map +0 -1
  485. package/dist/esm/v2/EntityStore.d.ts +0 -37
  486. package/dist/esm/v2/EntityStore.js +0 -166
  487. package/dist/esm/v2/EntityStore.js.map +0 -1
  488. package/dist/esm/v2/IDBService.d.ts +0 -7
  489. package/dist/esm/v2/IDBService.js +0 -22
  490. package/dist/esm/v2/IDBService.js.map +0 -1
  491. package/dist/esm/v2/LocalHistoryStore.d.ts +0 -15
  492. package/dist/esm/v2/LocalHistoryStore.js +0 -49
  493. package/dist/esm/v2/LocalHistoryStore.js.map +0 -1
  494. package/dist/esm/v2/LocalReplicaStore.d.ts +0 -14
  495. package/dist/esm/v2/LocalReplicaStore.js +0 -42
  496. package/dist/esm/v2/LocalReplicaStore.js.map +0 -1
  497. package/dist/esm/v2/MessageCreator.d.ts +0 -19
  498. package/dist/esm/v2/MessageCreator.js +0 -92
  499. package/dist/esm/v2/MessageCreator.js.map +0 -1
  500. package/dist/esm/v2/Metadata.d.ts +0 -90
  501. package/dist/esm/v2/Metadata.js +0 -246
  502. package/dist/esm/v2/Metadata.js.map +0 -1
  503. package/dist/esm/v2/OperationsStore.d.ts +0 -38
  504. package/dist/esm/v2/OperationsStore.js +0 -142
  505. package/dist/esm/v2/OperationsStore.js.map +0 -1
  506. package/dist/esm/v2/PresenceManager.d.ts +0 -24
  507. package/dist/esm/v2/PresenceManager.js +0 -69
  508. package/dist/esm/v2/PresenceManager.js.map +0 -1
  509. package/dist/esm/v2/Query.d.ts +0 -24
  510. package/dist/esm/v2/Query.js +0 -75
  511. package/dist/esm/v2/Query.js.map +0 -1
  512. package/dist/esm/v2/QueryMaker.d.ts +0 -16
  513. package/dist/esm/v2/QueryMaker.js +0 -80
  514. package/dist/esm/v2/QueryMaker.js.map +0 -1
  515. package/dist/esm/v2/QueryStore.d.ts +0 -26
  516. package/dist/esm/v2/QueryStore.js +0 -132
  517. package/dist/esm/v2/QueryStore.js.map +0 -1
  518. package/dist/esm/v2/SchemaStore.d.ts +0 -9
  519. package/dist/esm/v2/SchemaStore.js +0 -31
  520. package/dist/esm/v2/SchemaStore.js.map +0 -1
  521. package/dist/esm/v2/Storage.d.ts +0 -80
  522. package/dist/esm/v2/Storage.js +0 -149
  523. package/dist/esm/v2/Storage.js.map +0 -1
  524. package/dist/esm/v2/Sync.d.ts +0 -42
  525. package/dist/esm/v2/Sync.js +0 -94
  526. package/dist/esm/v2/Sync.js.map +0 -1
  527. package/dist/esm/v2/SyncHarness.d.ts +0 -45
  528. package/dist/esm/v2/SyncHarness.js +0 -105
  529. package/dist/esm/v2/SyncHarness.js.map +0 -1
  530. package/dist/esm/v2/__tests__/documents.test.d.ts +0 -1
  531. package/dist/esm/v2/__tests__/documents.test.js +0 -208
  532. package/dist/esm/v2/__tests__/documents.test.js.map +0 -1
  533. package/dist/esm/v2/__tests__/fixtures/testStorage.d.ts +0 -223
  534. package/dist/esm/v2/__tests__/fixtures/testStorage.js +0 -106
  535. package/dist/esm/v2/__tests__/fixtures/testStorage.js.map +0 -1
  536. package/dist/esm/v2/__tests__/queries.test.d.ts +0 -1
  537. package/dist/esm/v2/__tests__/queries.test.js +0 -90
  538. package/dist/esm/v2/__tests__/queries.test.js.map +0 -1
  539. package/dist/esm/v2/__tests__/setup/indexedDB.d.ts +0 -1
  540. package/dist/esm/v2/__tests__/setup/indexedDB.js +0 -2
  541. package/dist/esm/v2/__tests__/setup/indexedDB.js.map +0 -1
  542. package/dist/esm/v2/constants.d.ts +0 -1
  543. package/dist/esm/v2/constants.js +0 -2
  544. package/dist/esm/v2/constants.js.map +0 -1
  545. package/dist/esm/v2/idb.d.ts +0 -6
  546. package/dist/esm/v2/idb.js +0 -65
  547. package/dist/esm/v2/idb.js.map +0 -1
  548. package/dist/esm/v2/index.d.ts +0 -6
  549. package/dist/esm/v2/index.js +0 -5
  550. package/dist/esm/v2/index.js.map +0 -1
  551. package/dist/esm/v2/indexes.d.ts +0 -3
  552. package/dist/esm/v2/indexes.js +0 -15
  553. package/dist/esm/v2/indexes.js.map +0 -1
  554. package/dist/esm/v2/openDocumentDatabase.d.ts +0 -9
  555. package/dist/esm/v2/openDocumentDatabase.js +0 -96
  556. package/dist/esm/v2/openDocumentDatabase.js.map +0 -1
  557. package/dist/esm/v2/types.d.ts +0 -3
  558. package/dist/esm/v2/types.js +0 -2
  559. package/dist/esm/v2/types.js.map +0 -1
  560. /package/dist/esm/sync/{WebsocketSync.js.map → WebSocketSync.js.map} +0 -0
@@ -1,428 +1,428 @@
1
- import { addFieldDefaults, assignIndexValues, assignOidPropertiesToAllSubObjects, assignOidsToAllSubObjects, cloneDeep, createOid, decomposeOid, diffToPatches, initialToPatches, migrationRange, removeOidPropertiesFromAllSubObjects, removeOidsFromAllSubObjects, } from '@verdant-web/common';
2
- import { findAllOids, findOneOid } from './queries2/dbQueries.js';
3
- const globalIDB = typeof window !== 'undefined' ? window.indexedDB : undefined;
4
- export async function openDocumentDatabase({ version, indexedDB = globalIDB, migrations, meta, context, }) {
5
- const currentVersion = await getDatabaseVersion(indexedDB, context.namespace, version, context.log);
6
- context.log('Current database version:', currentVersion, 'target version:', version);
7
- const toRunVersions = migrationRange(currentVersion, version);
8
- const toRun = toRunVersions.map((ver) => migrations.find((m) => m.version === ver));
9
- if (toRun.some((m) => !m)) {
10
- throw new Error(`No migration found for version(s) ${toRunVersions}`);
11
- }
12
- if (toRun.length > 0) {
13
- await acquireLock(context.namespace, async () => {
14
- // now the fun part
15
- for (const migration of toRun) {
16
- // special case: if this is the version 1 migration, we have no pre-existing database
17
- // to use for the migration.
18
- let engine;
19
- if (migration.version === 1) {
20
- engine = getVersion1MigrationEngine({
21
- meta,
22
- migration,
23
- context,
24
- });
25
- await migration.migrate(engine);
26
- }
27
- else {
28
- // open the database with the current (old) version for this migration. this should
29
- // align with the database's current version.
30
- const originalDatabase = await openDatabase(indexedDB, context.namespace, migration.oldSchema.version);
31
- // this will only write to our metadata store via operations!
32
- engine = getMigrationEngine({
33
- meta,
34
- migration,
35
- context: Object.assign(Object.assign({}, context), { documentDb: originalDatabase }),
36
- });
37
- await migration.migrate(engine);
38
- // wait on any out-of-band async operations to complete
39
- await Promise.all(engine.awaitables);
40
- // now we have to open the database again with the next version and
41
- // make the appropriate schema changes during the upgrade.
42
- await closeDatabase(originalDatabase);
43
- }
44
- await upgradeDatabase(indexedDB, context.namespace, migration.newSchema.version, (transaction, db) => {
45
- for (const newCollection of migration.addedCollections) {
46
- db.createObjectStore(newCollection, {
47
- keyPath: migration.newSchema.collections[newCollection].primaryKey,
48
- autoIncrement: false,
49
- });
50
- }
51
- for (const collection of migration.allCollections) {
52
- const store = transaction.objectStore(collection);
53
- // apply new indexes
54
- for (const newIndex of migration.addedIndexes[collection] || []) {
55
- store.createIndex(newIndex.name, newIndex.name, {
56
- multiEntry: newIndex.multiEntry,
57
- });
58
- }
59
- // remove old indexes
60
- for (const oldIndex of migration.removedIndexes[collection] ||
61
- []) {
62
- store.deleteIndex(oldIndex.name);
63
- }
64
- }
65
- for (const removedCollection of migration.removedCollections) {
66
- // !! can't delete the store, because old operations that relate to
67
- // this store may still exist in history. instead, we can clear it out
68
- // and leave it in place
69
- transaction.objectStore(removedCollection).clear();
70
- }
71
- }, context.log);
72
- // once the schema is ready, we can write back the migrated documents
73
- const upgradedDatabase = await openDatabase(indexedDB, context.namespace, migration.newSchema.version);
74
- for (const collection of migration.allCollections) {
75
- // first step is to read in all the keys we need to rewrite
76
- const documentReadTransaction = upgradedDatabase.transaction(collection, 'readwrite');
77
- const readStore = documentReadTransaction.objectStore(collection);
78
- const keys = await getAllKeys(readStore);
79
- // map the keys to OIDs
80
- const oids = keys.map((key) => createOid(collection, `${key}`, []));
81
- oids.push(...engine.newOids.filter((oid) => {
82
- return decomposeOid(oid).collection === collection;
83
- }));
84
- const snapshots = await Promise.all(oids.map(async (oid) => {
85
- try {
86
- const snap = await meta.getDocumentSnapshot(oid);
87
- return [oid, snap];
88
- }
89
- catch (e) {
90
- // this seems to happen with baselines/ops which are not fully
91
- // cleaned up after deletion?
92
- context.log('error', 'Could not regenerate snapshot during migration for oid', oid, 'this document will not be preserved', e);
93
- return null;
94
- }
95
- }));
96
- const views = snapshots
97
- .filter((s) => !!s)
98
- .map(([oid, snapshot]) => {
99
- if (!snapshot)
100
- return [oid, undefined];
101
- const view = assignIndexValues(migration.newSchema.collections[collection], snapshot);
102
- // TODO: remove the need for this by only storing index values!
103
- assignOidPropertiesToAllSubObjects(view);
104
- return [oid, view];
105
- });
106
- // now we can write the documents back
107
- const documentWriteTransaction = upgradedDatabase.transaction(collection, 'readwrite');
108
- const writeStore = documentWriteTransaction.objectStore(collection);
109
- await Promise.all(views.map(([oid, view]) => {
110
- if (view) {
111
- return putView(writeStore, view);
112
- }
113
- else {
114
- const { id } = decomposeOid(oid);
115
- return deleteView(writeStore, id);
116
- }
117
- }));
118
- }
119
- await closeDatabase(upgradedDatabase);
1
+ import { addFieldDefaults, assignIndexValues, assignOidPropertiesToAllSubObjects, assignOidsToAllSubObjects, cloneDeep, createOid, decomposeOid, diffToPatches, initialToPatches, migrationRange, removeOidPropertiesFromAllSubObjects, removeOidsFromAllSubObjects, } from '@verdant-web/common';
2
+ import { findAllOids, findOneOid } from './queries2/dbQueries.js';
3
+ const globalIDB = typeof window !== 'undefined' ? window.indexedDB : undefined;
4
+ export async function openDocumentDatabase({ version, indexedDB = globalIDB, migrations, meta, context, }) {
5
+ const currentVersion = await getDatabaseVersion(indexedDB, context.namespace, version, context.log);
6
+ context.log('Current database version:', currentVersion, 'target version:', version);
7
+ const toRunVersions = migrationRange(currentVersion, version);
8
+ const toRun = toRunVersions.map((ver) => migrations.find((m) => m.version === ver));
9
+ if (toRun.some((m) => !m)) {
10
+ throw new Error(`No migration found for version(s) ${toRunVersions}`);
11
+ }
12
+ if (toRun.length > 0) {
13
+ await acquireLock(context.namespace, async () => {
14
+ // now the fun part
15
+ for (const migration of toRun) {
16
+ // special case: if this is the version 1 migration, we have no pre-existing database
17
+ // to use for the migration.
18
+ let engine;
19
+ if (migration.version === 1) {
20
+ engine = getVersion1MigrationEngine({
21
+ meta,
22
+ migration,
23
+ context,
24
+ });
25
+ await migration.migrate(engine);
26
+ }
27
+ else {
28
+ // open the database with the current (old) version for this migration. this should
29
+ // align with the database's current version.
30
+ const originalDatabase = await openDatabase(indexedDB, context.namespace, migration.oldSchema.version);
31
+ // this will only write to our metadata store via operations!
32
+ engine = getMigrationEngine({
33
+ meta,
34
+ migration,
35
+ context: Object.assign(Object.assign({}, context), { documentDb: originalDatabase }),
36
+ });
37
+ await migration.migrate(engine);
38
+ // wait on any out-of-band async operations to complete
39
+ await Promise.all(engine.awaitables);
40
+ // now we have to open the database again with the next version and
41
+ // make the appropriate schema changes during the upgrade.
42
+ await closeDatabase(originalDatabase);
43
+ }
44
+ await upgradeDatabase(indexedDB, context.namespace, migration.newSchema.version, (transaction, db) => {
45
+ for (const newCollection of migration.addedCollections) {
46
+ db.createObjectStore(newCollection, {
47
+ keyPath: migration.newSchema.collections[newCollection].primaryKey,
48
+ autoIncrement: false,
49
+ });
50
+ }
51
+ for (const collection of migration.allCollections) {
52
+ const store = transaction.objectStore(collection);
53
+ // apply new indexes
54
+ for (const newIndex of migration.addedIndexes[collection] || []) {
55
+ store.createIndex(newIndex.name, newIndex.name, {
56
+ multiEntry: newIndex.multiEntry,
57
+ });
58
+ }
59
+ // remove old indexes
60
+ for (const oldIndex of migration.removedIndexes[collection] ||
61
+ []) {
62
+ store.deleteIndex(oldIndex.name);
63
+ }
64
+ }
65
+ for (const removedCollection of migration.removedCollections) {
66
+ // !! can't delete the store, because old operations that relate to
67
+ // this store may still exist in history. instead, we can clear it out
68
+ // and leave it in place
69
+ transaction.objectStore(removedCollection).clear();
70
+ }
71
+ }, context.log);
72
+ // once the schema is ready, we can write back the migrated documents
73
+ const upgradedDatabase = await openDatabase(indexedDB, context.namespace, migration.newSchema.version);
74
+ for (const collection of migration.allCollections) {
75
+ // first step is to read in all the keys we need to rewrite
76
+ const documentReadTransaction = upgradedDatabase.transaction(collection, 'readwrite');
77
+ const readStore = documentReadTransaction.objectStore(collection);
78
+ const keys = await getAllKeys(readStore);
79
+ // map the keys to OIDs
80
+ const oids = keys.map((key) => createOid(collection, `${key}`, []));
81
+ oids.push(...engine.newOids.filter((oid) => {
82
+ return decomposeOid(oid).collection === collection;
83
+ }));
84
+ const snapshots = await Promise.all(oids.map(async (oid) => {
85
+ try {
86
+ const snap = await meta.getDocumentSnapshot(oid);
87
+ return [oid, snap];
88
+ }
89
+ catch (e) {
90
+ // this seems to happen with baselines/ops which are not fully
91
+ // cleaned up after deletion?
92
+ context.log('error', 'Could not regenerate snapshot during migration for oid', oid, 'this document will not be preserved', e);
93
+ return null;
94
+ }
95
+ }));
96
+ const views = snapshots
97
+ .filter((s) => !!s)
98
+ .map(([oid, snapshot]) => {
99
+ if (!snapshot)
100
+ return [oid, undefined];
101
+ const view = assignIndexValues(migration.newSchema.collections[collection], snapshot);
102
+ // TODO: remove the need for this by only storing index values!
103
+ assignOidPropertiesToAllSubObjects(view);
104
+ return [oid, view];
105
+ });
106
+ // now we can write the documents back
107
+ const documentWriteTransaction = upgradedDatabase.transaction(collection, 'readwrite');
108
+ const writeStore = documentWriteTransaction.objectStore(collection);
109
+ await Promise.all(views.map(([oid, view]) => {
110
+ if (view) {
111
+ return putView(writeStore, view);
112
+ }
113
+ else {
114
+ const { id } = decomposeOid(oid);
115
+ return deleteView(writeStore, id);
116
+ }
117
+ }));
118
+ }
119
+ await closeDatabase(upgradedDatabase);
120
120
  context.log(`
121
121
  ⬆️ v${migration.newSchema.version} Migration complete. Here's the rundown:
122
122
  - Added collections: ${migration.addedCollections.join(', ')}
123
123
  - Removed collections: ${migration.removedCollections.join(', ')}
124
124
  - Changed collections: ${migration.changedCollections.join(', ')}
125
- - New indexes: ${Object.keys(migration.addedIndexes)
126
- .map((col) => migration.addedIndexes[col].map((i) => `${col}.${i.name}`))
127
- .flatMap((i) => i)
125
+ - New indexes: ${Object.keys(migration.addedIndexes)
126
+ .map((col) => migration.addedIndexes[col].map((i) => `${col}.${i.name}`))
127
+ .flatMap((i) => i)
128
128
  .join(', ')}
129
- - Removed indexes: ${Object.keys(migration.removedIndexes)
130
- .map((col) => migration.removedIndexes[col].map((i) => `${col}.${i.name}`))
131
- .flatMap((i) => i)
129
+ - Removed indexes: ${Object.keys(migration.removedIndexes)
130
+ .map((col) => migration.removedIndexes[col].map((i) => `${col}.${i.name}`))
131
+ .flatMap((i) => i)
132
132
  .join(', ')}
133
- `);
134
- }
135
- });
136
- return openDatabase(indexedDB, context.namespace, version);
137
- }
138
- else {
139
- // just open the database
140
- return openDatabase(indexedDB, context.namespace, version);
141
- }
142
- }
143
- async function getDatabaseVersion(indexedDB, namespace, version, log) {
144
- function openAndGetVersion(resolve, reject) {
145
- let currentVersion;
146
- let database;
147
- const request = indexedDB.open([namespace, 'collections'].join('_'), version);
148
- request.onupgradeneeded = async (event) => {
149
- currentVersion = event.oldVersion;
150
- const transaction = request.transaction;
151
- database = request.result;
152
- transaction.abort();
153
- };
154
- request.onsuccess = (event) => {
155
- resolve([request.result.version, request.result]);
156
- };
157
- request.onblocked = (event) => {
158
- // retry if blocked
159
- log === null || log === void 0 ? void 0 : log('Database blocked, waiting...');
160
- // setTimeout(() => {
161
- // openAndGetVersion(resolve, reject);
162
- // }, 200);
163
- };
164
- request.onerror = (event) => {
165
- // FIXME: this fails if the code is older than the local database
166
- resolve([currentVersion, database]);
167
- };
168
- }
169
- const [currentVersion, db] = await new Promise(openAndGetVersion);
170
- await closeDatabase(db);
171
- return currentVersion;
172
- }
173
- async function openDatabase(indexedDb, namespace, version) {
174
- const db = await new Promise((resolve, reject) => {
175
- const request = indexedDb.open([namespace, 'collections'].join('_'), version);
176
- request.onupgradeneeded = async (event) => {
177
- const transaction = request.transaction;
178
- transaction.abort();
179
- reject(new Error('Migration error: database version changed while migrating'));
180
- };
181
- request.onsuccess = (event) => {
182
- resolve(request.result);
183
- };
184
- request.onblocked = (event) => {
185
- reject(new Error('Migration error: database blocked'));
186
- };
187
- request.onerror = (event) => {
188
- reject(new Error('Migration error: database error'));
189
- };
190
- });
191
- db.addEventListener('versionchange', (event) => {
192
- db.close();
193
- });
194
- return db;
195
- }
196
- function getMigrationMutations({ migration, meta, getMigrationNow, newOids, }) {
197
- return migration.allCollections.reduce((acc, collectionName) => {
198
- acc[collectionName] = {
199
- put: async (doc) => {
200
- // add defaults
201
- addFieldDefaults(migration.newSchema.collections[collectionName], doc);
202
- const primaryKey = doc[migration.newSchema.collections[collectionName].primaryKey];
203
- const oid = createOid(collectionName, primaryKey, []);
204
- newOids.push(oid);
205
- await meta.insertLocalOperation(initialToPatches(doc, oid, getMigrationNow));
206
- return doc;
207
- },
208
- delete: (id) => {
209
- const oid = createOid(collectionName, id, []);
210
- return meta.insertLocalOperation([
211
- {
212
- oid,
213
- timestamp: getMigrationNow(),
214
- data: { op: 'delete' },
215
- },
216
- ]);
217
- },
218
- };
219
- return acc;
220
- }, {});
221
- }
222
- function getMigrationEngine({ meta, migration, context, }) {
223
- function getMigrationNow() {
224
- return meta.time.zero(migration.version);
225
- }
226
- const newOids = new Array();
227
- const queries = migration.oldCollections.reduce((acc, collectionName) => {
228
- acc[collectionName] = {
229
- get: async (id) => {
230
- const oid = createOid(collectionName, id, []);
231
- const doc = await meta.getDocumentSnapshot(oid);
232
- removeOidsFromAllSubObjects(doc);
233
- return doc;
234
- },
235
- findOne: async (filter) => {
236
- const oid = await findOneOid({
237
- collection: collectionName,
238
- index: filter,
239
- context,
240
- });
241
- if (!oid)
242
- return null;
243
- const doc = await meta.getDocumentSnapshot(oid);
244
- removeOidsFromAllSubObjects(doc);
245
- return doc;
246
- },
247
- findAll: async (filter) => {
248
- const oids = await findAllOids({
249
- collection: collectionName,
250
- index: filter,
251
- context,
252
- });
253
- const docs = await Promise.all(oids.map((oid) => meta.getDocumentSnapshot(oid)));
254
- docs.forEach((doc) => removeOidsFromAllSubObjects(doc));
255
- return docs;
256
- },
257
- };
258
- return acc;
259
- }, {});
260
- const mutations = getMigrationMutations({
261
- migration,
262
- getMigrationNow,
263
- newOids,
264
- meta,
265
- });
266
- const awaitables = new Array();
267
- const engine = {
268
- newOids,
269
- migrate: async (collection, strategy) => {
270
- const docs = await new Promise((resolve, reject) => {
271
- const transaction = context.documentDb.transaction(collection, 'readonly');
272
- const store = transaction.objectStore(collection);
273
- const cursorReq = store.openCursor();
274
- const documentsToMigrate = [];
275
- cursorReq.onsuccess = async (event) => {
276
- const cursor = cursorReq.result;
277
- if (cursor) {
278
- documentsToMigrate.push(cursor.value);
279
- cursor.continue();
280
- }
281
- else {
282
- resolve(documentsToMigrate);
283
- }
284
- };
285
- cursorReq.onerror = (event) => {
286
- reject(cursorReq.error);
287
- };
288
- });
289
- await Promise.all(docs.map(async (doc) => {
290
- const original = cloneDeep(doc);
291
- // remove any indexes before computing the diff
292
- const collectionSpec = migration.oldSchema.collections[collection];
293
- const indexKeys = [
294
- ...Object.keys(collectionSpec.synthetics || {}),
295
- ...Object.keys(collectionSpec.compounds || {}),
296
- ];
297
- indexKeys.forEach((key) => {
298
- delete doc[key];
299
- });
300
- // @ts-ignore - excessive type resolution
301
- const newValue = await strategy(doc);
302
- if (newValue) {
303
- // the migration has altered the shape of our document. we need
304
- // to create the operation from the diff and write it to meta as
305
- // a migration patch
306
- removeOidPropertiesFromAllSubObjects(original);
307
- removeOidPropertiesFromAllSubObjects(newValue);
308
- assignOidsToAllSubObjects(newValue);
309
- const patches = diffToPatches(original, newValue, getMigrationNow, [], undefined, [], {
310
- mergeUnknownObjects: true,
311
- });
312
- if (patches.length > 0) {
313
- await meta.insertLocalOperation(patches);
314
- }
315
- }
316
- }));
317
- },
318
- queries,
319
- mutations,
320
- awaitables,
321
- };
322
- return engine;
323
- }
324
- function getVersion1MigrationEngine({ meta, migration, }) {
325
- function getMigrationNow() {
326
- return meta.time.zero(migration.version);
327
- }
328
- const newOids = new Array();
329
- const queries = new Proxy({}, {
330
- get() {
331
- throw new Error('Queries are not available in version 1 migrations; there is no database yet!');
332
- },
333
- });
334
- const mutations = getMigrationMutations({
335
- migration,
336
- getMigrationNow,
337
- newOids,
338
- meta,
339
- });
340
- const engine = {
341
- newOids,
342
- migrate: (collection, strategy) => {
343
- throw new Error('Calling migrate() in version 1 migrations is not supported! Use version 1 migrations to seed initial data using mutations.');
344
- },
345
- queries,
346
- mutations,
347
- awaitables: [],
348
- };
349
- return engine;
350
- }
351
- async function closeDatabase(db) {
352
- db.close();
353
- // FIXME: this isn't right!!!!
354
- await new Promise((resolve) => resolve());
355
- }
356
- async function upgradeDatabase(indexedDb, namespace, version, upgrader, log) {
357
- function openAndUpgrade(resolve, reject) {
358
- const request = indexedDb.open([namespace, 'collections'].join('_'), version);
359
- let wasUpgraded = false;
360
- request.onupgradeneeded = (event) => {
361
- const transaction = request.transaction;
362
- upgrader(transaction, request.result, event);
363
- wasUpgraded = true;
364
- };
365
- request.onsuccess = (event) => {
366
- request.result.close();
367
- if (wasUpgraded) {
368
- resolve();
369
- }
370
- else {
371
- reject(new Error('Database was not upgraded when a version change was expected'));
372
- }
373
- };
374
- request.onerror = (event) => {
375
- reject(request.error || new Error('Unknown error'));
376
- };
377
- request.onblocked = (event) => {
378
- log === null || log === void 0 ? void 0 : log('Database upgrade blocked, waiting...');
379
- // setTimeout(() => {
380
- // openAndUpgrade(resolve, reject);
381
- // }, 200);
382
- };
383
- }
384
- return new Promise(openAndUpgrade);
385
- }
386
- async function getAllKeys(store) {
387
- return new Promise((resolve, reject) => {
388
- const request = store.getAllKeys();
389
- request.onsuccess = (event) => {
390
- resolve(request.result);
391
- };
392
- request.onerror = (event) => {
393
- reject(request.error);
394
- };
395
- });
396
- }
397
- async function deleteView(store, id) {
398
- const request = store.delete(id);
399
- return new Promise((resolve, reject) => {
400
- request.onsuccess = (event) => {
401
- resolve();
402
- };
403
- request.onerror = (event) => {
404
- reject(request.error);
405
- };
406
- });
407
- }
408
- async function putView(store, view) {
409
- const request = store.put(view);
410
- return new Promise((resolve, reject) => {
411
- request.onsuccess = (event) => {
412
- resolve();
413
- };
414
- request.onerror = (event) => {
415
- reject(request.error);
416
- };
417
- });
418
- }
419
- async function acquireLock(namespace, procedure) {
420
- if (typeof navigator !== 'undefined' && navigator.locks) {
421
- await navigator.locks.request(`lo-fi_migration_${namespace}`, procedure);
422
- }
423
- else {
424
- // TODO: is there a fallback?
425
- await procedure();
426
- }
427
- }
133
+ `);
134
+ }
135
+ });
136
+ return openDatabase(indexedDB, context.namespace, version);
137
+ }
138
+ else {
139
+ // just open the database
140
+ return openDatabase(indexedDB, context.namespace, version);
141
+ }
142
+ }
143
+ async function getDatabaseVersion(indexedDB, namespace, version, log) {
144
+ function openAndGetVersion(resolve, reject) {
145
+ let currentVersion;
146
+ let database;
147
+ const request = indexedDB.open([namespace, 'collections'].join('_'), version);
148
+ request.onupgradeneeded = async (event) => {
149
+ currentVersion = event.oldVersion;
150
+ const transaction = request.transaction;
151
+ database = request.result;
152
+ transaction.abort();
153
+ };
154
+ request.onsuccess = (event) => {
155
+ resolve([request.result.version, request.result]);
156
+ };
157
+ request.onblocked = (event) => {
158
+ // retry if blocked
159
+ log === null || log === void 0 ? void 0 : log('Database blocked, waiting...');
160
+ // setTimeout(() => {
161
+ // openAndGetVersion(resolve, reject);
162
+ // }, 200);
163
+ };
164
+ request.onerror = (event) => {
165
+ // FIXME: this fails if the code is older than the local database
166
+ resolve([currentVersion, database]);
167
+ };
168
+ }
169
+ const [currentVersion, db] = await new Promise(openAndGetVersion);
170
+ await closeDatabase(db);
171
+ return currentVersion;
172
+ }
173
+ async function openDatabase(indexedDb, namespace, version) {
174
+ const db = await new Promise((resolve, reject) => {
175
+ const request = indexedDb.open([namespace, 'collections'].join('_'), version);
176
+ request.onupgradeneeded = async (event) => {
177
+ const transaction = request.transaction;
178
+ transaction.abort();
179
+ reject(new Error('Migration error: database version changed while migrating'));
180
+ };
181
+ request.onsuccess = (event) => {
182
+ resolve(request.result);
183
+ };
184
+ request.onblocked = (event) => {
185
+ reject(new Error('Migration error: database blocked'));
186
+ };
187
+ request.onerror = (event) => {
188
+ reject(new Error('Migration error: database error'));
189
+ };
190
+ });
191
+ db.addEventListener('versionchange', (event) => {
192
+ db.close();
193
+ });
194
+ return db;
195
+ }
196
+ function getMigrationMutations({ migration, meta, getMigrationNow, newOids, }) {
197
+ return migration.allCollections.reduce((acc, collectionName) => {
198
+ acc[collectionName] = {
199
+ put: async (doc) => {
200
+ // add defaults
201
+ addFieldDefaults(migration.newSchema.collections[collectionName], doc);
202
+ const primaryKey = doc[migration.newSchema.collections[collectionName].primaryKey];
203
+ const oid = createOid(collectionName, primaryKey, []);
204
+ newOids.push(oid);
205
+ await meta.insertLocalOperation(initialToPatches(doc, oid, getMigrationNow));
206
+ return doc;
207
+ },
208
+ delete: (id) => {
209
+ const oid = createOid(collectionName, id, []);
210
+ return meta.insertLocalOperation([
211
+ {
212
+ oid,
213
+ timestamp: getMigrationNow(),
214
+ data: { op: 'delete' },
215
+ },
216
+ ]);
217
+ },
218
+ };
219
+ return acc;
220
+ }, {});
221
+ }
222
+ function getMigrationEngine({ meta, migration, context, }) {
223
+ function getMigrationNow() {
224
+ return meta.time.zero(migration.version);
225
+ }
226
+ const newOids = new Array();
227
+ const queries = migration.oldCollections.reduce((acc, collectionName) => {
228
+ acc[collectionName] = {
229
+ get: async (id) => {
230
+ const oid = createOid(collectionName, id, []);
231
+ const doc = await meta.getDocumentSnapshot(oid);
232
+ removeOidsFromAllSubObjects(doc);
233
+ return doc;
234
+ },
235
+ findOne: async (filter) => {
236
+ const oid = await findOneOid({
237
+ collection: collectionName,
238
+ index: filter,
239
+ context,
240
+ });
241
+ if (!oid)
242
+ return null;
243
+ const doc = await meta.getDocumentSnapshot(oid);
244
+ removeOidsFromAllSubObjects(doc);
245
+ return doc;
246
+ },
247
+ findAll: async (filter) => {
248
+ const oids = await findAllOids({
249
+ collection: collectionName,
250
+ index: filter,
251
+ context,
252
+ });
253
+ const docs = await Promise.all(oids.map((oid) => meta.getDocumentSnapshot(oid)));
254
+ docs.forEach((doc) => removeOidsFromAllSubObjects(doc));
255
+ return docs;
256
+ },
257
+ };
258
+ return acc;
259
+ }, {});
260
+ const mutations = getMigrationMutations({
261
+ migration,
262
+ getMigrationNow,
263
+ newOids,
264
+ meta,
265
+ });
266
+ const awaitables = new Array();
267
+ const engine = {
268
+ newOids,
269
+ migrate: async (collection, strategy) => {
270
+ const docs = await new Promise((resolve, reject) => {
271
+ const transaction = context.documentDb.transaction(collection, 'readonly');
272
+ const store = transaction.objectStore(collection);
273
+ const cursorReq = store.openCursor();
274
+ const documentsToMigrate = [];
275
+ cursorReq.onsuccess = async (event) => {
276
+ const cursor = cursorReq.result;
277
+ if (cursor) {
278
+ documentsToMigrate.push(cursor.value);
279
+ cursor.continue();
280
+ }
281
+ else {
282
+ resolve(documentsToMigrate);
283
+ }
284
+ };
285
+ cursorReq.onerror = (event) => {
286
+ reject(cursorReq.error);
287
+ };
288
+ });
289
+ await Promise.all(docs.map(async (doc) => {
290
+ const original = cloneDeep(doc);
291
+ // remove any indexes before computing the diff
292
+ const collectionSpec = migration.oldSchema.collections[collection];
293
+ const indexKeys = [
294
+ ...Object.keys(collectionSpec.synthetics || {}),
295
+ ...Object.keys(collectionSpec.compounds || {}),
296
+ ];
297
+ indexKeys.forEach((key) => {
298
+ delete doc[key];
299
+ });
300
+ // @ts-ignore - excessive type resolution
301
+ const newValue = await strategy(doc);
302
+ if (newValue) {
303
+ // the migration has altered the shape of our document. we need
304
+ // to create the operation from the diff and write it to meta as
305
+ // a migration patch
306
+ removeOidPropertiesFromAllSubObjects(original);
307
+ removeOidPropertiesFromAllSubObjects(newValue);
308
+ assignOidsToAllSubObjects(newValue);
309
+ const patches = diffToPatches(original, newValue, getMigrationNow, [], undefined, [], {
310
+ mergeUnknownObjects: true,
311
+ });
312
+ if (patches.length > 0) {
313
+ await meta.insertLocalOperation(patches);
314
+ }
315
+ }
316
+ }));
317
+ },
318
+ queries,
319
+ mutations,
320
+ awaitables,
321
+ };
322
+ return engine;
323
+ }
324
+ function getVersion1MigrationEngine({ meta, migration, }) {
325
+ function getMigrationNow() {
326
+ return meta.time.zero(migration.version);
327
+ }
328
+ const newOids = new Array();
329
+ const queries = new Proxy({}, {
330
+ get() {
331
+ throw new Error('Queries are not available in version 1 migrations; there is no database yet!');
332
+ },
333
+ });
334
+ const mutations = getMigrationMutations({
335
+ migration,
336
+ getMigrationNow,
337
+ newOids,
338
+ meta,
339
+ });
340
+ const engine = {
341
+ newOids,
342
+ migrate: (collection, strategy) => {
343
+ throw new Error('Calling migrate() in version 1 migrations is not supported! Use version 1 migrations to seed initial data using mutations.');
344
+ },
345
+ queries,
346
+ mutations,
347
+ awaitables: [],
348
+ };
349
+ return engine;
350
+ }
351
+ async function closeDatabase(db) {
352
+ db.close();
353
+ // FIXME: this isn't right!!!!
354
+ await new Promise((resolve) => resolve());
355
+ }
356
+ async function upgradeDatabase(indexedDb, namespace, version, upgrader, log) {
357
+ function openAndUpgrade(resolve, reject) {
358
+ const request = indexedDb.open([namespace, 'collections'].join('_'), version);
359
+ let wasUpgraded = false;
360
+ request.onupgradeneeded = (event) => {
361
+ const transaction = request.transaction;
362
+ upgrader(transaction, request.result, event);
363
+ wasUpgraded = true;
364
+ };
365
+ request.onsuccess = (event) => {
366
+ request.result.close();
367
+ if (wasUpgraded) {
368
+ resolve();
369
+ }
370
+ else {
371
+ reject(new Error('Database was not upgraded when a version change was expected'));
372
+ }
373
+ };
374
+ request.onerror = (event) => {
375
+ reject(request.error || new Error('Unknown error'));
376
+ };
377
+ request.onblocked = (event) => {
378
+ log === null || log === void 0 ? void 0 : log('Database upgrade blocked, waiting...');
379
+ // setTimeout(() => {
380
+ // openAndUpgrade(resolve, reject);
381
+ // }, 200);
382
+ };
383
+ }
384
+ return new Promise(openAndUpgrade);
385
+ }
386
+ async function getAllKeys(store) {
387
+ return new Promise((resolve, reject) => {
388
+ const request = store.getAllKeys();
389
+ request.onsuccess = (event) => {
390
+ resolve(request.result);
391
+ };
392
+ request.onerror = (event) => {
393
+ reject(request.error);
394
+ };
395
+ });
396
+ }
397
+ async function deleteView(store, id) {
398
+ const request = store.delete(id);
399
+ return new Promise((resolve, reject) => {
400
+ request.onsuccess = (event) => {
401
+ resolve();
402
+ };
403
+ request.onerror = (event) => {
404
+ reject(request.error);
405
+ };
406
+ });
407
+ }
408
+ async function putView(store, view) {
409
+ const request = store.put(view);
410
+ return new Promise((resolve, reject) => {
411
+ request.onsuccess = (event) => {
412
+ resolve();
413
+ };
414
+ request.onerror = (event) => {
415
+ reject(request.error);
416
+ };
417
+ });
418
+ }
419
+ async function acquireLock(namespace, procedure) {
420
+ if (typeof navigator !== 'undefined' && navigator.locks) {
421
+ await navigator.locks.request(`lo-fi_migration_${namespace}`, procedure);
422
+ }
423
+ else {
424
+ // TODO: is there a fallback?
425
+ await procedure();
426
+ }
427
+ }
428
428
  //# sourceMappingURL=openDocumentDatabase.js.map