@synchronized-console/objectloader2 2.25.7 → 2.31.14
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.
- package/dist/commonjs/{operations → core}/interfaces.d.ts +5 -7
- package/dist/commonjs/core/interfaces.d.ts.map +1 -0
- package/dist/commonjs/core/interfaces.js.map +1 -0
- package/dist/commonjs/{operations → core}/objectLoader2.d.ts +1 -1
- package/dist/commonjs/core/objectLoader2.d.ts.map +1 -0
- package/dist/commonjs/core/objectLoader2.js +120 -0
- package/dist/commonjs/core/objectLoader2.js.map +1 -0
- package/dist/{esm/operations → commonjs/core}/objectLoader2Factory.d.ts +10 -2
- package/dist/commonjs/core/objectLoader2Factory.d.ts.map +1 -0
- package/dist/commonjs/core/objectLoader2Factory.js +86 -0
- package/dist/commonjs/core/objectLoader2Factory.js.map +1 -0
- package/dist/commonjs/core/objectLoader2Factory.test.d.ts +2 -0
- package/dist/commonjs/core/objectLoader2Factory.test.d.ts.map +1 -0
- package/dist/commonjs/core/objectLoader2Factory.test.js +106 -0
- package/dist/commonjs/core/objectLoader2Factory.test.js.map +1 -0
- package/dist/{esm/operations → commonjs/core}/options.d.ts +4 -1
- package/dist/commonjs/core/options.d.ts.map +1 -0
- package/dist/commonjs/{operations → core}/options.js.map +1 -1
- package/dist/commonjs/core/stages/cacheReader.d.ts +18 -0
- package/dist/commonjs/core/stages/cacheReader.d.ts.map +1 -0
- package/dist/commonjs/core/stages/cacheReader.js +72 -0
- package/dist/commonjs/core/stages/cacheReader.js.map +1 -0
- package/dist/commonjs/core/stages/cacheWriter.d.ts +15 -0
- package/dist/commonjs/core/stages/cacheWriter.d.ts.map +1 -0
- package/dist/commonjs/core/stages/cacheWriter.js +50 -0
- package/dist/commonjs/core/stages/cacheWriter.js.map +1 -0
- package/dist/commonjs/core/stages/indexedDatabase.d.ts +34 -0
- package/dist/commonjs/core/stages/indexedDatabase.d.ts.map +1 -0
- package/dist/commonjs/core/stages/indexedDatabase.js +150 -0
- package/dist/commonjs/core/stages/indexedDatabase.js.map +1 -0
- package/dist/commonjs/core/stages/memory/memoryDatabase.d.ts +11 -0
- package/dist/commonjs/core/stages/memory/memoryDatabase.d.ts.map +1 -0
- package/dist/commonjs/{operations/databases → core/stages/memory}/memoryDatabase.js +6 -3
- package/dist/commonjs/core/stages/memory/memoryDatabase.js.map +1 -0
- package/dist/commonjs/{operations/downloaders → core/stages/memory}/memoryDownloader.d.ts +4 -4
- package/dist/commonjs/core/stages/memory/memoryDownloader.d.ts.map +1 -0
- package/dist/commonjs/{operations/downloaders → core/stages/memory}/memoryDownloader.js +1 -1
- package/dist/commonjs/core/stages/memory/memoryDownloader.js.map +1 -0
- package/dist/{esm/operations/downloaders → commonjs/core/stages}/serverDownloader.d.ts +8 -6
- package/dist/commonjs/core/stages/serverDownloader.d.ts.map +1 -0
- package/dist/commonjs/{operations/downloaders → core/stages}/serverDownloader.js +99 -50
- package/dist/commonjs/core/stages/serverDownloader.js.map +1 -0
- package/dist/commonjs/core/traverser.d.ts.map +1 -0
- package/dist/commonjs/{operations → core}/traverser.js +7 -7
- package/dist/commonjs/core/traverser.js.map +1 -0
- package/dist/commonjs/deferment/MemoryCache.d.ts +35 -0
- package/dist/commonjs/deferment/MemoryCache.d.ts.map +1 -0
- package/dist/commonjs/deferment/MemoryCache.js +162 -0
- package/dist/commonjs/deferment/MemoryCache.js.map +1 -0
- package/dist/commonjs/deferment/MemoryCache.test.d.ts +2 -0
- package/dist/commonjs/deferment/MemoryCache.test.d.ts.map +1 -0
- package/dist/commonjs/deferment/MemoryCache.test.js +153 -0
- package/dist/commonjs/deferment/MemoryCache.test.js.map +1 -0
- package/dist/commonjs/deferment/defermentManager.d.ts +32 -0
- package/dist/commonjs/deferment/defermentManager.d.ts.map +1 -0
- package/dist/commonjs/deferment/defermentManager.js +85 -0
- package/dist/commonjs/deferment/defermentManager.js.map +1 -0
- package/dist/commonjs/deferment/defermentManager.test.d.ts +2 -0
- package/dist/commonjs/deferment/defermentManager.test.d.ts.map +1 -0
- package/dist/commonjs/deferment/defermentManager.test.js +193 -0
- package/dist/commonjs/deferment/defermentManager.test.js.map +1 -0
- package/dist/commonjs/deferment/deferredBase.d.ts +12 -0
- package/dist/commonjs/deferment/deferredBase.d.ts.map +1 -0
- package/dist/commonjs/deferment/deferredBase.js +27 -0
- package/dist/commonjs/deferment/deferredBase.js.map +1 -0
- package/dist/commonjs/index.d.ts +4 -2
- package/dist/commonjs/index.d.ts.map +1 -1
- package/dist/commonjs/index.js +6 -3
- package/dist/commonjs/index.js.map +1 -1
- package/dist/commonjs/{helpers → queues}/aggregateQueue.d.ts +2 -1
- package/dist/commonjs/queues/aggregateQueue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/aggregateQueue.js +4 -0
- package/dist/commonjs/queues/aggregateQueue.js.map +1 -0
- package/dist/{esm/helpers → commonjs/queues}/asyncGeneratorQueue.d.ts +1 -1
- package/dist/commonjs/queues/asyncGeneratorQueue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/asyncGeneratorQueue.js +2 -1
- package/dist/commonjs/queues/asyncGeneratorQueue.js.map +1 -0
- package/dist/commonjs/{helpers → queues}/batchingQueue.d.ts +4 -1
- package/dist/commonjs/queues/batchingQueue.d.ts.map +1 -0
- package/dist/commonjs/queues/batchingQueue.dispose.test.d.ts +2 -0
- package/dist/commonjs/queues/batchingQueue.dispose.test.d.ts.map +1 -0
- package/dist/commonjs/queues/batchingQueue.dispose.test.js +62 -0
- package/dist/commonjs/queues/batchingQueue.dispose.test.js.map +1 -0
- package/dist/commonjs/queues/batchingQueue.js +128 -0
- package/dist/commonjs/queues/batchingQueue.js.map +1 -0
- package/dist/commonjs/queues/batchingQueue.test.d.ts +2 -0
- package/dist/commonjs/queues/batchingQueue.test.d.ts.map +1 -0
- package/dist/commonjs/queues/batchingQueue.test.js +236 -0
- package/dist/commonjs/queues/batchingQueue.test.js.map +1 -0
- package/dist/{esm/helpers → commonjs/queues}/bufferQueue.d.ts +1 -0
- package/dist/commonjs/queues/bufferQueue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/bufferQueue.js +3 -0
- package/dist/commonjs/queues/bufferQueue.js.map +1 -0
- package/dist/commonjs/{helpers → queues}/keyedQueue.d.ts +1 -0
- package/dist/commonjs/queues/keyedQueue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/keyedQueue.js +11 -0
- package/dist/commonjs/queues/keyedQueue.js.map +1 -0
- package/dist/commonjs/queues/keyedQueue.test.d.ts +2 -0
- package/dist/commonjs/queues/keyedQueue.test.d.ts.map +1 -0
- package/dist/commonjs/queues/keyedQueue.test.js +118 -0
- package/dist/commonjs/queues/keyedQueue.test.js.map +1 -0
- package/dist/commonjs/queues/queue.d.ts +5 -0
- package/dist/commonjs/queues/queue.d.ts.map +1 -0
- package/dist/commonjs/{helpers → queues}/queue.js.map +1 -1
- package/dist/commonjs/types/functions.d.ts +21 -0
- package/dist/commonjs/types/functions.d.ts.map +1 -0
- package/dist/commonjs/types/functions.js +92 -0
- package/dist/commonjs/types/functions.js.map +1 -0
- package/dist/commonjs/types/types.d.ts +6 -7
- package/dist/commonjs/types/types.d.ts.map +1 -1
- package/dist/commonjs/types/types.js +0 -36
- package/dist/commonjs/types/types.js.map +1 -1
- package/dist/esm/{operations → core}/interfaces.d.ts +5 -7
- package/dist/esm/core/interfaces.d.ts.map +1 -0
- package/dist/esm/core/interfaces.js.map +1 -0
- package/dist/esm/{operations → core}/objectLoader2.d.ts +1 -1
- package/dist/esm/core/objectLoader2.d.ts.map +1 -0
- package/dist/esm/core/objectLoader2.js +113 -0
- package/dist/esm/core/objectLoader2.js.map +1 -0
- package/dist/{commonjs/operations → esm/core}/objectLoader2Factory.d.ts +10 -2
- package/dist/esm/core/objectLoader2Factory.d.ts.map +1 -0
- package/dist/esm/core/objectLoader2Factory.js +79 -0
- package/dist/esm/core/objectLoader2Factory.js.map +1 -0
- package/dist/esm/core/objectLoader2Factory.test.d.ts +2 -0
- package/dist/esm/core/objectLoader2Factory.test.d.ts.map +1 -0
- package/dist/esm/core/objectLoader2Factory.test.js +104 -0
- package/dist/esm/core/objectLoader2Factory.test.js.map +1 -0
- package/dist/{commonjs/operations → esm/core}/options.d.ts +4 -1
- package/dist/esm/core/options.d.ts.map +1 -0
- package/dist/esm/{operations → core}/options.js.map +1 -1
- package/dist/esm/core/stages/cacheReader.d.ts +18 -0
- package/dist/esm/core/stages/cacheReader.d.ts.map +1 -0
- package/dist/esm/core/stages/cacheReader.js +65 -0
- package/dist/esm/core/stages/cacheReader.js.map +1 -0
- package/dist/esm/core/stages/cacheWriter.d.ts +15 -0
- package/dist/esm/core/stages/cacheWriter.d.ts.map +1 -0
- package/dist/esm/core/stages/cacheWriter.js +43 -0
- package/dist/esm/core/stages/cacheWriter.js.map +1 -0
- package/dist/esm/core/stages/indexedDatabase.d.ts +34 -0
- package/dist/esm/core/stages/indexedDatabase.d.ts.map +1 -0
- package/dist/esm/core/stages/indexedDatabase.js +146 -0
- package/dist/esm/core/stages/indexedDatabase.js.map +1 -0
- package/dist/esm/core/stages/memory/memoryDatabase.d.ts +11 -0
- package/dist/esm/core/stages/memory/memoryDatabase.d.ts.map +1 -0
- package/dist/esm/{operations/databases → core/stages/memory}/memoryDatabase.js +6 -3
- package/dist/esm/core/stages/memory/memoryDatabase.js.map +1 -0
- package/dist/esm/{operations/downloaders → core/stages/memory}/memoryDownloader.d.ts +4 -4
- package/dist/esm/core/stages/memory/memoryDownloader.d.ts.map +1 -0
- package/dist/esm/{operations/downloaders → core/stages/memory}/memoryDownloader.js +1 -1
- package/dist/esm/core/stages/memory/memoryDownloader.js.map +1 -0
- package/dist/{commonjs/operations/downloaders → esm/core/stages}/serverDownloader.d.ts +8 -6
- package/dist/esm/core/stages/serverDownloader.d.ts.map +1 -0
- package/dist/esm/{operations/downloaders → core/stages}/serverDownloader.js +98 -49
- package/dist/esm/core/stages/serverDownloader.js.map +1 -0
- package/dist/esm/core/traverser.d.ts.map +1 -0
- package/dist/esm/{operations → core}/traverser.js +1 -1
- package/dist/esm/core/traverser.js.map +1 -0
- package/dist/esm/deferment/MemoryCache.d.ts +35 -0
- package/dist/esm/deferment/MemoryCache.d.ts.map +1 -0
- package/dist/esm/deferment/MemoryCache.js +157 -0
- package/dist/esm/deferment/MemoryCache.js.map +1 -0
- package/dist/esm/deferment/MemoryCache.test.d.ts +2 -0
- package/dist/esm/deferment/MemoryCache.test.d.ts.map +1 -0
- package/dist/esm/deferment/MemoryCache.test.js +151 -0
- package/dist/esm/deferment/MemoryCache.test.js.map +1 -0
- package/dist/esm/deferment/defermentManager.d.ts +32 -0
- package/dist/esm/deferment/defermentManager.d.ts.map +1 -0
- package/dist/esm/deferment/defermentManager.js +80 -0
- package/dist/esm/deferment/defermentManager.js.map +1 -0
- package/dist/esm/deferment/defermentManager.test.d.ts +2 -0
- package/dist/esm/deferment/defermentManager.test.d.ts.map +1 -0
- package/dist/esm/deferment/defermentManager.test.js +191 -0
- package/dist/esm/deferment/defermentManager.test.js.map +1 -0
- package/dist/esm/deferment/deferredBase.d.ts +12 -0
- package/dist/esm/deferment/deferredBase.d.ts.map +1 -0
- package/dist/esm/deferment/deferredBase.js +23 -0
- package/dist/esm/deferment/deferredBase.js.map +1 -0
- package/dist/esm/index.d.ts +4 -2
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +3 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/{helpers → queues}/aggregateQueue.d.ts +2 -1
- package/dist/esm/queues/aggregateQueue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/aggregateQueue.js +4 -0
- package/dist/esm/queues/aggregateQueue.js.map +1 -0
- package/dist/{commonjs/helpers → esm/queues}/asyncGeneratorQueue.d.ts +1 -1
- package/dist/esm/queues/asyncGeneratorQueue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/asyncGeneratorQueue.js +2 -1
- package/dist/esm/queues/asyncGeneratorQueue.js.map +1 -0
- package/dist/esm/{helpers → queues}/batchingQueue.d.ts +4 -1
- package/dist/esm/queues/batchingQueue.d.ts.map +1 -0
- package/dist/esm/queues/batchingQueue.dispose.test.d.ts +2 -0
- package/dist/esm/queues/batchingQueue.dispose.test.d.ts.map +1 -0
- package/dist/esm/queues/batchingQueue.dispose.test.js +57 -0
- package/dist/esm/queues/batchingQueue.dispose.test.js.map +1 -0
- package/dist/esm/queues/batchingQueue.js +122 -0
- package/dist/esm/queues/batchingQueue.js.map +1 -0
- package/dist/esm/queues/batchingQueue.test.d.ts +2 -0
- package/dist/esm/queues/batchingQueue.test.d.ts.map +1 -0
- package/dist/esm/queues/batchingQueue.test.js +231 -0
- package/dist/esm/queues/batchingQueue.test.js.map +1 -0
- package/dist/{commonjs/helpers → esm/queues}/bufferQueue.d.ts +1 -0
- package/dist/esm/queues/bufferQueue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/bufferQueue.js +3 -0
- package/dist/esm/queues/bufferQueue.js.map +1 -0
- package/dist/esm/{helpers → queues}/keyedQueue.d.ts +1 -0
- package/dist/esm/queues/keyedQueue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/keyedQueue.js +11 -0
- package/dist/esm/queues/keyedQueue.js.map +1 -0
- package/dist/esm/queues/keyedQueue.test.d.ts +2 -0
- package/dist/esm/queues/keyedQueue.test.d.ts.map +1 -0
- package/dist/esm/queues/keyedQueue.test.js +113 -0
- package/dist/esm/queues/keyedQueue.test.js.map +1 -0
- package/dist/esm/queues/queue.d.ts +5 -0
- package/dist/esm/queues/queue.d.ts.map +1 -0
- package/dist/esm/{helpers → queues}/queue.js.map +1 -1
- package/dist/esm/types/functions.d.ts +21 -0
- package/dist/esm/types/functions.d.ts.map +1 -0
- package/dist/esm/types/functions.js +83 -0
- package/dist/esm/types/functions.js.map +1 -0
- package/dist/esm/types/types.d.ts +6 -7
- package/dist/esm/types/types.d.ts.map +1 -1
- package/dist/esm/types/types.js +1 -32
- package/dist/esm/types/types.js.map +1 -1
- package/package.json +5 -3
- package/src/{operations → core}/interfaces.ts +5 -5
- package/src/{operations → core}/objectLoader2.spec.ts +31 -11
- package/src/core/objectLoader2.ts +152 -0
- package/src/core/objectLoader2Factory.test.ts +135 -0
- package/src/core/objectLoader2Factory.ts +113 -0
- package/src/{operations → core}/options.ts +4 -1
- package/src/{operations/databases → core/stages}/__snapshots__/indexedDatabase.spec.ts.snap +4 -4
- package/src/{operations/downloaders → core/stages}/__snapshots__/serverDownloader.spec.ts.snap +25 -0
- package/src/{helpers → core/stages}/cacheReader.spec.ts +12 -7
- package/src/core/stages/cacheReader.ts +88 -0
- package/src/core/stages/cacheWriter.spec.ts +213 -0
- package/src/core/stages/cacheWriter.ts +64 -0
- package/src/{operations/databases → core/stages}/indexedDatabase.spec.ts +12 -8
- package/src/core/stages/indexedDatabase.ts +178 -0
- package/src/{operations/databases → core/stages/memory}/memoryDatabase.spec.ts +7 -7
- package/src/{operations/databases → core/stages/memory}/memoryDatabase.ts +9 -6
- package/src/{operations/downloaders → core/stages/memory}/memoryDownloader.spec.ts +5 -5
- package/src/{operations/downloaders → core/stages/memory}/memoryDownloader.ts +4 -4
- package/src/core/stages/serverDownloader.spec.ts +382 -0
- package/src/{operations/downloaders → core/stages}/serverDownloader.ts +115 -52
- package/src/{operations → core}/traverser.ts +2 -1
- package/src/deferment/MemoryCache.test.ts +187 -0
- package/src/deferment/MemoryCache.ts +189 -0
- package/src/deferment/defermentManager.test.ts +225 -0
- package/src/deferment/defermentManager.ts +95 -0
- package/src/deferment/deferredBase.ts +29 -0
- package/src/index.ts +4 -2
- package/src/{helpers → queues}/aggregateQueue.ts +5 -1
- package/src/{helpers → queues}/asyncGeneratorQueue.ts +2 -1
- package/src/queues/batchingQueue.dispose.test.ts +72 -0
- package/src/queues/batchingQueue.test.ts +270 -0
- package/src/queues/batchingQueue.ts +140 -0
- package/src/{helpers → queues}/bufferQueue.ts +3 -0
- package/src/queues/keyedQueue.test.ts +146 -0
- package/src/{helpers → queues}/keyedQueue.ts +12 -0
- package/src/{helpers → queues}/queue.ts +1 -0
- package/src/test/e2e.spec.ts +2 -2
- package/src/types/functions.spec.ts +155 -0
- package/src/types/functions.ts +116 -0
- package/src/types/types.ts +5 -50
- package/dist/commonjs/helpers/aggregateQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/aggregateQueue.js.map +0 -1
- package/dist/commonjs/helpers/asyncGeneratorQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/asyncGeneratorQueue.js.map +0 -1
- package/dist/commonjs/helpers/batchedPool.d.ts +0 -12
- package/dist/commonjs/helpers/batchedPool.d.ts.map +0 -1
- package/dist/commonjs/helpers/batchedPool.js +0 -45
- package/dist/commonjs/helpers/batchedPool.js.map +0 -1
- package/dist/commonjs/helpers/batchingQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/batchingQueue.js +0 -77
- package/dist/commonjs/helpers/batchingQueue.js.map +0 -1
- package/dist/commonjs/helpers/bufferQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/bufferQueue.js.map +0 -1
- package/dist/commonjs/helpers/cachePump.d.ts +0 -22
- package/dist/commonjs/helpers/cachePump.d.ts.map +0 -1
- package/dist/commonjs/helpers/cachePump.js +0 -86
- package/dist/commonjs/helpers/cachePump.js.map +0 -1
- package/dist/commonjs/helpers/cacheReader.d.ts +0 -14
- package/dist/commonjs/helpers/cacheReader.d.ts.map +0 -1
- package/dist/commonjs/helpers/cacheReader.js +0 -58
- package/dist/commonjs/helpers/cacheReader.js.map +0 -1
- package/dist/commonjs/helpers/defermentManager.d.ts +0 -28
- package/dist/commonjs/helpers/defermentManager.d.ts.map +0 -1
- package/dist/commonjs/helpers/defermentManager.js +0 -150
- package/dist/commonjs/helpers/defermentManager.js.map +0 -1
- package/dist/commonjs/helpers/deferredBase.d.ts +0 -19
- package/dist/commonjs/helpers/deferredBase.d.ts.map +0 -1
- package/dist/commonjs/helpers/deferredBase.js +0 -51
- package/dist/commonjs/helpers/deferredBase.js.map +0 -1
- package/dist/commonjs/helpers/keyedQueue.d.ts.map +0 -1
- package/dist/commonjs/helpers/keyedQueue.js.map +0 -1
- package/dist/commonjs/helpers/memoryPump.d.ts +0 -15
- package/dist/commonjs/helpers/memoryPump.d.ts.map +0 -1
- package/dist/commonjs/helpers/memoryPump.js +0 -34
- package/dist/commonjs/helpers/memoryPump.js.map +0 -1
- package/dist/commonjs/helpers/pump.d.ts +0 -8
- package/dist/commonjs/helpers/pump.d.ts.map +0 -1
- package/dist/commonjs/helpers/pump.js +0 -3
- package/dist/commonjs/helpers/pump.js.map +0 -1
- package/dist/commonjs/helpers/queue.d.ts +0 -4
- package/dist/commonjs/helpers/queue.d.ts.map +0 -1
- package/dist/commonjs/operations/databases/indexedDatabase.d.ts +0 -27
- package/dist/commonjs/operations/databases/indexedDatabase.d.ts.map +0 -1
- package/dist/commonjs/operations/databases/indexedDatabase.js +0 -98
- package/dist/commonjs/operations/databases/indexedDatabase.js.map +0 -1
- package/dist/commonjs/operations/databases/memoryDatabase.d.ts +0 -13
- package/dist/commonjs/operations/databases/memoryDatabase.d.ts.map +0 -1
- package/dist/commonjs/operations/databases/memoryDatabase.js.map +0 -1
- package/dist/commonjs/operations/downloaders/memoryDownloader.d.ts.map +0 -1
- package/dist/commonjs/operations/downloaders/memoryDownloader.js.map +0 -1
- package/dist/commonjs/operations/downloaders/serverDownloader.d.ts.map +0 -1
- package/dist/commonjs/operations/downloaders/serverDownloader.js.map +0 -1
- package/dist/commonjs/operations/interfaces.d.ts.map +0 -1
- package/dist/commonjs/operations/interfaces.js.map +0 -1
- package/dist/commonjs/operations/objectLoader2.d.ts.map +0 -1
- package/dist/commonjs/operations/objectLoader2.js +0 -101
- package/dist/commonjs/operations/objectLoader2.js.map +0 -1
- package/dist/commonjs/operations/objectLoader2Factory.d.ts.map +0 -1
- package/dist/commonjs/operations/objectLoader2Factory.js +0 -68
- package/dist/commonjs/operations/objectLoader2Factory.js.map +0 -1
- package/dist/commonjs/operations/options.d.ts.map +0 -1
- package/dist/commonjs/operations/traverser.d.ts.map +0 -1
- package/dist/commonjs/operations/traverser.js.map +0 -1
- package/dist/esm/helpers/aggregateQueue.d.ts.map +0 -1
- package/dist/esm/helpers/aggregateQueue.js.map +0 -1
- package/dist/esm/helpers/asyncGeneratorQueue.d.ts.map +0 -1
- package/dist/esm/helpers/asyncGeneratorQueue.js.map +0 -1
- package/dist/esm/helpers/batchedPool.d.ts +0 -12
- package/dist/esm/helpers/batchedPool.d.ts.map +0 -1
- package/dist/esm/helpers/batchedPool.js +0 -42
- package/dist/esm/helpers/batchedPool.js.map +0 -1
- package/dist/esm/helpers/batchingQueue.d.ts.map +0 -1
- package/dist/esm/helpers/batchingQueue.js +0 -71
- package/dist/esm/helpers/batchingQueue.js.map +0 -1
- package/dist/esm/helpers/bufferQueue.d.ts.map +0 -1
- package/dist/esm/helpers/bufferQueue.js.map +0 -1
- package/dist/esm/helpers/cachePump.d.ts +0 -22
- package/dist/esm/helpers/cachePump.d.ts.map +0 -1
- package/dist/esm/helpers/cachePump.js +0 -79
- package/dist/esm/helpers/cachePump.js.map +0 -1
- package/dist/esm/helpers/cacheReader.d.ts +0 -14
- package/dist/esm/helpers/cacheReader.d.ts.map +0 -1
- package/dist/esm/helpers/cacheReader.js +0 -51
- package/dist/esm/helpers/cacheReader.js.map +0 -1
- package/dist/esm/helpers/defermentManager.d.ts +0 -28
- package/dist/esm/helpers/defermentManager.d.ts.map +0 -1
- package/dist/esm/helpers/defermentManager.js +0 -146
- package/dist/esm/helpers/defermentManager.js.map +0 -1
- package/dist/esm/helpers/deferredBase.d.ts +0 -19
- package/dist/esm/helpers/deferredBase.d.ts.map +0 -1
- package/dist/esm/helpers/deferredBase.js +0 -47
- package/dist/esm/helpers/deferredBase.js.map +0 -1
- package/dist/esm/helpers/keyedQueue.d.ts.map +0 -1
- package/dist/esm/helpers/keyedQueue.js.map +0 -1
- package/dist/esm/helpers/memoryPump.d.ts +0 -15
- package/dist/esm/helpers/memoryPump.d.ts.map +0 -1
- package/dist/esm/helpers/memoryPump.js +0 -30
- package/dist/esm/helpers/memoryPump.js.map +0 -1
- package/dist/esm/helpers/pump.d.ts +0 -8
- package/dist/esm/helpers/pump.d.ts.map +0 -1
- package/dist/esm/helpers/pump.js +0 -2
- package/dist/esm/helpers/pump.js.map +0 -1
- package/dist/esm/helpers/queue.d.ts +0 -4
- package/dist/esm/helpers/queue.d.ts.map +0 -1
- package/dist/esm/operations/databases/indexedDatabase.d.ts +0 -27
- package/dist/esm/operations/databases/indexedDatabase.d.ts.map +0 -1
- package/dist/esm/operations/databases/indexedDatabase.js +0 -93
- package/dist/esm/operations/databases/indexedDatabase.js.map +0 -1
- package/dist/esm/operations/databases/memoryDatabase.d.ts +0 -13
- package/dist/esm/operations/databases/memoryDatabase.d.ts.map +0 -1
- package/dist/esm/operations/databases/memoryDatabase.js.map +0 -1
- package/dist/esm/operations/downloaders/memoryDownloader.d.ts.map +0 -1
- package/dist/esm/operations/downloaders/memoryDownloader.js.map +0 -1
- package/dist/esm/operations/downloaders/serverDownloader.d.ts.map +0 -1
- package/dist/esm/operations/downloaders/serverDownloader.js.map +0 -1
- package/dist/esm/operations/interfaces.d.ts.map +0 -1
- package/dist/esm/operations/interfaces.js.map +0 -1
- package/dist/esm/operations/objectLoader2.d.ts.map +0 -1
- package/dist/esm/operations/objectLoader2.js +0 -94
- package/dist/esm/operations/objectLoader2.js.map +0 -1
- package/dist/esm/operations/objectLoader2Factory.d.ts.map +0 -1
- package/dist/esm/operations/objectLoader2Factory.js +0 -61
- package/dist/esm/operations/objectLoader2Factory.js.map +0 -1
- package/dist/esm/operations/options.d.ts.map +0 -1
- package/dist/esm/operations/traverser.d.ts.map +0 -1
- package/dist/esm/operations/traverser.js.map +0 -1
- package/src/helpers/__snapshots__/cachePump.spec.ts.snap +0 -31
- package/src/helpers/__snapshots__/defermentManager.spec.ts.snap +0 -8
- package/src/helpers/batchedPool.ts +0 -56
- package/src/helpers/batchingQueue.ts +0 -85
- package/src/helpers/cachePump.disposal.spec.ts +0 -51
- package/src/helpers/cachePump.spec.ts +0 -104
- package/src/helpers/cachePump.ts +0 -107
- package/src/helpers/cacheReader.ts +0 -64
- package/src/helpers/defermentManager.defermentTotals.spec.ts +0 -53
- package/src/helpers/defermentManager.disposal.spec.ts +0 -28
- package/src/helpers/defermentManager.spec.ts +0 -37
- package/src/helpers/defermentManager.ts +0 -160
- package/src/helpers/deferredBase.ts +0 -55
- package/src/helpers/memoryPump.ts +0 -40
- package/src/helpers/pump.ts +0 -8
- package/src/operations/databases/indexedDatabase.ts +0 -126
- package/src/operations/downloaders/serverDownloader.spec.ts +0 -161
- package/src/operations/objectLoader2.ts +0 -119
- package/src/operations/objectLoader2Factory.ts +0 -78
- package/dist/commonjs/{operations → core}/interfaces.js +0 -0
- package/dist/commonjs/{operations → core}/options.js +0 -0
- package/dist/commonjs/{operations → core}/traverser.d.ts +0 -0
- package/dist/commonjs/{helpers → queues}/queue.js +0 -0
- package/dist/esm/{operations → core}/interfaces.js +0 -0
- package/dist/esm/{operations → core}/options.js +0 -0
- package/dist/esm/{operations → core}/traverser.d.ts +0 -0
- package/dist/esm/{helpers → queues}/queue.js +0 -0
- package/src/{operations → core}/__snapshots__/objectLoader2.spec.ts.snap +0 -0
- package/src/{operations → core}/__snapshots__/traverser.spec.ts.snap +0 -0
- package/src/{helpers → core/stages}/__snapshots__/cacheReader.spec.ts.snap +0 -0
- package/src/{operations/downloaders → core/stages/memory}/__snapshots__/memoryDownloader.spec.ts.snap +0 -0
- package/src/{operations → core}/traverser.spec.ts +1 -1
|
@@ -1,39 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.isBase = isBase;
|
|
4
|
-
exports.isReference = isReference;
|
|
5
|
-
exports.isScalar = isScalar;
|
|
6
|
-
exports.take = take;
|
|
7
|
-
function isBase(maybeBase) {
|
|
8
|
-
return (maybeBase !== null &&
|
|
9
|
-
typeof maybeBase === 'object' &&
|
|
10
|
-
'id' in maybeBase &&
|
|
11
|
-
typeof maybeBase.id === 'string');
|
|
12
|
-
}
|
|
13
|
-
function isReference(maybeRef) {
|
|
14
|
-
return (maybeRef !== null &&
|
|
15
|
-
typeof maybeRef === 'object' &&
|
|
16
|
-
'referencedId' in maybeRef &&
|
|
17
|
-
typeof maybeRef.referencedId === 'string');
|
|
18
|
-
}
|
|
19
|
-
function isScalar(value) {
|
|
20
|
-
const type = typeof value;
|
|
21
|
-
return (value === null ||
|
|
22
|
-
type === 'string' ||
|
|
23
|
-
type === 'number' ||
|
|
24
|
-
type === 'boolean' ||
|
|
25
|
-
type === 'bigint' ||
|
|
26
|
-
type === 'symbol' ||
|
|
27
|
-
type === 'undefined');
|
|
28
|
-
}
|
|
29
|
-
function take(it, count) {
|
|
30
|
-
const result = [];
|
|
31
|
-
for (let i = 0; i < count; i++) {
|
|
32
|
-
const itr = it.next();
|
|
33
|
-
if (itr.done)
|
|
34
|
-
break;
|
|
35
|
-
result.push(itr.value);
|
|
36
|
-
}
|
|
37
|
-
return result;
|
|
38
|
-
}
|
|
39
3
|
//# sourceMappingURL=types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/types/types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/types/types.ts"],"names":[],"mappings":""}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import Queue from '../
|
|
1
|
+
import Queue from '../queues/queue.js';
|
|
2
2
|
import { Item } from '../types/types.js';
|
|
3
3
|
export interface Downloader extends Queue<string> {
|
|
4
|
-
|
|
4
|
+
initialize(params: {
|
|
5
5
|
results: Queue<Item>;
|
|
6
6
|
total: number;
|
|
7
7
|
maxDownloadBatchWait?: number;
|
|
@@ -10,10 +10,8 @@ export interface Downloader extends Queue<string> {
|
|
|
10
10
|
disposeAsync(): Promise<void>;
|
|
11
11
|
}
|
|
12
12
|
export interface Database {
|
|
13
|
-
getAll(
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
}): Promise<void>;
|
|
17
|
-
disposeAsync(): Promise<void>;
|
|
13
|
+
getAll(ids: string[]): Promise<(Item | undefined)[]>;
|
|
14
|
+
putAll(batch: Item[]): Promise<void>;
|
|
15
|
+
dispose(): void;
|
|
18
16
|
}
|
|
19
17
|
//# sourceMappingURL=interfaces.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../../src/core/interfaces.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,oBAAoB,CAAA;AACtC,OAAO,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAExC,MAAM,WAAW,UAAW,SAAQ,KAAK,CAAC,MAAM,CAAC;IAC/C,UAAU,CAAC,MAAM,EAAE;QACjB,OAAO,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;QACpB,KAAK,EAAE,MAAM,CAAA;QACb,oBAAoB,CAAC,EAAE,MAAM,CAAA;KAC9B,GAAG,IAAI,CAAA;IACR,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;IAC/B,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;CAC9B;AAED,MAAM,WAAW,QAAQ;IACvB,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,IAAI,GAAG,SAAS,CAAC,EAAE,CAAC,CAAA;IACpD,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACpC,OAAO,IAAI,IAAI,CAAA;CAChB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../src/core/interfaces.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"objectLoader2.d.ts","sourceRoot":"","sources":["../../../src/core/objectLoader2.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AAG9C,OAAO,EAAE,oBAAoB,EAAgB,MAAM,cAAc,CAAA;AAOjE,qBAAa,aAAa;;gBAiBZ,OAAO,EAAE,oBAAoB;IAqCnC,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAU7B,aAAa,IAAI,OAAO,CAAC,IAAI,GAAG,SAAS,CAAC;IAY1C,SAAS,CAAC,MAAM,EAAE;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAIhD,mBAAmB,IAAI,OAAO,CAAC,MAAM,CAAC;IAMrC,iBAAiB,IAAI,cAAc,CAAC,IAAI,CAAC;IA4ChD,MAAM,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,aAAa;IAIxD,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,aAAa;CAGnD"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import AggregateQueue from '../queues/aggregateQueue.js';
|
|
2
|
+
import AsyncGeneratorQueue from '../queues/asyncGeneratorQueue.js';
|
|
3
|
+
import { take } from '../types/functions.js';
|
|
4
|
+
import { ObjectLoader2Factory } from './objectLoader2Factory.js';
|
|
5
|
+
import { CacheReader } from './stages/cacheReader.js';
|
|
6
|
+
import { CacheWriter } from './stages/cacheWriter.js';
|
|
7
|
+
const MAX_CLOSURES_TO_TAKE = 100;
|
|
8
|
+
const EXPECTED_CLOSURE_VALUE = 100;
|
|
9
|
+
export class ObjectLoader2 {
|
|
10
|
+
#rootId;
|
|
11
|
+
#logger;
|
|
12
|
+
#database;
|
|
13
|
+
#downloader;
|
|
14
|
+
#cacheReader;
|
|
15
|
+
#cacheWriter;
|
|
16
|
+
#deferments;
|
|
17
|
+
#gathered;
|
|
18
|
+
#root = undefined;
|
|
19
|
+
#isRootStored = false;
|
|
20
|
+
constructor(options) {
|
|
21
|
+
this.#rootId = options.rootId;
|
|
22
|
+
this.#logger = options.logger || (() => { });
|
|
23
|
+
this.#logger('ObjectLoader2 initialized with rootId:', this.#rootId);
|
|
24
|
+
const cacheOptions = {
|
|
25
|
+
logger: this.#logger,
|
|
26
|
+
maxCacheReadSize: 10_000,
|
|
27
|
+
maxCacheWriteSize: 10_000,
|
|
28
|
+
maxWriteQueueSize: 40_000,
|
|
29
|
+
maxCacheBatchWriteWait: 100, //100 ms, next to nothing!
|
|
30
|
+
maxCacheBatchReadWait: 100 //100 ms, next to nothing!
|
|
31
|
+
};
|
|
32
|
+
this.#gathered = new AsyncGeneratorQueue();
|
|
33
|
+
this.#database = options.database;
|
|
34
|
+
this.#deferments = options.deferments;
|
|
35
|
+
this.#downloader = options.downloader;
|
|
36
|
+
this.#cacheReader = new CacheReader(this.#database, this.#deferments, this.#logger, cacheOptions);
|
|
37
|
+
this.#cacheReader.initializeQueue(this.#gathered, this.#downloader);
|
|
38
|
+
this.#cacheWriter = new CacheWriter(this.#database, this.#logger, this.#deferments, cacheOptions, (id) => {
|
|
39
|
+
this.#cacheReader.requestItem(id);
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
async disposeAsync() {
|
|
43
|
+
await Promise.all([
|
|
44
|
+
this.#gathered.disposeAsync(),
|
|
45
|
+
this.#downloader.disposeAsync(),
|
|
46
|
+
this.#cacheWriter.disposeAsync(),
|
|
47
|
+
this.#cacheReader.disposeAsync()
|
|
48
|
+
]);
|
|
49
|
+
this.#deferments.dispose();
|
|
50
|
+
}
|
|
51
|
+
async getRootObject() {
|
|
52
|
+
if (!this.#root) {
|
|
53
|
+
this.#root = (await this.#database.getAll([this.#rootId]))[0];
|
|
54
|
+
if (!this.#root) {
|
|
55
|
+
this.#root = await this.#downloader.downloadSingle();
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
this.#isRootStored = true;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return this.#root;
|
|
62
|
+
}
|
|
63
|
+
async getObject(params) {
|
|
64
|
+
return await this.#cacheReader.getObject({ id: params.id });
|
|
65
|
+
}
|
|
66
|
+
async getTotalObjectCount() {
|
|
67
|
+
const rootObj = await this.getRootObject();
|
|
68
|
+
const totalChildrenCount = Object.keys(rootObj?.base?.__closure || {}).length;
|
|
69
|
+
return totalChildrenCount + 1; //count the root
|
|
70
|
+
}
|
|
71
|
+
async *getObjectIterator() {
|
|
72
|
+
const rootItem = await this.getRootObject();
|
|
73
|
+
if (rootItem?.base === undefined) {
|
|
74
|
+
this.#logger('No root object found!');
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
if (!rootItem.base.__closure) {
|
|
78
|
+
yield rootItem.base;
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
//sort the closures by their values descending
|
|
82
|
+
const sortedClosures = Object.entries(rootItem.base.__closure ?? []).sort((a, b) => b[1] - a[1]);
|
|
83
|
+
this.#logger('calculated closures: ', !take(sortedClosures.values(), MAX_CLOSURES_TO_TAKE).every((x) => x[1] === EXPECTED_CLOSURE_VALUE));
|
|
84
|
+
const children = sortedClosures.map((x) => x[0]);
|
|
85
|
+
const total = children.length + 1; // +1 for the root object
|
|
86
|
+
this.#downloader.initialize({
|
|
87
|
+
results: new AggregateQueue(this.#gathered, this.#cacheWriter),
|
|
88
|
+
total
|
|
89
|
+
});
|
|
90
|
+
//only for root
|
|
91
|
+
this.#gathered.add(rootItem);
|
|
92
|
+
this.#cacheReader.requestAll(children);
|
|
93
|
+
let count = 0;
|
|
94
|
+
for await (const item of this.#gathered.consume()) {
|
|
95
|
+
yield item.base; //always defined, as we add it to the queue
|
|
96
|
+
count++;
|
|
97
|
+
if (count >= total) {
|
|
98
|
+
break;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
if (!this.#isRootStored) {
|
|
102
|
+
await this.#database.putAll([rootItem]);
|
|
103
|
+
this.#isRootStored = true;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
static createFromObjects(objects) {
|
|
107
|
+
return ObjectLoader2Factory.createFromObjects(objects);
|
|
108
|
+
}
|
|
109
|
+
static createFromJSON(json) {
|
|
110
|
+
return ObjectLoader2Factory.createFromJSON(json);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=objectLoader2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"objectLoader2.js","sourceRoot":"","sources":["../../../src/core/objectLoader2.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,17 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { CustomLogger, Fetcher } from '../types/functions.js';
|
|
2
|
+
import { Base, ObjectAttributeMask } from '../types/types.js';
|
|
2
3
|
import { ObjectLoader2 } from './objectLoader2.js';
|
|
3
4
|
export interface ObjectLoader2FactoryOptions {
|
|
4
|
-
useMemoryCache?: boolean;
|
|
5
5
|
keyRange?: {
|
|
6
6
|
bound: Function;
|
|
7
7
|
lowerBound: Function;
|
|
8
8
|
upperBound: Function;
|
|
9
9
|
};
|
|
10
10
|
indexedDB?: IDBFactory;
|
|
11
|
+
fetch?: Fetcher;
|
|
12
|
+
attributeMask?: ObjectAttributeMask;
|
|
13
|
+
useCache?: boolean;
|
|
14
|
+
debug?: boolean;
|
|
11
15
|
logger?: CustomLogger;
|
|
12
16
|
}
|
|
13
17
|
export declare class ObjectLoader2Factory {
|
|
@@ -20,6 +24,10 @@ export declare class ObjectLoader2Factory {
|
|
|
20
24
|
token?: string;
|
|
21
25
|
headers?: Headers;
|
|
22
26
|
options?: ObjectLoader2FactoryOptions;
|
|
27
|
+
attributeMask?: ObjectAttributeMask;
|
|
28
|
+
objectTypeMask?: string[];
|
|
23
29
|
}): ObjectLoader2;
|
|
30
|
+
static getLogger(providedLogger?: CustomLogger): CustomLogger | undefined;
|
|
31
|
+
static logger: CustomLogger;
|
|
24
32
|
}
|
|
25
33
|
//# sourceMappingURL=objectLoader2Factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"objectLoader2Factory.d.ts","sourceRoot":"","sources":["../../../src/core/objectLoader2Factory.ts"],"names":[],"mappings":"AACA,OAAO,EACL,YAAY,EACZ,OAAO,EAGR,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EAAE,IAAI,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAMlD,MAAM,WAAW,2BAA2B;IAE1C,QAAQ,CAAC,EAAE;QAAE,KAAK,EAAE,QAAQ,CAAC;QAAC,UAAU,EAAE,QAAQ,CAAC;QAAC,UAAU,EAAE,QAAQ,CAAA;KAAE,CAAA;IAC1E,SAAS,CAAC,EAAE,UAAU,CAAA;IACtB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,aAAa,CAAC,EAAE,mBAAmB,CAAA;IACnC,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,MAAM,CAAC,EAAE,YAAY,CAAA;CACtB;AAED,qBAAa,oBAAoB;IAC/B,MAAM,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,aAAa;IAexD,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,aAAa;IAKlD,MAAM,CAAC,aAAa,CAAC,MAAM,EAAE;QAC3B,SAAS,EAAE,MAAM,CAAA;QACjB,QAAQ,EAAE,MAAM,CAAA;QAChB,QAAQ,EAAE,MAAM,CAAA;QAChB,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,OAAO,CAAC,EAAE,OAAO,CAAA;QACjB,OAAO,CAAC,EAAE,2BAA2B,CAAA;QACrC,aAAa,CAAC,EAAE,mBAAmB,CAAA;QACnC,cAAc,CAAC,EAAE,MAAM,EAAE,CAAA;KAC1B,GAAG,aAAa;IA+CjB,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE,YAAY,GAAG,YAAY,GAAG,SAAS;IAOzE,MAAM,CAAC,MAAM,EAAE,YAAY,CAE1B;CACF"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { DefermentManager, MemoryOnlyDeferment } from '../deferment/defermentManager.js';
|
|
2
|
+
import { getFeatureFlag, ObjectLoader2Flags } from '../types/functions.js';
|
|
3
|
+
import { ObjectLoader2 } from './objectLoader2.js';
|
|
4
|
+
import { IndexedDatabase } from './stages/indexedDatabase.js';
|
|
5
|
+
import { MemoryDatabase } from './stages/memory/memoryDatabase.js';
|
|
6
|
+
import { MemoryDownloader } from './stages/memory/memoryDownloader.js';
|
|
7
|
+
import ServerDownloader from './stages/serverDownloader.js';
|
|
8
|
+
export class ObjectLoader2Factory {
|
|
9
|
+
static createFromObjects(objects) {
|
|
10
|
+
const root = objects[0];
|
|
11
|
+
const records = new Map();
|
|
12
|
+
objects.forEach((element) => {
|
|
13
|
+
records.set(element.id, element);
|
|
14
|
+
});
|
|
15
|
+
const loader = new ObjectLoader2({
|
|
16
|
+
rootId: root.id,
|
|
17
|
+
deferments: new MemoryOnlyDeferment(records),
|
|
18
|
+
database: new MemoryDatabase({ items: records }),
|
|
19
|
+
downloader: new MemoryDownloader(root.id, records)
|
|
20
|
+
});
|
|
21
|
+
return loader;
|
|
22
|
+
}
|
|
23
|
+
static createFromJSON(json) {
|
|
24
|
+
const jsonObj = JSON.parse(json);
|
|
25
|
+
return this.createFromObjects(jsonObj);
|
|
26
|
+
}
|
|
27
|
+
static createFromUrl(params) {
|
|
28
|
+
const log = ObjectLoader2Factory.getLogger(params.options?.logger);
|
|
29
|
+
let database;
|
|
30
|
+
if (params.options?.debug === true ||
|
|
31
|
+
getFeatureFlag(ObjectLoader2Flags.DEBUG) === 'true') {
|
|
32
|
+
this.logger('Using DEBUG mode for ObjectLoader2Factory');
|
|
33
|
+
}
|
|
34
|
+
const useCache = params.options?.useCache ?? true;
|
|
35
|
+
const flag = getFeatureFlag(ObjectLoader2Flags.USE_CACHE);
|
|
36
|
+
const flagAllowsCache = flag !== 'false';
|
|
37
|
+
if (useCache && flagAllowsCache) {
|
|
38
|
+
database = new IndexedDatabase({
|
|
39
|
+
indexedDB: params.options?.indexedDB,
|
|
40
|
+
keyRange: params.options?.keyRange
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
database = new MemoryDatabase({
|
|
45
|
+
items: new Map()
|
|
46
|
+
});
|
|
47
|
+
this.logger('Disabled persistent caching for ObjectLoader2. Using MemoryDatabase');
|
|
48
|
+
}
|
|
49
|
+
const logger = log || (() => { });
|
|
50
|
+
const loader = new ObjectLoader2({
|
|
51
|
+
rootId: params.objectId,
|
|
52
|
+
deferments: new DefermentManager(logger),
|
|
53
|
+
downloader: new ServerDownloader({
|
|
54
|
+
serverUrl: params.serverUrl,
|
|
55
|
+
streamId: params.streamId,
|
|
56
|
+
objectId: params.objectId,
|
|
57
|
+
token: params.token,
|
|
58
|
+
headers: params.headers,
|
|
59
|
+
fetch: params.options?.fetch,
|
|
60
|
+
attributeMask: params.attributeMask,
|
|
61
|
+
objectTypeMask: params.objectTypeMask,
|
|
62
|
+
logger
|
|
63
|
+
}),
|
|
64
|
+
database,
|
|
65
|
+
logger
|
|
66
|
+
});
|
|
67
|
+
return loader;
|
|
68
|
+
}
|
|
69
|
+
static getLogger(providedLogger) {
|
|
70
|
+
if (getFeatureFlag(ObjectLoader2Flags.DEBUG) === 'true') {
|
|
71
|
+
return providedLogger || this.logger;
|
|
72
|
+
}
|
|
73
|
+
return providedLogger;
|
|
74
|
+
}
|
|
75
|
+
static logger = (m, ...optionalParams) => {
|
|
76
|
+
console.log(`[debug] ${m}`, ...optionalParams);
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=objectLoader2Factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"objectLoader2Factory.js","sourceRoot":"","sources":["../../../src/core/objectLoader2Factory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"objectLoader2Factory.test.d.ts","sourceRoot":"","sources":["../../../src/core/objectLoader2Factory.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
/* eslint-disable camelcase */
|
|
2
|
+
import { describe, it, expect, beforeEach } from 'vitest';
|
|
3
|
+
import { ObjectLoader2Factory } from './objectLoader2Factory.js';
|
|
4
|
+
describe('ObjectLoader2Factory', () => {
|
|
5
|
+
let testObjects;
|
|
6
|
+
beforeEach(() => {
|
|
7
|
+
testObjects = [
|
|
8
|
+
{
|
|
9
|
+
id: 'root-id',
|
|
10
|
+
synchronized_type: 'Base',
|
|
11
|
+
__closure: {
|
|
12
|
+
'child-1': 1,
|
|
13
|
+
'child-2': 2
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
id: 'child-1',
|
|
18
|
+
synchronized_type: 'Base'
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
id: 'child-2',
|
|
22
|
+
synchronized_type: 'Base'
|
|
23
|
+
}
|
|
24
|
+
];
|
|
25
|
+
});
|
|
26
|
+
describe('createFromObjects', () => {
|
|
27
|
+
it('should create ObjectLoader2 from array of objects', async () => {
|
|
28
|
+
const loader = ObjectLoader2Factory.createFromObjects(testObjects);
|
|
29
|
+
expect(loader).toBeDefined();
|
|
30
|
+
// Test that we can get the root object
|
|
31
|
+
const rootObject = await loader.getRootObject();
|
|
32
|
+
expect(rootObject?.baseId).toBe('root-id');
|
|
33
|
+
expect(rootObject?.base?.synchronized_type).toBe('Base');
|
|
34
|
+
await loader.disposeAsync();
|
|
35
|
+
});
|
|
36
|
+
it('should use first object as root', async () => {
|
|
37
|
+
const loader = ObjectLoader2Factory.createFromObjects(testObjects);
|
|
38
|
+
const rootObject = await loader.getRootObject();
|
|
39
|
+
expect(rootObject?.baseId).toBe('root-id');
|
|
40
|
+
expect(rootObject?.base?.__closure).toEqual({
|
|
41
|
+
'child-1': 1,
|
|
42
|
+
'child-2': 2
|
|
43
|
+
});
|
|
44
|
+
await loader.disposeAsync();
|
|
45
|
+
});
|
|
46
|
+
it('should allow iteration over all objects', async () => {
|
|
47
|
+
const loader = ObjectLoader2Factory.createFromObjects(testObjects);
|
|
48
|
+
const objects = [];
|
|
49
|
+
for await (const obj of loader.getObjectIterator()) {
|
|
50
|
+
objects.push(obj);
|
|
51
|
+
}
|
|
52
|
+
expect(objects).toHaveLength(3);
|
|
53
|
+
expect(objects[0].id).toBe('root-id');
|
|
54
|
+
await loader.disposeAsync();
|
|
55
|
+
});
|
|
56
|
+
it('should get total object count correctly', async () => {
|
|
57
|
+
const loader = ObjectLoader2Factory.createFromObjects(testObjects);
|
|
58
|
+
const totalCount = await loader.getTotalObjectCount();
|
|
59
|
+
expect(totalCount).toBe(3); // root + 2 children
|
|
60
|
+
await loader.disposeAsync();
|
|
61
|
+
});
|
|
62
|
+
it('should handle empty objects array', () => {
|
|
63
|
+
expect(() => {
|
|
64
|
+
ObjectLoader2Factory.createFromObjects([]);
|
|
65
|
+
}).toThrow();
|
|
66
|
+
});
|
|
67
|
+
it('should get individual objects by id', async () => {
|
|
68
|
+
const loader = ObjectLoader2Factory.createFromObjects(testObjects);
|
|
69
|
+
const rootObj = await loader.getObject({ id: 'root-id' });
|
|
70
|
+
expect(rootObj.id).toBe('root-id');
|
|
71
|
+
expect(rootObj.synchronized_type).toBe('Base');
|
|
72
|
+
const child1 = await loader.getObject({ id: 'child-1' });
|
|
73
|
+
expect(child1.id).toBe('child-1');
|
|
74
|
+
const child2 = await loader.getObject({ id: 'child-2' });
|
|
75
|
+
expect(child2.id).toBe('child-2');
|
|
76
|
+
await loader.disposeAsync();
|
|
77
|
+
});
|
|
78
|
+
it('should get individual objects by id that does not exist', async () => {
|
|
79
|
+
const loader = ObjectLoader2Factory.createFromObjects(testObjects);
|
|
80
|
+
const rootObj = await loader.getObject({ id: 'root-id' });
|
|
81
|
+
expect(rootObj.id).toBe('root-id');
|
|
82
|
+
expect(rootObj.synchronized_type).toBe('Base');
|
|
83
|
+
const getObjectPromise = loader.getObject({ id: 'child-11111' });
|
|
84
|
+
await expect(getObjectPromise).rejects.toThrow();
|
|
85
|
+
await loader.disposeAsync();
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
describe('createFromJSON', () => {
|
|
89
|
+
it('should create ObjectLoader2 from JSON string', async () => {
|
|
90
|
+
const json = JSON.stringify(testObjects);
|
|
91
|
+
const loader = ObjectLoader2Factory.createFromJSON(json);
|
|
92
|
+
expect(loader).toBeDefined();
|
|
93
|
+
const rootObject = await loader.getRootObject();
|
|
94
|
+
expect(rootObject?.baseId).toBe('root-id');
|
|
95
|
+
await loader.disposeAsync();
|
|
96
|
+
});
|
|
97
|
+
it('should handle invalid JSON', () => {
|
|
98
|
+
expect(() => {
|
|
99
|
+
ObjectLoader2Factory.createFromJSON('invalid json');
|
|
100
|
+
}).toThrow();
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
});
|
|
104
|
+
//# sourceMappingURL=objectLoader2Factory.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"objectLoader2Factory.test.js","sourceRoot":"","sources":["../../../src/core/objectLoader2Factory.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Deferment } from '../deferment/defermentManager.js';
|
|
2
|
+
import { CustomLogger } from '../types/functions.js';
|
|
3
|
+
import { Base } from '../types/types.js';
|
|
2
4
|
import { Downloader, Database } from './interfaces.js';
|
|
3
5
|
export interface ObjectLoader2Options {
|
|
4
6
|
rootId: string;
|
|
7
|
+
deferments: Deferment;
|
|
5
8
|
downloader: Downloader;
|
|
6
9
|
database: Database;
|
|
7
10
|
logger?: CustomLogger;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../../src/core/options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAA;AACpD,OAAO,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAA;AACxC,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAEtD,MAAM,WAAW,oBAAoB;IACnC,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,SAAS,CAAA;IACrB,UAAU,EAAE,UAAU,CAAA;IACtB,QAAQ,EAAE,QAAQ,CAAA;IAClB,MAAM,CAAC,EAAE,YAAY,CAAA;CACtB;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,EAAE,YAAY,CAAA;IACrB,gBAAgB,EAAE,MAAM,CAAA;IACxB,iBAAiB,EAAE,MAAM,CAAA;IACzB,sBAAsB,EAAE,MAAM,CAAA;IAC9B,qBAAqB,EAAE,MAAM,CAAA;IAC7B,iBAAiB,EAAE,MAAM,CAAA;CAC1B;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,CAAC,EAAE,YAAY,CAAA;IACrB,KAAK,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;CAC1B;AAED,MAAM,WAAW,uBAAuB;IACtC,MAAM,CAAC,EAAE,YAAY,CAAA;IACrB,WAAW,EAAE,MAAM,CAAA;IACnB,KAAK,EAAE,MAAM,CAAA;CACd"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"options.js","sourceRoot":"","sources":["../../../src/
|
|
1
|
+
{"version":3,"file":"options.js","sourceRoot":"","sources":["../../../src/core/options.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Deferment } from '../../deferment/defermentManager.js';
|
|
2
|
+
import Queue from '../../queues/queue.js';
|
|
3
|
+
import { CustomLogger } from '../../types/functions.js';
|
|
4
|
+
import { Item, Base } from '../../types/types.js';
|
|
5
|
+
import { Database } from '../interfaces.js';
|
|
6
|
+
import { CacheOptions } from '../options.js';
|
|
7
|
+
export declare class CacheReader {
|
|
8
|
+
#private;
|
|
9
|
+
constructor(database: Database, defermentManager: Deferment, logger: CustomLogger, options: CacheOptions);
|
|
10
|
+
initializeQueue(foundQueue: Queue<Item>, notFoundQueue: Queue<string>): void;
|
|
11
|
+
getObject(params: {
|
|
12
|
+
id: string;
|
|
13
|
+
}): Promise<Base>;
|
|
14
|
+
requestItem(id: string): void;
|
|
15
|
+
requestAll(keys: string[]): void;
|
|
16
|
+
disposeAsync(): Promise<void>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=cacheReader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cacheReader.d.ts","sourceRoot":"","sources":["../../../../src/core/stages/cacheReader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAA;AAE/D,OAAO,KAAK,MAAM,uBAAuB,CAAA;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAE5C,qBAAa,WAAW;;gBAUpB,QAAQ,EAAE,QAAQ,EAClB,gBAAgB,EAAE,SAAS,EAC3B,MAAM,EAAE,YAAY,EACpB,OAAO,EAAE,YAAY;IAQvB,eAAe,CAAC,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE,aAAa,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI;IAK5E,SAAS,CAAC,MAAM,EAAE;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBhD,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI;IAO7B,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI;IAyBhC,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;CAG9B"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import BatchingQueue from '../../queues/batchingQueue.js';
|
|
2
|
+
export class CacheReader {
|
|
3
|
+
#database;
|
|
4
|
+
#defermentManager;
|
|
5
|
+
#logger;
|
|
6
|
+
#options;
|
|
7
|
+
#readQueue;
|
|
8
|
+
#foundQueue;
|
|
9
|
+
#notFoundQueue;
|
|
10
|
+
constructor(database, defermentManager, logger, options) {
|
|
11
|
+
this.#database = database;
|
|
12
|
+
this.#defermentManager = defermentManager;
|
|
13
|
+
this.#logger = logger;
|
|
14
|
+
this.#options = options;
|
|
15
|
+
}
|
|
16
|
+
initializeQueue(foundQueue, notFoundQueue) {
|
|
17
|
+
this.#foundQueue = foundQueue;
|
|
18
|
+
this.#notFoundQueue = notFoundQueue;
|
|
19
|
+
}
|
|
20
|
+
getObject(params) {
|
|
21
|
+
const [p, b] = this.#defermentManager.defer({ id: params.id });
|
|
22
|
+
if (!b) {
|
|
23
|
+
this.requestItem(params.id);
|
|
24
|
+
}
|
|
25
|
+
return p;
|
|
26
|
+
}
|
|
27
|
+
#createReadQueue() {
|
|
28
|
+
if (!this.#readQueue) {
|
|
29
|
+
this.#readQueue = new BatchingQueue({
|
|
30
|
+
batchSize: this.#options.maxCacheReadSize,
|
|
31
|
+
maxWaitTime: this.#options.maxCacheBatchReadWait,
|
|
32
|
+
processFunction: this.#processBatch
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
requestItem(id) {
|
|
37
|
+
this.#createReadQueue();
|
|
38
|
+
if (!this.#readQueue?.get(id)) {
|
|
39
|
+
this.#readQueue?.add(id, id);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
requestAll(keys) {
|
|
43
|
+
this.#createReadQueue();
|
|
44
|
+
this.#readQueue?.addAll(keys, keys);
|
|
45
|
+
}
|
|
46
|
+
#processBatch = async (batch) => {
|
|
47
|
+
const start = performance.now();
|
|
48
|
+
const items = await this.#database.getAll(batch);
|
|
49
|
+
for (let i = 0; i < items.length; i++) {
|
|
50
|
+
const item = items[i];
|
|
51
|
+
if (item) {
|
|
52
|
+
this.#foundQueue?.add(item);
|
|
53
|
+
this.#defermentManager.undefer(item, (id) => this.requestItem(id));
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
this.#notFoundQueue?.add(batch[i]);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
this.#logger(`readBatch: batch ${batch.length}, time ${performance.now() - start} ms left ${this.#readQueue?.count()}`);
|
|
60
|
+
};
|
|
61
|
+
disposeAsync() {
|
|
62
|
+
return this.#readQueue?.disposeAsync() || Promise.resolve();
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=cacheReader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cacheReader.js","sourceRoot":"","sources":["../../../../src/core/stages/cacheReader.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Deferment } from '../../deferment/defermentManager.js';
|
|
2
|
+
import Queue from '../../queues/queue.js';
|
|
3
|
+
import { CustomLogger } from '../../types/functions.js';
|
|
4
|
+
import { Item } from '../../types/types.js';
|
|
5
|
+
import { Database } from '../interfaces.js';
|
|
6
|
+
import { CacheOptions } from '../options.js';
|
|
7
|
+
export declare class CacheWriter implements Queue<Item> {
|
|
8
|
+
#private;
|
|
9
|
+
constructor(database: Database, logger: CustomLogger, deferment: Deferment, options: CacheOptions, requestItem: (id: string) => void);
|
|
10
|
+
add(item: Item): void;
|
|
11
|
+
writeAll(items: Item[]): Promise<void>;
|
|
12
|
+
disposeAsync(): Promise<void>;
|
|
13
|
+
get isDisposed(): boolean;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=cacheWriter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cacheWriter.d.ts","sourceRoot":"","sources":["../../../../src/core/stages/cacheWriter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAA;AAE/D,OAAO,KAAK,MAAM,uBAAuB,CAAA;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAE5C,qBAAa,WAAY,YAAW,KAAK,CAAC,IAAI,CAAC;;gBAU3C,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,YAAY,EACpB,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,YAAY,EACrB,WAAW,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI;IASnC,GAAG,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI;IAcf,QAAQ,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAUtC,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAKnC,IAAI,UAAU,IAAI,OAAO,CAExB;CACF"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import BatchingQueue from '../../queues/batchingQueue.js';
|
|
2
|
+
export class CacheWriter {
|
|
3
|
+
#writeQueue;
|
|
4
|
+
#database;
|
|
5
|
+
#deferment;
|
|
6
|
+
#requestItem;
|
|
7
|
+
#logger;
|
|
8
|
+
#options;
|
|
9
|
+
#disposed = false;
|
|
10
|
+
constructor(database, logger, deferment, options, requestItem) {
|
|
11
|
+
this.#database = database;
|
|
12
|
+
this.#options = options;
|
|
13
|
+
this.#logger = logger;
|
|
14
|
+
this.#deferment = deferment;
|
|
15
|
+
this.#requestItem = requestItem;
|
|
16
|
+
}
|
|
17
|
+
add(item) {
|
|
18
|
+
if (!this.#writeQueue) {
|
|
19
|
+
this.#writeQueue = new BatchingQueue({
|
|
20
|
+
batchSize: this.#options.maxCacheWriteSize,
|
|
21
|
+
maxWaitTime: this.#options.maxCacheBatchWriteWait,
|
|
22
|
+
processFunction: async (batch) => {
|
|
23
|
+
await this.writeAll(batch);
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
this.#writeQueue.add(item.baseId, item);
|
|
28
|
+
this.#deferment.undefer(item, this.#requestItem);
|
|
29
|
+
}
|
|
30
|
+
async writeAll(items) {
|
|
31
|
+
const start = performance.now();
|
|
32
|
+
await this.#database.putAll(items);
|
|
33
|
+
this.#logger(`writeBatch: wrote ${items.length}, time ${performance.now() - start} ms left ${this.#writeQueue?.count()}`);
|
|
34
|
+
}
|
|
35
|
+
async disposeAsync() {
|
|
36
|
+
this.#disposed = true;
|
|
37
|
+
await this.#writeQueue?.disposeAsync();
|
|
38
|
+
}
|
|
39
|
+
get isDisposed() {
|
|
40
|
+
return this.#disposed;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=cacheWriter.js.map
|