@dxos/feed-store 0.8.3 → 0.8.4-main.1da679c

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 (42) hide show
  1. package/dist/lib/browser/{chunk-WS47OKDO.mjs → chunk-4RW534M7.mjs} +192 -116
  2. package/dist/lib/browser/chunk-4RW534M7.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +116 -64
  4. package/dist/lib/browser/index.mjs.map +3 -3
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +78 -32
  7. package/dist/lib/browser/testing/index.mjs.map +3 -3
  8. package/dist/lib/node-esm/{chunk-AO5I2BX3.mjs → chunk-D4DVCY7Y.mjs} +192 -116
  9. package/dist/lib/node-esm/chunk-D4DVCY7Y.mjs.map +7 -0
  10. package/dist/lib/node-esm/index.mjs +116 -64
  11. package/dist/lib/node-esm/index.mjs.map +3 -3
  12. package/dist/lib/node-esm/meta.json +1 -1
  13. package/dist/lib/node-esm/testing/index.mjs +78 -32
  14. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  15. package/dist/types/src/feed-queue.d.ts.map +1 -1
  16. package/dist/types/src/feed-wrapper.d.ts +18 -19
  17. package/dist/types/src/feed-wrapper.d.ts.map +1 -1
  18. package/dist/types/src/index.d.ts +1 -1
  19. package/dist/types/src/index.d.ts.map +1 -1
  20. package/dist/types/src/testing/test-builder.d.ts +2 -2
  21. package/dist/types/src/testing/test-builder.d.ts.map +1 -1
  22. package/dist/types/src/testing/test-generator.d.ts +1 -1
  23. package/dist/types/src/testing/test-generator.d.ts.map +1 -1
  24. package/dist/types/tsconfig.tsbuildinfo +1 -1
  25. package/package.json +20 -17
  26. package/src/feed-queue.test.ts +1 -1
  27. package/src/feed-queue.ts +5 -2
  28. package/src/feed-store.node.test.ts +3 -3
  29. package/src/feed-wrapper.test.ts +38 -4
  30. package/src/feed-wrapper.ts +75 -35
  31. package/src/index.ts +1 -1
  32. package/src/testing/test-builder.ts +4 -4
  33. package/src/testing/test-generator.ts +1 -2
  34. package/dist/lib/browser/chunk-WS47OKDO.mjs.map +0 -7
  35. package/dist/lib/node/chunk-YOYJCS5J.cjs +0 -523
  36. package/dist/lib/node/chunk-YOYJCS5J.cjs.map +0 -7
  37. package/dist/lib/node/index.cjs +0 -593
  38. package/dist/lib/node/index.cjs.map +0 -7
  39. package/dist/lib/node/meta.json +0 -1
  40. package/dist/lib/node/testing/index.cjs +0 -173
  41. package/dist/lib/node/testing/index.cjs.map +0 -7
  42. package/dist/lib/node-esm/chunk-AO5I2BX3.mjs.map +0 -7
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/feed-wrapper.ts", "../../../src/feed-factory.ts", "../../../src/feed-store.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport { inspect } from 'node:util';\nimport { promisify } from 'node:util';\n\nimport { Readable, Transform } from 'streamx';\n\nimport { Trigger } from '@dxos/async';\nimport { StackTrace, inspectObject } from '@dxos/debug';\nimport type { Hypercore, HypercoreProperties, ReadStreamOptions } from '@dxos/hypercore';\nimport { assertArgument, invariant } from '@dxos/invariant';\nimport { type PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type Directory } from '@dxos/random-access-storage';\nimport { arrayToBuffer, rangeFromTo } from '@dxos/util';\nimport type { GetOptions, Proof } from '@dxos/vendor-hypercore/hypercore';\n\nimport { type FeedWriter, type WriteReceipt } from './feed-writer';\n\n/**\n * Async feed wrapper.\n */\nexport class FeedWrapper<T extends {}> {\n private _hypercore: Hypercore<T>;\n private readonly _pendingWrites = new Set<StackTrace>();\n\n // Pending while writes are happening. Resolves when there are no pending writes.\n private readonly _writeLock = new Trigger();\n\n private _closed = false;\n\n constructor(\n hypercore: Hypercore<T>,\n private _key: PublicKey, // TODO(burdon): Required since currently patching the key inside factory.\n private _storageDirectory: Directory,\n ) {\n assertArgument(hypercore, 'hypercore');\n this._hypercore = hypercore;\n invariant(this._key);\n this._writeLock.wake();\n }\n\n [inspect.custom](): string {\n return inspectObject(this);\n }\n\n toJSON(): { feedKey: PublicKey; length: number; opened: boolean; closed: boolean } {\n return {\n feedKey: this._key,\n length: this.properties.length,\n opened: this.properties.opened,\n closed: this.properties.closed,\n };\n }\n\n get key(): PublicKey {\n return this._key;\n }\n\n get core(): Hypercore<T> {\n return this._hypercore;\n }\n\n // TODO(burdon): Create proxy.\n get properties(): HypercoreProperties {\n return this._hypercore;\n }\n\n createReadableStream(opts?: ReadStreamOptions): Readable {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const self = this;\n const transform = new Transform({\n transform(data: any, cb: (err?: Error | null, data?: any) => void) {\n // Delay until write is complete.\n void self._writeLock.wait().then(() => {\n this.push(data);\n cb();\n });\n },\n });\n const readStream =\n opts?.batch !== undefined && opts?.batch > 1\n ? new BatchedReadStream(this._hypercore, opts)\n : this._hypercore.createReadStream(opts);\n\n readStream.pipe(transform, (err: any) => {\n // Ignore errors.\n // We might get \"Writable stream closed prematurely\" error.\n // Its okay since the pipeline is closed and does not expect more messages.\n });\n\n return transform;\n }\n\n createFeedWriter(): FeedWriter<T> {\n return {\n write: async (data: T, { afterWrite } = {}) => {\n log('write', { feed: this._key, seq: this._hypercore.length });\n invariant(!this._closed, 'Feed closed');\n const stackTrace = new StackTrace();\n\n try {\n // Pending writes pause the read stream.\n this._pendingWrites.add(stackTrace);\n if (this._pendingWrites.size === 1) {\n this._writeLock.reset();\n }\n\n const receipt = await this.appendWithReceipt(data);\n\n // TODO(dmaretskyi): Removing this will make user-intiated writes faster but might result in a data-loss.\n await this.flushToDisk();\n\n await afterWrite?.(receipt);\n\n return receipt;\n } finally {\n // Unblock the read stream after the write (and callback) is complete.\n this._pendingWrites.delete(stackTrace);\n if (this._pendingWrites.size === 0) {\n this._writeLock.wake();\n }\n }\n },\n };\n }\n\n async appendWithReceipt(data: T): Promise<WriteReceipt> {\n const seq = await this.append(data);\n invariant(seq < this.length, 'Invalid seq after write');\n log('write complete', { feed: this._key, seq });\n const receipt: WriteReceipt = {\n feedKey: this.key,\n seq,\n };\n return receipt;\n }\n\n /**\n * Flush pending changes to disk.\n * Calling this is not required unless you want to explicitly wait for data to be written.\n */\n async flushToDisk(): Promise<void> {\n await this._storageDirectory.flush();\n }\n\n get opened(): boolean {\n return this._hypercore.opened;\n }\n\n get closed(): boolean {\n return this._hypercore.closed;\n }\n\n get readable(): boolean {\n return this._hypercore.readable;\n }\n\n get length(): number {\n return this._hypercore.length;\n }\n\n get byteLength(): number {\n return this._hypercore.byteLength;\n }\n\n on(...args: any[]) {\n return (this._hypercore as any).on(...args);\n }\n\n off(...args: any[]) {\n return (this._hypercore as any).off(...args);\n }\n\n open(...args: Parameters<Hypercore<T>['open']>) {\n return promisify(this._hypercore.open.bind(this._hypercore) as any)(...args);\n }\n\n _close(...args: Parameters<Hypercore<T>['close']>) {\n return promisify(this._hypercore.close.bind(this._hypercore) as any)(...args);\n }\n\n close = async () => {\n if (this._pendingWrites.size) {\n log.warn('Closing feed with pending writes', {\n feed: this._key,\n count: this._pendingWrites.size,\n pendingWrites: Array.from(this._pendingWrites.values()).map((stack) => stack.getStack()),\n });\n }\n this._closed = true;\n await this.flushToDisk();\n await this._close();\n };\n\n has(start: number, end?: number) {\n return this._hypercore.has(start, end);\n }\n\n get(index: number, options?: GetOptions) {\n return promisify(this._hypercore.get.bind(this._hypercore) as any)(index, options);\n }\n\n // TODO(dmaretskyi): Type better\n append(data: any | any[]): Promise<number> {\n return promisify(this._hypercore.append.bind(this._hypercore))(data);\n }\n\n /**\n * Will not resolve if `end` parameter is not specified and the feed is not closed.\n */\n download(...args: Parameters<Hypercore<T>['download']>) {\n return this._hypercore.download(...args);\n }\n\n undownload(...args: Parameters<Hypercore<T>['undownload']>) {\n return this._hypercore.undownload(...args);\n }\n\n setDownloading(...args: Parameters<Hypercore<T>['setDownloading']>) {\n return this._hypercore.setDownloading(...args);\n }\n\n replicate(...args: Parameters<Hypercore<T>['replicate']>) {\n return this._hypercore.replicate(...args);\n }\n\n clear(start: number, end?: number) {\n return promisify(this._hypercore.clear.bind(this._hypercore))(start, end);\n }\n\n proof(index: number, options?: any) {\n return promisify(this._hypercore.proof.bind(this._hypercore))(index);\n }\n\n put(index: number, data: T, proof: Proof) {\n return promisify(this._hypercore.put.bind(this._hypercore))(index, data, proof);\n }\n\n putBuffer(index: number, data: Buffer | Uint8Array, proof: Proof, peer: null): Promise<void> {\n return promisify((this._hypercore as any)._putBuffer.bind(this._hypercore) as any)(index, data, proof, peer);\n }\n\n /**\n * Clear and check for integrity.\n */\n async safeClear(from: number, to: number): Promise<void> {\n invariant(from >= 0 && from < to && to <= this.length, 'Invalid range');\n\n const CHECK_MESSAGES = 20;\n const checkBegin = to;\n const checkEnd = Math.min(checkBegin + CHECK_MESSAGES, this.length);\n\n const messagesBefore = await Promise.all(\n rangeFromTo(checkBegin, checkEnd).map((idx) =>\n this.get(idx, {\n valueEncoding: { decode: (x: Uint8Array) => x } as any,\n }),\n ),\n );\n\n await this.clear(from, to);\n\n const messagesAfter = await Promise.all(\n rangeFromTo(checkBegin, checkEnd).map((idx) =>\n this.get(idx, {\n valueEncoding: { decode: (x: Uint8Array) => x } as any,\n }),\n ),\n );\n\n for (let i = 0; i < messagesBefore.length; i++) {\n const before = arrayToBuffer(messagesBefore[i]);\n const after = arrayToBuffer(messagesAfter[i]);\n if (!before.equals(after)) {\n throw new Error('Feed corruption on clear. There has likely been a data loss.');\n }\n }\n }\n}\n\nclass BatchedReadStream extends Readable {\n private readonly _feed: Hypercore<any>;\n private readonly _batch: number;\n private _cursor: number;\n private _reading = false;\n\n constructor(feed: Hypercore<any>, opts: ReadStreamOptions = {}) {\n super({ objectMode: true });\n invariant(opts.live === true, 'Only live mode supported');\n invariant(opts.batch !== undefined && opts.batch > 1);\n this._feed = feed;\n this._batch = opts.batch;\n this._cursor = opts.start ?? 0;\n }\n\n override _open(cb: (err: Error | null) => void): void {\n this._feed.ready(cb);\n }\n\n override _read(cb: (err: Error | null) => void): void {\n if (this._reading) {\n return;\n }\n\n if (this._feed.bitfield!.total(this._cursor, this._cursor + this._batch) === this._batch) {\n this._batchedRead(cb);\n } else {\n this._nonBatchedRead(cb);\n }\n }\n\n private _nonBatchedRead(cb: (err: Error | null) => void): void {\n this._feed.get(this._cursor, { wait: true }, (err, data) => {\n if (err) {\n cb(err);\n } else {\n this._cursor++;\n this._reading = false;\n this.push(data);\n cb(null);\n }\n });\n }\n\n private _batchedRead(cb: (err: Error | null) => void): void {\n this._feed.getBatch(this._cursor, this._cursor + this._batch, { wait: true }, (err, data) => {\n if (err) {\n cb(err);\n } else {\n this._cursor += data.length;\n this._reading = false;\n for (const item of data) {\n this.push(item);\n }\n cb(null);\n }\n });\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport defaultsDeep from 'lodash.defaultsdeep';\n\nimport { type Signer, subtleCrypto } from '@dxos/crypto';\nimport { failUndefined } from '@dxos/debug';\nimport type { HypercoreOptions } from '@dxos/hypercore';\nimport { createCrypto, hypercore } from '@dxos/hypercore';\nimport { type PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type Directory } from '@dxos/random-access-storage';\n\nimport { FeedWrapper } from './feed-wrapper';\n\nexport type FeedFactoryOptions = {\n root: Directory;\n signer?: Signer;\n hypercore?: HypercoreOptions;\n};\n\nexport type FeedOptions = HypercoreOptions & {\n writable?: boolean;\n /**\n * Optional hook called before data is written after being verified.\n * Called for writes done by this peer as well as for data replicated from other peers.\n * NOTE: The callback must be invoked to complete the write operation.\n * @param peer Always null in hypercore@9.12.0.\n */\n onwrite?: (index: number, data: any, peer: null, cb: (err: Error | null) => void) => void;\n};\n\n/**\n * Hypercore factory.\n */\nexport class FeedFactory<T extends {}> {\n private readonly _root: Directory;\n private readonly _signer?: Signer;\n private readonly _hypercoreOptions?: HypercoreOptions;\n\n constructor({ root, signer, hypercore }: FeedFactoryOptions) {\n log('FeedFactory', { options: hypercore });\n this._root = root ?? failUndefined();\n this._signer = signer;\n this._hypercoreOptions = hypercore;\n }\n\n get storageRoot() {\n return this._root;\n }\n\n async createFeed(publicKey: PublicKey, options?: FeedOptions): Promise<FeedWrapper<T>> {\n if (options?.writable && !this._signer) {\n throw new Error('Signer required to create writable feeds.');\n }\n if (options?.secretKey) {\n log.warn('Secret key ignored due to signer.');\n }\n\n // Required due to hypercore's 32-byte key limit.\n const key = await subtleCrypto.digest('SHA-256', Buffer.from(publicKey.toHex()));\n\n const opts = defaultsDeep(\n {\n // sparse: false,\n // stats: false,\n },\n this._hypercoreOptions,\n {\n secretKey: this._signer && options?.writable ? Buffer.from('secret') : undefined,\n crypto: this._signer ? createCrypto(this._signer, publicKey) : undefined,\n onwrite: options?.onwrite,\n noiseKeyPair: {}, // We're not using noise.\n },\n options,\n );\n\n const storageDir = this._root.createDirectory(publicKey.toHex());\n const makeStorage = (filename: string) => {\n const { type, native } = storageDir.getOrCreateFile(filename);\n log('created', {\n path: `${type}:${this._root.path}/${publicKey.truncate()}/${filename}`,\n });\n\n return native;\n };\n\n const core = hypercore(makeStorage, Buffer.from(key), opts);\n return new FeedWrapper(core, publicKey, storageDir);\n }\n}\n", "//\n// Copyright 2019 DXOS.org\n//\n\nimport { Event, Mutex } from '@dxos/async';\nimport { failUndefined } from '@dxos/debug';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { ComplexMap, defaultMap } from '@dxos/util';\n\nimport { type FeedFactory, type FeedOptions } from './feed-factory';\nimport { type FeedWrapper } from './feed-wrapper';\n\nexport interface FeedStoreOptions<T extends {}> {\n factory: FeedFactory<T>;\n}\n\n/**\n * Persistent hypercore store.\n */\nexport class FeedStore<T extends {}> {\n private readonly _feeds: ComplexMap<PublicKey, FeedWrapper<T>> = new ComplexMap(PublicKey.hash);\n private readonly _mutexes = new ComplexMap<PublicKey, Mutex>(PublicKey.hash);\n private readonly _factory: FeedFactory<T>;\n\n private _closed = false;\n\n readonly feedOpened = new Event<FeedWrapper<T>>();\n\n constructor({ factory }: FeedStoreOptions<T>) {\n this._factory = factory ?? failUndefined();\n }\n\n get size() {\n return this._feeds.size;\n }\n\n get feeds() {\n return Array.from(this._feeds.values());\n }\n\n /**\n * Get the open feed if it exists.\n */\n getFeed(publicKey: PublicKey): FeedWrapper<T> | undefined {\n return this._feeds.get(publicKey);\n }\n\n /**\n * Gets or opens a feed.\n * The feed is readonly unless a secret key is provided.\n */\n async openFeed(feedKey: PublicKey, { writable, sparse }: FeedOptions = {}): Promise<FeedWrapper<T>> {\n log('opening feed', { feedKey });\n invariant(feedKey);\n invariant(!this._closed, 'Feed store is closed');\n\n const mutex = defaultMap(this._mutexes, feedKey, () => new Mutex());\n\n return mutex.executeSynchronized(async () => {\n let feed = this.getFeed(feedKey);\n if (feed) {\n // TODO(burdon): Need to check that there's another instance being used (create test and break this).\n // TODO(burdon): Remove from store if feed is closed externally? (remove wrapped open/close methods?)\n if (writable && !feed.properties.writable) {\n throw new Error(`Read-only feed is already open: ${feedKey.truncate()}`);\n } else if ((sparse ?? false) !== feed.properties.sparse) {\n throw new Error(\n `Feed already open with different sparse setting: ${feedKey.truncate()} [${sparse} !== ${\n feed.properties.sparse\n }]`,\n );\n } else {\n await feed.open();\n return feed;\n }\n }\n\n feed = await this._factory.createFeed(feedKey, { writable, sparse });\n this._feeds.set(feed.key, feed);\n\n await feed.open();\n this.feedOpened.emit(feed);\n log('opened', { feedKey });\n return feed;\n });\n }\n\n /**\n * Close all feeds.\n */\n async close(): Promise<void> {\n log('closing...');\n this._closed = true;\n await Promise.all(\n Array.from(this._feeds.values()).map(async (feed) => {\n await feed.close();\n invariant(feed.closed);\n // TODO(burdon): SpaceProxy still being initialized.\n // SpaceProxy.initialize => Database.createItem => ... => FeedWrapper.append\n // Uncaught Error: Closed [random-access-storage/index.js:181:38]\n // await sleep(100);\n }),\n );\n\n this._feeds.clear();\n log('closed');\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["inspect", "promisify", "Readable", "Transform", "Trigger", "StackTrace", "inspectObject", "assertArgument", "invariant", "log", "arrayToBuffer", "rangeFromTo", "custom", "FeedWrapper", "toJSON", "feedKey", "_key", "length", "properties", "opened", "closed", "key", "core", "_hypercore", "createReadableStream", "opts", "self", "transform", "data", "cb", "_writeLock", "wait", "then", "push", "readStream", "batch", "undefined", "BatchedReadStream", "createReadStream", "pipe", "err", "createFeedWriter", "write", "afterWrite", "feed", "seq", "_closed", "stackTrace", "_pendingWrites", "add", "size", "reset", "receipt", "appendWithReceipt", "flushToDisk", "delete", "wake", "append", "_storageDirectory", "flush", "readable", "byteLength", "on", "args", "off", "open", "bind", "_close", "close", "has", "start", "end", "get", "index", "options", "download", "undownload", "setDownloading", "replicate", "clear", "proof", "put", "putBuffer", "peer", "_putBuffer", "safeClear", "from", "to", "CHECK_MESSAGES", "checkBegin", "checkEnd", "Math", "min", "messagesBefore", "Promise", "all", "map", "idx", "valueEncoding", "decode", "x", "messagesAfter", "i", "before", "after", "equals", "Error", "hypercore", "Set", "warn", "count", "pendingWrites", "Array", "values", "stack", "getStack", "_open", "_feed", "ready", "_read", "_reading", "bitfield", "total", "_cursor", "_batch", "_batchedRead", "_nonBatchedRead", "getBatch", "item", "objectMode", "live", "defaultsDeep", "subtleCrypto", "failUndefined", "createCrypto", "hypercore", "log", "FeedFactory", "storageRoot", "_root", "createFeed", "publicKey", "options", "writable", "_signer", "Error", "secretKey", "log", "warn", "key", "subtleCrypto", "digest", "Buffer", "from", "toHex", "opts", "defaultsDeep", "_hypercoreOptions", "undefined", "crypto", "createCrypto", "onwrite", "noiseKeyPair", "storageDir", "createDirectory", "makeStorage", "filename", "type", "native", "getOrCreateFile", "path", "truncate", "core", "hypercore", "FeedWrapper", "root", "signer", "_define_property", "failUndefined", "Event", "Mutex", "failUndefined", "invariant", "PublicKey", "log", "ComplexMap", "defaultMap", "FeedStore", "size", "_feeds", "feeds", "Array", "from", "values", "getFeed", "publicKey", "get", "openFeed", "feedKey", "writable", "sparse", "_closed", "mutex", "_mutexes", "executeSynchronized", "feed", "properties", "Error", "truncate", "open", "_factory", "createFeed", "set", "key", "feedOpened", "emit", "close", "Promise", "all", "map", "closed", "clear", "factory", "_define_property", "hash"]
7
+ }
@@ -3,40 +3,42 @@ import {
3
3
  FeedFactory,
4
4
  FeedStore,
5
5
  FeedWrapper
6
- } from "./chunk-AO5I2BX3.mjs";
6
+ } from "./chunk-D4DVCY7Y.mjs";
7
7
 
8
- // packages/common/feed-store/src/feed-iterator.ts
8
+ // src/feed-iterator.ts
9
9
  import safeRace from "race-as-promised";
10
10
  import { Trigger as Trigger2 } from "@dxos/async";
11
11
  import { invariant as invariant2 } from "@dxos/invariant";
12
12
  import { log as log2 } from "@dxos/log";
13
13
 
14
- // packages/common/feed-store/src/feed-queue.ts
14
+ // src/feed-queue.ts
15
15
  import { inspect } from "node:util";
16
16
  import { Writable } from "streamx";
17
- import { Event, latch, Trigger } from "@dxos/async";
17
+ import { Event, Trigger, latch } from "@dxos/async";
18
18
  import { inspectObject } from "@dxos/debug";
19
19
  import { invariant } from "@dxos/invariant";
20
20
  import { log } from "@dxos/log";
21
- var __dxlog_file = "/home/runner/work/dxos/dxos/packages/common/feed-store/src/feed-queue.ts";
21
+ function _define_property(obj, key, value) {
22
+ if (key in obj) {
23
+ Object.defineProperty(obj, key, {
24
+ value,
25
+ enumerable: true,
26
+ configurable: true,
27
+ writable: true
28
+ });
29
+ } else {
30
+ obj[key] = value;
31
+ }
32
+ return obj;
33
+ }
34
+ var __dxlog_file = "/__w/dxos/dxos/packages/common/feed-store/src/feed-queue.ts";
22
35
  var defaultReadStreamOptions = {
23
36
  live: true,
24
37
  batch: 1024
25
38
  };
39
+ var _inspect_custom = inspect.custom;
26
40
  var FeedQueue = class {
27
- // prettier-ignore
28
- constructor(_feed, _options = {}) {
29
- this._feed = _feed;
30
- this._options = _options;
31
- this.updated = new Event();
32
- this._messageTrigger = new Trigger({
33
- autoReset: true
34
- });
35
- this._feedConsumer = void 0;
36
- this._currentBlock = void 0;
37
- this._index = -1;
38
- }
39
- [inspect.custom]() {
41
+ [_inspect_custom]() {
40
42
  return inspectObject(this);
41
43
  }
42
44
  toJSON() {
@@ -75,7 +77,7 @@ var FeedQueue = class {
75
77
  feedKey: this._feed.key
76
78
  }, {
77
79
  F: __dxlog_file,
78
- L: 92,
80
+ L: 93,
79
81
  S: this,
80
82
  C: (f, a) => f(...a)
81
83
  });
@@ -105,6 +107,9 @@ var FeedQueue = class {
105
107
  this._destroyConsumer();
106
108
  };
107
109
  const onError = (err) => {
110
+ if (!this.isOpen) {
111
+ return;
112
+ }
108
113
  if (!err) {
109
114
  return;
110
115
  }
@@ -115,7 +120,7 @@ var FeedQueue = class {
115
120
  feedKey: this._feed.key
116
121
  }, {
117
122
  F: __dxlog_file,
118
- L: 135,
123
+ L: 138,
119
124
  S: this,
120
125
  C: (f, a) => f(...a)
121
126
  });
@@ -131,7 +136,7 @@ var FeedQueue = class {
131
136
  });
132
137
  log("opened", void 0, {
133
138
  F: __dxlog_file,
134
- L: 153,
139
+ L: 156,
135
140
  S: this,
136
141
  C: (f, a) => f(...a)
137
142
  });
@@ -143,7 +148,7 @@ var FeedQueue = class {
143
148
  if (this.isOpen) {
144
149
  invariant(this._feedConsumer, void 0, {
145
150
  F: __dxlog_file,
146
- L: 161,
151
+ L: 164,
147
152
  S: this,
148
153
  A: [
149
154
  "this._feedConsumer",
@@ -152,7 +157,7 @@ var FeedQueue = class {
152
157
  });
153
158
  invariant(!this._feed.properties.closed, void 0, {
154
159
  F: __dxlog_file,
155
- L: 162,
160
+ L: 165,
156
161
  S: this,
157
162
  A: [
158
163
  "!this._feed.properties.closed",
@@ -163,7 +168,7 @@ var FeedQueue = class {
163
168
  feedKey: this._feed.key
164
169
  }, {
165
170
  F: __dxlog_file,
166
- L: 164,
171
+ L: 167,
167
172
  S: this,
168
173
  C: (f, a) => f(...a)
169
174
  });
@@ -174,7 +179,7 @@ var FeedQueue = class {
174
179
  await closed();
175
180
  log("closed", void 0, {
176
181
  F: __dxlog_file,
177
- L: 170,
182
+ L: 173,
178
183
  S: this,
179
184
  C: (f, a) => f(...a)
180
185
  });
@@ -208,7 +213,7 @@ var FeedQueue = class {
208
213
  feedKey: this._feed.key
209
214
  }, {
210
215
  F: __dxlog_file,
211
- L: 203,
216
+ L: 206,
212
217
  S: this,
213
218
  C: (f, a) => f(...a)
214
219
  });
@@ -218,16 +223,44 @@ var FeedQueue = class {
218
223
  this._index = -1;
219
224
  }
220
225
  }
226
+ // prettier-ignore
227
+ constructor(_feed, _options = {}) {
228
+ _define_property(this, "_feed", void 0);
229
+ _define_property(this, "_options", void 0);
230
+ _define_property(this, "updated", void 0);
231
+ _define_property(this, "_messageTrigger", void 0);
232
+ _define_property(this, "_feedConsumer", void 0);
233
+ _define_property(this, "_next", void 0);
234
+ _define_property(this, "_currentBlock", void 0);
235
+ _define_property(this, "_index", void 0);
236
+ this._feed = _feed;
237
+ this._options = _options;
238
+ this.updated = new Event();
239
+ this._messageTrigger = new Trigger({
240
+ autoReset: true
241
+ });
242
+ this._feedConsumer = void 0;
243
+ this._currentBlock = void 0;
244
+ this._index = -1;
245
+ }
221
246
  };
222
247
 
223
- // packages/common/feed-store/src/feed-iterator.ts
224
- var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/common/feed-store/src/feed-iterator.ts";
225
- var AbstractFeedIterator = class {
226
- constructor() {
227
- this._stopTrigger = new Trigger2();
228
- this._open = false;
229
- this._running = false;
248
+ // src/feed-iterator.ts
249
+ function _define_property2(obj, key, value) {
250
+ if (key in obj) {
251
+ Object.defineProperty(obj, key, {
252
+ value,
253
+ enumerable: true,
254
+ configurable: true,
255
+ writable: true
256
+ });
257
+ } else {
258
+ obj[key] = value;
230
259
  }
260
+ return obj;
261
+ }
262
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/common/feed-store/src/feed-iterator.ts";
263
+ var AbstractFeedIterator = class {
231
264
  toJSON() {
232
265
  return {
233
266
  open: this.isOpen,
@@ -337,12 +370,13 @@ var AbstractFeedIterator = class {
337
370
  C: (f, a) => f(...a)
338
371
  });
339
372
  }
373
+ constructor() {
374
+ _define_property2(this, "_stopTrigger", new Trigger2());
375
+ _define_property2(this, "_open", false);
376
+ _define_property2(this, "_running", false);
377
+ }
340
378
  };
341
379
  var FeedIterator = class extends AbstractFeedIterator {
342
- constructor(_feed) {
343
- super(), this._feed = _feed;
344
- this._queue = new FeedQueue(this._feed);
345
- }
346
380
  async _onOpen() {
347
381
  await this._queue.open();
348
382
  }
@@ -352,9 +386,13 @@ var FeedIterator = class extends AbstractFeedIterator {
352
386
  async _nextBlock() {
353
387
  return this._queue.pop();
354
388
  }
389
+ constructor(_feed) {
390
+ super(), _define_property2(this, "_feed", void 0), _define_property2(this, "_queue", void 0), this._feed = _feed;
391
+ this._queue = new FeedQueue(this._feed);
392
+ }
355
393
  };
356
394
 
357
- // packages/common/feed-store/src/feed-set-iterator.ts
395
+ // src/feed-set-iterator.ts
358
396
  import { inspect as inspect2 } from "node:util";
359
397
  import { Event as Event2, SubscriptionList, Trigger as Trigger3 } from "@dxos/async";
360
398
  import { inspectObject as inspectObject2 } from "@dxos/debug";
@@ -362,35 +400,26 @@ import { invariant as invariant3 } from "@dxos/invariant";
362
400
  import { PublicKey } from "@dxos/keys";
363
401
  import { log as log3 } from "@dxos/log";
364
402
  import { ComplexMap, isNonNullable } from "@dxos/util";
365
- var __dxlog_file3 = "/home/runner/work/dxos/dxos/packages/common/feed-store/src/feed-set-iterator.ts";
403
+ function _define_property3(obj, key, value) {
404
+ if (key in obj) {
405
+ Object.defineProperty(obj, key, {
406
+ value,
407
+ enumerable: true,
408
+ configurable: true,
409
+ writable: true
410
+ });
411
+ } else {
412
+ obj[key] = value;
413
+ }
414
+ return obj;
415
+ }
416
+ var __dxlog_file3 = "/__w/dxos/dxos/packages/common/feed-store/src/feed-set-iterator.ts";
366
417
  var defaultFeedSetIteratorOptions = {
367
418
  stallTimeout: 1e3
368
419
  };
420
+ var _inspect_custom2 = inspect2.custom;
369
421
  var FeedSetIterator = class extends AbstractFeedIterator {
370
- constructor(_selector, options = defaultFeedSetIteratorOptions) {
371
- super(), this._selector = _selector, this.options = options, this._feedQueues = new ComplexMap(PublicKey.hash), this._trigger = new Trigger3({
372
- autoReset: true
373
- }), this._subscriptions = new SubscriptionList(), this.stalled = new Event2();
374
- invariant3(_selector, void 0, {
375
- F: __dxlog_file3,
376
- L: 55,
377
- S: this,
378
- A: [
379
- "_selector",
380
- ""
381
- ]
382
- });
383
- invariant3(options, void 0, {
384
- F: __dxlog_file3,
385
- L: 56,
386
- S: this,
387
- A: [
388
- "options",
389
- ""
390
- ]
391
- });
392
- }
393
- [inspect2.custom]() {
422
+ [_inspect_custom2]() {
394
423
  return inspectObject2(this);
395
424
  }
396
425
  toJSON() {
@@ -533,9 +562,32 @@ var FeedSetIterator = class extends AbstractFeedIterator {
533
562
  await this._trigger.wait();
534
563
  }
535
564
  }
565
+ constructor(_selector, options = defaultFeedSetIteratorOptions) {
566
+ super(), _define_property3(this, "_selector", void 0), _define_property3(this, "options", void 0), _define_property3(this, "_feedQueues", void 0), _define_property3(this, "_trigger", void 0), _define_property3(this, "_subscriptions", void 0), _define_property3(this, "stalled", void 0), this._selector = _selector, this.options = options, this._feedQueues = new ComplexMap(PublicKey.hash), this._trigger = new Trigger3({
567
+ autoReset: true
568
+ }), this._subscriptions = new SubscriptionList(), this.stalled = new Event2();
569
+ invariant3(_selector, void 0, {
570
+ F: __dxlog_file3,
571
+ L: 55,
572
+ S: this,
573
+ A: [
574
+ "_selector",
575
+ ""
576
+ ]
577
+ });
578
+ invariant3(options, void 0, {
579
+ F: __dxlog_file3,
580
+ L: 56,
581
+ S: this,
582
+ A: [
583
+ "options",
584
+ ""
585
+ ]
586
+ });
587
+ }
536
588
  };
537
589
 
538
- // packages/common/feed-store/src/feed-writer.ts
590
+ // src/feed-writer.ts
539
591
  var createFeedWriter = (cb) => ({
540
592
  write: async (data) => {
541
593
  return cb(data);
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/feed-iterator.ts", "../../../src/feed-queue.ts", "../../../src/feed-set-iterator.ts", "../../../src/feed-writer.ts"],
4
- "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\nimport safeRace from 'race-as-promised';\n\nimport { Trigger } from '@dxos/async';\nimport { invariant } from '@dxos/invariant';\nimport { log } from '@dxos/log';\n\nimport { FeedQueue } from './feed-queue';\nimport { type FeedWrapper } from './feed-wrapper';\nimport { type FeedBlock } from './types';\n\n/**\n * Base class for an async iterable feed.\n */\nexport abstract class AbstractFeedIterator<T> implements AsyncIterable<FeedBlock<T>> {\n private readonly _stopTrigger = new Trigger();\n\n protected _open = false;\n protected _running = false;\n\n toJSON(): { open: boolean; running: boolean } {\n return {\n open: this.isOpen,\n running: this.isRunning,\n };\n }\n\n get isOpen() {\n return this._open;\n }\n\n get isRunning() {\n return this._running;\n }\n\n async open(): Promise<void> {\n if (!this._open) {\n log('opening...');\n await this._onOpen();\n this._open = true;\n\n await this.start();\n log('opened');\n }\n }\n\n async close(): Promise<void> {\n if (this._open) {\n log('closing...');\n await this.stop();\n\n await this._onClose();\n this._open = false;\n log('closed');\n }\n }\n\n async start(): Promise<void> {\n invariant(this._open);\n if (!this._running) {\n this._running = true;\n }\n }\n\n async stop(): Promise<void> {\n invariant(this._open);\n if (this._running) {\n this._running = false;\n this._stopTrigger.wake();\n }\n }\n\n //\n // AsyncIterable\n //\n\n [Symbol.asyncIterator]() {\n return this._generator();\n }\n\n async *_generator() {\n log('started');\n while (this._running) {\n // https://github.com/nodejs/node/issues/17469\n const block = await safeRace([this._stopTrigger.wait(), this._nextBlock()]);\n\n if (block === undefined) {\n break;\n }\n\n yield block;\n }\n\n log('stopped');\n }\n\n abstract _onOpen(): Promise<void>;\n abstract _onClose(): Promise<void>;\n abstract _nextBlock(): Promise<FeedBlock<T> | undefined>;\n}\n\n/**\n * Iterator that reads blocks from a single feed.\n */\nexport class FeedIterator<T extends {}> extends AbstractFeedIterator<T> {\n private readonly _queue: FeedQueue<T>;\n\n constructor(private readonly _feed: FeedWrapper<T>) {\n super();\n this._queue = new FeedQueue<T>(this._feed);\n }\n\n override async _onOpen(): Promise<void> {\n await this._queue.open();\n }\n\n override async _onClose(): Promise<void> {\n await this._queue.close();\n }\n\n override async _nextBlock(): Promise<FeedBlock<T> | undefined> {\n return this._queue.pop();\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { inspect } from 'node:util';\nimport { Writable } from 'streamx';\n\nimport { Event, latch, Trigger } from '@dxos/async';\nimport { inspectObject } from '@dxos/debug';\nimport type { ReadStreamOptions } from '@dxos/hypercore';\nimport { invariant } from '@dxos/invariant';\nimport { log } from '@dxos/log';\n\nimport { type FeedWrapper } from './feed-wrapper';\nimport { type FeedBlock } from './types';\n\nexport const defaultReadStreamOptions: ReadStreamOptions = {\n live: true, // Keep reading until closed.\n batch: 1024, // Read in batches.\n};\n\nexport type FeedQueueOptions = {};\n\n/**\n * Async queue using an AsyncIterator created from a hypercore.\n */\nexport class FeedQueue<T extends {}> {\n public updated = new Event<FeedQueue<T>>();\n\n private readonly _messageTrigger = new Trigger<FeedBlock<T>>({\n autoReset: true,\n });\n\n private _feedConsumer?: Writable = undefined;\n private _next?: () => void;\n private _currentBlock?: FeedBlock<T> = undefined;\n private _index = -1;\n\n // prettier-ignore\n constructor(\n private readonly _feed: FeedWrapper<T>,\n private readonly _options: FeedQueueOptions = {},\n ) {}\n\n [inspect.custom](): string {\n return inspectObject(this);\n }\n\n toJSON() {\n return {\n feedKey: this._feed.key,\n index: this.index,\n length: this.length,\n open: this.isOpen,\n };\n }\n\n get feed() {\n return this._feed;\n }\n\n get isOpen(): boolean {\n return Boolean(this._feedConsumer);\n }\n\n get length(): number {\n return this._feed.properties.length;\n }\n\n /**\n * Index (seq) of the NEXT block to be read, or -1 if not open.\n */\n get index() {\n return this._index;\n }\n\n /**\n * Opens (or reopens) the queue.\n * @param options.start Starting index. First mutation to be read would have `seq == options.start`.\n */\n async open(options: ReadStreamOptions = {}): Promise<void> {\n if (this.isOpen) {\n // TODO(burdon): Warn if re-opening (e.g., with different starting point).\n return;\n }\n\n this._index = options.start ?? 0;\n // if (this._index !== 0) {\n // console.warn('Start index not yet supported.');\n // }\n\n log('opening', { feedKey: this._feed.key });\n\n // TODO(burdon): Open with starting range.\n const opts = Object.assign({}, defaultReadStreamOptions, options);\n const feedStream = this._feed.createReadableStream(opts);\n\n this._feedConsumer = new Writable({\n write: (data: any, next: () => void) => {\n this._next = () => {\n this._next = undefined;\n this._currentBlock = undefined;\n this._index++;\n next();\n };\n\n this._currentBlock = {\n feedKey: this._feed.key,\n seq: this._index,\n data,\n };\n\n this._messageTrigger.wake(this._currentBlock);\n this.updated.emit(this);\n },\n });\n\n const onClose = () => {\n this.feed.core.off('close', onClose);\n this._feedConsumer?.off('close', onClose);\n this._feedConsumer?.off('error', onError);\n\n this._destroyConsumer();\n };\n\n const onError = (err?: Error) => {\n if (!err) {\n return;\n }\n\n if (err.message === 'Writable stream closed prematurely' || err.message === 'Feed is closed') {\n return;\n }\n\n log.catch(err, { feedKey: this._feed.key });\n };\n\n // Called if feed is closed externally.\n this._feed.core.once('close', onClose);\n this._feedConsumer.on('error', onError);\n\n // Called when queue is closed. Throws exception if waiting for `pop`.\n this._feedConsumer.once('close', onClose);\n\n // Pipe readable stream into writable consumer.\n feedStream.pipe(this._feedConsumer, (err) => {\n if (err) {\n onError(err);\n }\n this._destroyConsumer();\n });\n\n log('opened');\n }\n\n /**\n * Closes the queue.\n */\n async close(): Promise<void> {\n if (this.isOpen) {\n invariant(this._feedConsumer);\n invariant(!this._feed.properties.closed);\n\n log('closing', { feedKey: this._feed.key });\n const [closed, setClosed] = latch();\n this._feedConsumer.once('close', setClosed);\n this._feedConsumer.destroy();\n this._next?.(); // Release any message currently in the queue (otherwise destroy will block).\n await closed();\n log('closed');\n }\n }\n\n /**\n * Get the block at the head of the queue without removing it.\n */\n peek(): FeedBlock<T> | undefined {\n return this._currentBlock;\n }\n\n /**\n * Pop block at the head of the queue.\n */\n async pop(): Promise<FeedBlock<T>> {\n if (!this.isOpen) {\n throw new Error(`Queue closed: ${this.feed.key.truncate()}`);\n }\n\n let block = this.peek();\n if (!block) {\n block = await this._messageTrigger.wait();\n }\n\n if (block) {\n this._next?.();\n }\n\n return block;\n }\n\n private _destroyConsumer(): void {\n if (this._feedConsumer) {\n log('queue closed', { feedKey: this._feed.key });\n this._feedConsumer = undefined;\n this._next = undefined;\n this._currentBlock = undefined;\n this._index = -1;\n }\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { inspect } from 'node:util';\n\nimport { Event, SubscriptionList, Trigger } from '@dxos/async';\nimport { inspectObject } from '@dxos/debug';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { ComplexMap, isNonNullable } from '@dxos/util';\n\nimport { AbstractFeedIterator } from './feed-iterator';\nimport { FeedQueue } from './feed-queue';\nimport { type FeedWrapper } from './feed-wrapper';\nimport { type FeedBlock } from './types';\n\n/**\n * Select next block.\n */\nexport type FeedBlockSelector<T> = (blocks: FeedBlock<T>[]) => number | undefined;\n\nexport type FeedIndex = {\n feedKey: PublicKey;\n index: number;\n};\n\nexport type FeedSetIteratorOptions = {\n // TODO(burdon): Should we remove this and assume the feeds are positioned before adding?\n start?: FeedIndex[];\n stallTimeout?: number;\n};\n\nexport const defaultFeedSetIteratorOptions = {\n stallTimeout: 1000,\n};\n\n/**\n * Iterator that reads blocks from multiple feeds, ordering them based on a traversal callback.\n */\nexport class FeedSetIterator<T extends {}> extends AbstractFeedIterator<T> {\n private readonly _feedQueues = new ComplexMap<PublicKey, FeedQueue<T>>(PublicKey.hash);\n\n private readonly _trigger = new Trigger({ autoReset: true });\n private readonly _subscriptions = new SubscriptionList();\n\n public readonly stalled = new Event<FeedSetIterator<T>>();\n\n constructor(\n private readonly _selector: FeedBlockSelector<T>,\n public readonly options: FeedSetIteratorOptions = defaultFeedSetIteratorOptions,\n ) {\n super();\n invariant(_selector);\n invariant(options);\n }\n\n [inspect.custom](): string {\n return inspectObject(this);\n }\n\n override toJSON(): { open: boolean; running: boolean; indexes: FeedIndex[] } {\n return {\n open: this.isOpen,\n running: this.isRunning,\n indexes: this.indexes,\n };\n }\n\n get size() {\n return this._feedQueues.size;\n }\n\n get feeds(): FeedWrapper<T>[] {\n return Array.from(this._feedQueues.values()).map((feedQueue) => feedQueue.feed);\n }\n\n get indexes(): FeedIndex[] {\n return Array.from(this._feedQueues.values()).map((feedQueue) => ({\n feedKey: feedQueue.feed.key,\n index: feedQueue.index,\n }));\n }\n\n reiterateBlock(block: FeedBlock<T>): void {\n this._trigger.wake();\n }\n\n async addFeed(feed: FeedWrapper<T>): Promise<void> {\n invariant(!this._feedQueues.has(feed.key), `Feed already added: ${feed.key}`);\n invariant(feed.properties.opened);\n log('feed added', { feedKey: feed.key });\n\n // Create queue and listen for updates.\n const queue = new FeedQueue<T>(feed);\n this._feedQueues.set(feed.key, queue);\n this._subscriptions.add(\n queue.updated.on(() => {\n this._trigger.wake();\n }),\n );\n\n await queue.open({\n start: this.options.start?.find((index) => index.feedKey.equals(feed.key))?.index,\n });\n\n // Wake when feed added or queue updated.\n this._trigger.wake();\n }\n\n hasFeed(feedKey: PublicKey): boolean {\n return this._feedQueues.has(feedKey);\n }\n\n override async _onOpen(): Promise<void> {\n for (const queue of this._feedQueues.values()) {\n await queue.open();\n }\n }\n\n override async _onClose(): Promise<void> {\n this._subscriptions.clear();\n await Promise.all(Array.from(this._feedQueues.values()).map((queue) => queue.close()));\n\n // Wake when feed added or queue updated.\n this._trigger.wake();\n }\n\n /**\n * Gets the next block from the selected queue.\n */\n override async _nextBlock(): Promise<FeedBlock<T> | undefined> {\n let t: NodeJS.Timeout | undefined;\n\n while (this._running) {\n // Get blocks from the head of each queue.\n const queues = Array.from(this._feedQueues.values());\n const blocks = queues.map((queue) => queue.peek()).filter(isNonNullable);\n if (blocks.length) {\n // Get the selected block from candidates.\n const idx = this._selector(blocks);\n log('selected', { idx, blocks });\n if (idx === undefined) {\n // Timeout if all candidates are rejected.\n if (t === undefined) {\n t = setTimeout(() => {\n this.stalled.emit(this);\n this._trigger.wake();\n }, this.options.stallTimeout);\n }\n } else {\n if (t !== undefined) {\n clearTimeout(t);\n t = undefined;\n }\n if (idx >= blocks.length) {\n throw new Error(`Index out of bounds: ${idx} of ${blocks.length}`);\n }\n\n // Pop from queue.\n const queue = this._feedQueues.get(blocks[idx].feedKey)!;\n log('popping', queue.toJSON());\n try {\n const message = await queue.pop();\n invariant(message === blocks[idx]);\n return message;\n } catch (err) {\n // TODO(burdon): Same queue closed twice.\n log.warn('queue closed', { feedKey: queue.feed.key });\n // console.log(Array.from(this._feedQueues.values()));\n }\n }\n }\n\n // Wait until feed added, new block, or closing.\n await this._trigger.wait();\n }\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { type PublicKey } from '@dxos/keys';\n\nexport type WriteReceipt = {\n feedKey: PublicKey;\n seq: number;\n};\n\nexport type WriteOptions = {\n /**\n * Called after the write is complete.\n * Runs and completes before the mutation is read from the pipeline.\n */\n afterWrite?: (receipt: WriteReceipt) => Promise<void>;\n};\n\nexport interface FeedWriter<T extends {}> {\n /**\n * Write data to the feed.\n * Awaits `afterWrite` before returning.\n */\n write(data: T, options?: WriteOptions): Promise<WriteReceipt>;\n}\n\nexport const createFeedWriter = <T extends {}>(cb: (data: T) => Promise<WriteReceipt>): FeedWriter<T> => ({\n write: async (data: T) => {\n return cb(data);\n },\n});\n\nexport const writeMessages = async <T extends {}>(writer: FeedWriter<T>, messages: T[]): Promise<WriteReceipt[]> => {\n const receipts: WriteReceipt[] = [];\n // NOTE: Write messages sequentially.\n for (const message of messages) {\n receipts.push(await writer.write(message));\n }\n return receipts;\n};\n"],
5
- "mappings": "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",
6
- "names": ["safeRace", "Trigger", "invariant", "log", "inspect", "Writable", "Event", "latch", "Trigger", "inspectObject", "invariant", "log", "defaultReadStreamOptions", "live", "batch", "FeedQueue", "_feed", "_options", "updated", "_messageTrigger", "autoReset", "_feedConsumer", "undefined", "_currentBlock", "_index", "custom", "toJSON", "feedKey", "key", "index", "length", "open", "isOpen", "feed", "Boolean", "properties", "options", "start", "opts", "Object", "assign", "feedStream", "createReadableStream", "write", "data", "next", "_next", "seq", "wake", "emit", "onClose", "core", "off", "onError", "_destroyConsumer", "err", "message", "catch", "once", "on", "pipe", "close", "closed", "setClosed", "destroy", "peek", "pop", "Error", "truncate", "block", "wait", "AbstractFeedIterator", "_stopTrigger", "Trigger", "_open", "_running", "toJSON", "open", "isOpen", "running", "isRunning", "log", "_onOpen", "start", "close", "stop", "_onClose", "invariant", "wake", "Symbol", "asyncIterator", "_generator", "block", "safeRace", "wait", "_nextBlock", "undefined", "FeedIterator", "_feed", "_queue", "FeedQueue", "pop", "inspect", "Event", "SubscriptionList", "Trigger", "inspectObject", "invariant", "PublicKey", "log", "ComplexMap", "isNonNullable", "defaultFeedSetIteratorOptions", "stallTimeout", "FeedSetIterator", "AbstractFeedIterator", "_selector", "options", "_feedQueues", "ComplexMap", "PublicKey", "hash", "_trigger", "Trigger", "autoReset", "_subscriptions", "SubscriptionList", "stalled", "Event", "invariant", "inspect", "custom", "inspectObject", "toJSON", "open", "isOpen", "running", "isRunning", "indexes", "size", "feeds", "Array", "from", "values", "map", "feedQueue", "feed", "feedKey", "key", "index", "reiterateBlock", "block", "wake", "addFeed", "has", "properties", "opened", "log", "queue", "FeedQueue", "set", "add", "updated", "on", "start", "find", "equals", "hasFeed", "_onOpen", "_onClose", "clear", "Promise", "all", "close", "_nextBlock", "t", "_running", "queues", "blocks", "peek", "filter", "isNonNullable", "length", "idx", "undefined", "setTimeout", "emit", "clearTimeout", "Error", "get", "message", "pop", "err", "warn", "wait", "createFeedWriter", "cb", "write", "data", "writeMessages", "writer", "messages", "receipts", "message", "push"]
4
+ "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\nimport safeRace from 'race-as-promised';\n\nimport { Trigger } from '@dxos/async';\nimport { invariant } from '@dxos/invariant';\nimport { log } from '@dxos/log';\n\nimport { FeedQueue } from './feed-queue';\nimport { type FeedWrapper } from './feed-wrapper';\nimport { type FeedBlock } from './types';\n\n/**\n * Base class for an async iterable feed.\n */\nexport abstract class AbstractFeedIterator<T> implements AsyncIterable<FeedBlock<T>> {\n private readonly _stopTrigger = new Trigger();\n\n protected _open = false;\n protected _running = false;\n\n toJSON(): { open: boolean; running: boolean } {\n return {\n open: this.isOpen,\n running: this.isRunning,\n };\n }\n\n get isOpen() {\n return this._open;\n }\n\n get isRunning() {\n return this._running;\n }\n\n async open(): Promise<void> {\n if (!this._open) {\n log('opening...');\n await this._onOpen();\n this._open = true;\n\n await this.start();\n log('opened');\n }\n }\n\n async close(): Promise<void> {\n if (this._open) {\n log('closing...');\n await this.stop();\n\n await this._onClose();\n this._open = false;\n log('closed');\n }\n }\n\n async start(): Promise<void> {\n invariant(this._open);\n if (!this._running) {\n this._running = true;\n }\n }\n\n async stop(): Promise<void> {\n invariant(this._open);\n if (this._running) {\n this._running = false;\n this._stopTrigger.wake();\n }\n }\n\n //\n // AsyncIterable\n //\n\n [Symbol.asyncIterator]() {\n return this._generator();\n }\n\n async *_generator() {\n log('started');\n while (this._running) {\n // https://github.com/nodejs/node/issues/17469\n const block = await safeRace([this._stopTrigger.wait(), this._nextBlock()]);\n\n if (block === undefined) {\n break;\n }\n\n yield block;\n }\n\n log('stopped');\n }\n\n abstract _onOpen(): Promise<void>;\n abstract _onClose(): Promise<void>;\n abstract _nextBlock(): Promise<FeedBlock<T> | undefined>;\n}\n\n/**\n * Iterator that reads blocks from a single feed.\n */\nexport class FeedIterator<T extends {}> extends AbstractFeedIterator<T> {\n private readonly _queue: FeedQueue<T>;\n\n constructor(private readonly _feed: FeedWrapper<T>) {\n super();\n this._queue = new FeedQueue<T>(this._feed);\n }\n\n override async _onOpen(): Promise<void> {\n await this._queue.open();\n }\n\n override async _onClose(): Promise<void> {\n await this._queue.close();\n }\n\n override async _nextBlock(): Promise<FeedBlock<T> | undefined> {\n return this._queue.pop();\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { inspect } from 'node:util';\n\nimport { Writable } from 'streamx';\n\nimport { Event, Trigger, latch } from '@dxos/async';\nimport { inspectObject } from '@dxos/debug';\nimport type { ReadStreamOptions } from '@dxos/hypercore';\nimport { invariant } from '@dxos/invariant';\nimport { log } from '@dxos/log';\n\nimport { type FeedWrapper } from './feed-wrapper';\nimport { type FeedBlock } from './types';\n\nexport const defaultReadStreamOptions: ReadStreamOptions = {\n live: true, // Keep reading until closed.\n batch: 1024, // Read in batches.\n};\n\nexport type FeedQueueOptions = {};\n\n/**\n * Async queue using an AsyncIterator created from a hypercore.\n */\nexport class FeedQueue<T extends {}> {\n public updated = new Event<FeedQueue<T>>();\n\n private readonly _messageTrigger = new Trigger<FeedBlock<T>>({\n autoReset: true,\n });\n\n private _feedConsumer?: Writable = undefined;\n private _next?: () => void;\n private _currentBlock?: FeedBlock<T> = undefined;\n private _index = -1;\n\n // prettier-ignore\n constructor(\n private readonly _feed: FeedWrapper<T>,\n private readonly _options: FeedQueueOptions = {},\n ) {}\n\n [inspect.custom](): string {\n return inspectObject(this);\n }\n\n toJSON() {\n return {\n feedKey: this._feed.key,\n index: this.index,\n length: this.length,\n open: this.isOpen,\n };\n }\n\n get feed() {\n return this._feed;\n }\n\n get isOpen(): boolean {\n return Boolean(this._feedConsumer);\n }\n\n get length(): number {\n return this._feed.properties.length;\n }\n\n /**\n * Index (seq) of the NEXT block to be read, or -1 if not open.\n */\n get index() {\n return this._index;\n }\n\n /**\n * Opens (or reopens) the queue.\n * @param options.start Starting index. First mutation to be read would have `seq == options.start`.\n */\n async open(options: ReadStreamOptions = {}): Promise<void> {\n if (this.isOpen) {\n // TODO(burdon): Warn if re-opening (e.g., with different starting point).\n return;\n }\n\n this._index = options.start ?? 0;\n // if (this._index !== 0) {\n // console.warn('Start index not yet supported.');\n // }\n\n log('opening', { feedKey: this._feed.key });\n\n // TODO(burdon): Open with starting range.\n const opts = Object.assign({}, defaultReadStreamOptions, options);\n const feedStream = this._feed.createReadableStream(opts);\n\n this._feedConsumer = new Writable({\n write: (data: any, next: () => void) => {\n this._next = () => {\n this._next = undefined;\n this._currentBlock = undefined;\n this._index++;\n next();\n };\n\n this._currentBlock = {\n feedKey: this._feed.key,\n seq: this._index,\n data,\n };\n\n this._messageTrigger.wake(this._currentBlock);\n this.updated.emit(this);\n },\n });\n\n const onClose = () => {\n this.feed.core.off('close', onClose);\n this._feedConsumer?.off('close', onClose);\n this._feedConsumer?.off('error', onError);\n\n this._destroyConsumer();\n };\n\n const onError = (err?: Error) => {\n if (!this.isOpen) {\n return;\n }\n if (!err) {\n return;\n }\n if (err.message === 'Writable stream closed prematurely' || err.message === 'Feed is closed') {\n return;\n }\n\n log.catch(err, { feedKey: this._feed.key });\n };\n\n // Called if feed is closed externally.\n this._feed.core.once('close', onClose);\n this._feedConsumer.on('error', onError);\n\n // Called when queue is closed. Throws exception if waiting for `pop`.\n this._feedConsumer.once('close', onClose);\n\n // Pipe readable stream into writable consumer.\n feedStream.pipe(this._feedConsumer, (err) => {\n if (err) {\n onError(err);\n }\n this._destroyConsumer();\n });\n\n log('opened');\n }\n\n /**\n * Closes the queue.\n */\n async close(): Promise<void> {\n if (this.isOpen) {\n invariant(this._feedConsumer);\n invariant(!this._feed.properties.closed);\n\n log('closing', { feedKey: this._feed.key });\n const [closed, setClosed] = latch();\n this._feedConsumer.once('close', setClosed);\n this._feedConsumer.destroy();\n this._next?.(); // Release any message currently in the queue (otherwise destroy will block).\n await closed();\n log('closed');\n }\n }\n\n /**\n * Get the block at the head of the queue without removing it.\n */\n peek(): FeedBlock<T> | undefined {\n return this._currentBlock;\n }\n\n /**\n * Pop block at the head of the queue.\n */\n async pop(): Promise<FeedBlock<T>> {\n if (!this.isOpen) {\n throw new Error(`Queue closed: ${this.feed.key.truncate()}`);\n }\n\n let block = this.peek();\n if (!block) {\n block = await this._messageTrigger.wait();\n }\n\n if (block) {\n this._next?.();\n }\n\n return block;\n }\n\n private _destroyConsumer(): void {\n if (this._feedConsumer) {\n log('queue closed', { feedKey: this._feed.key });\n this._feedConsumer = undefined;\n this._next = undefined;\n this._currentBlock = undefined;\n this._index = -1;\n }\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { inspect } from 'node:util';\n\nimport { Event, SubscriptionList, Trigger } from '@dxos/async';\nimport { inspectObject } from '@dxos/debug';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { ComplexMap, isNonNullable } from '@dxos/util';\n\nimport { AbstractFeedIterator } from './feed-iterator';\nimport { FeedQueue } from './feed-queue';\nimport { type FeedWrapper } from './feed-wrapper';\nimport { type FeedBlock } from './types';\n\n/**\n * Select next block.\n */\nexport type FeedBlockSelector<T> = (blocks: FeedBlock<T>[]) => number | undefined;\n\nexport type FeedIndex = {\n feedKey: PublicKey;\n index: number;\n};\n\nexport type FeedSetIteratorOptions = {\n // TODO(burdon): Should we remove this and assume the feeds are positioned before adding?\n start?: FeedIndex[];\n stallTimeout?: number;\n};\n\nexport const defaultFeedSetIteratorOptions = {\n stallTimeout: 1000,\n};\n\n/**\n * Iterator that reads blocks from multiple feeds, ordering them based on a traversal callback.\n */\nexport class FeedSetIterator<T extends {}> extends AbstractFeedIterator<T> {\n private readonly _feedQueues = new ComplexMap<PublicKey, FeedQueue<T>>(PublicKey.hash);\n\n private readonly _trigger = new Trigger({ autoReset: true });\n private readonly _subscriptions = new SubscriptionList();\n\n public readonly stalled = new Event<FeedSetIterator<T>>();\n\n constructor(\n private readonly _selector: FeedBlockSelector<T>,\n public readonly options: FeedSetIteratorOptions = defaultFeedSetIteratorOptions,\n ) {\n super();\n invariant(_selector);\n invariant(options);\n }\n\n [inspect.custom](): string {\n return inspectObject(this);\n }\n\n override toJSON(): { open: boolean; running: boolean; indexes: FeedIndex[] } {\n return {\n open: this.isOpen,\n running: this.isRunning,\n indexes: this.indexes,\n };\n }\n\n get size() {\n return this._feedQueues.size;\n }\n\n get feeds(): FeedWrapper<T>[] {\n return Array.from(this._feedQueues.values()).map((feedQueue) => feedQueue.feed);\n }\n\n get indexes(): FeedIndex[] {\n return Array.from(this._feedQueues.values()).map((feedQueue) => ({\n feedKey: feedQueue.feed.key,\n index: feedQueue.index,\n }));\n }\n\n reiterateBlock(block: FeedBlock<T>): void {\n this._trigger.wake();\n }\n\n async addFeed(feed: FeedWrapper<T>): Promise<void> {\n invariant(!this._feedQueues.has(feed.key), `Feed already added: ${feed.key}`);\n invariant(feed.properties.opened);\n log('feed added', { feedKey: feed.key });\n\n // Create queue and listen for updates.\n const queue = new FeedQueue<T>(feed);\n this._feedQueues.set(feed.key, queue);\n this._subscriptions.add(\n queue.updated.on(() => {\n this._trigger.wake();\n }),\n );\n\n await queue.open({\n start: this.options.start?.find((index) => index.feedKey.equals(feed.key))?.index,\n });\n\n // Wake when feed added or queue updated.\n this._trigger.wake();\n }\n\n hasFeed(feedKey: PublicKey): boolean {\n return this._feedQueues.has(feedKey);\n }\n\n override async _onOpen(): Promise<void> {\n for (const queue of this._feedQueues.values()) {\n await queue.open();\n }\n }\n\n override async _onClose(): Promise<void> {\n this._subscriptions.clear();\n await Promise.all(Array.from(this._feedQueues.values()).map((queue) => queue.close()));\n\n // Wake when feed added or queue updated.\n this._trigger.wake();\n }\n\n /**\n * Gets the next block from the selected queue.\n */\n override async _nextBlock(): Promise<FeedBlock<T> | undefined> {\n let t: NodeJS.Timeout | undefined;\n\n while (this._running) {\n // Get blocks from the head of each queue.\n const queues = Array.from(this._feedQueues.values());\n const blocks = queues.map((queue) => queue.peek()).filter(isNonNullable);\n if (blocks.length) {\n // Get the selected block from candidates.\n const idx = this._selector(blocks);\n log('selected', { idx, blocks });\n if (idx === undefined) {\n // Timeout if all candidates are rejected.\n if (t === undefined) {\n t = setTimeout(() => {\n this.stalled.emit(this);\n this._trigger.wake();\n }, this.options.stallTimeout);\n }\n } else {\n if (t !== undefined) {\n clearTimeout(t);\n t = undefined;\n }\n if (idx >= blocks.length) {\n throw new Error(`Index out of bounds: ${idx} of ${blocks.length}`);\n }\n\n // Pop from queue.\n const queue = this._feedQueues.get(blocks[idx].feedKey)!;\n log('popping', queue.toJSON());\n try {\n const message = await queue.pop();\n invariant(message === blocks[idx]);\n return message;\n } catch (err) {\n // TODO(burdon): Same queue closed twice.\n log.warn('queue closed', { feedKey: queue.feed.key });\n // console.log(Array.from(this._feedQueues.values()));\n }\n }\n }\n\n // Wait until feed added, new block, or closing.\n await this._trigger.wait();\n }\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { type PublicKey } from '@dxos/keys';\n\nexport type WriteReceipt = {\n feedKey: PublicKey;\n seq: number;\n};\n\nexport type WriteOptions = {\n /**\n * Called after the write is complete.\n * Runs and completes before the mutation is read from the pipeline.\n */\n afterWrite?: (receipt: WriteReceipt) => Promise<void>;\n};\n\nexport interface FeedWriter<T extends {}> {\n /**\n * Write data to the feed.\n * Awaits `afterWrite` before returning.\n */\n write(data: T, options?: WriteOptions): Promise<WriteReceipt>;\n}\n\nexport const createFeedWriter = <T extends {}>(cb: (data: T) => Promise<WriteReceipt>): FeedWriter<T> => ({\n write: async (data: T) => {\n return cb(data);\n },\n});\n\nexport const writeMessages = async <T extends {}>(writer: FeedWriter<T>, messages: T[]): Promise<WriteReceipt[]> => {\n const receipts: WriteReceipt[] = [];\n // NOTE: Write messages sequentially.\n for (const message of messages) {\n receipts.push(await writer.write(message));\n }\n return receipts;\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["safeRace", "Trigger", "invariant", "log", "inspect", "Writable", "Event", "Trigger", "latch", "inspectObject", "invariant", "log", "defaultReadStreamOptions", "live", "batch", "custom", "FeedQueue", "toJSON", "feedKey", "_feed", "key", "index", "length", "open", "isOpen", "feed", "Boolean", "_feedConsumer", "properties", "_index", "options", "start", "opts", "Object", "assign", "feedStream", "createReadableStream", "write", "data", "next", "_next", "undefined", "_currentBlock", "seq", "_messageTrigger", "wake", "updated", "emit", "onClose", "core", "off", "onError", "_destroyConsumer", "err", "message", "catch", "once", "on", "pipe", "close", "closed", "setClosed", "destroy", "peek", "pop", "Error", "truncate", "block", "wait", "_options", "autoReset", "AbstractFeedIterator", "toJSON", "open", "isOpen", "running", "isRunning", "_open", "_running", "log", "_onOpen", "start", "close", "stop", "_onClose", "invariant", "_stopTrigger", "wake", "Symbol", "asyncIterator", "_generator", "block", "safeRace", "wait", "_nextBlock", "undefined", "_define_property", "Trigger", "FeedIterator", "_queue", "pop", "_feed", "FeedQueue", "inspect", "Event", "SubscriptionList", "Trigger", "inspectObject", "invariant", "PublicKey", "log", "ComplexMap", "isNonNullable", "defaultFeedSetIteratorOptions", "stallTimeout", "inspect", "custom", "FeedSetIterator", "AbstractFeedIterator", "inspectObject", "toJSON", "open", "isOpen", "running", "isRunning", "indexes", "size", "_feedQueues", "feeds", "Array", "from", "values", "map", "feedQueue", "feed", "feedKey", "key", "index", "reiterateBlock", "block", "_trigger", "wake", "addFeed", "invariant", "has", "properties", "opened", "log", "queue", "FeedQueue", "set", "_subscriptions", "add", "updated", "on", "start", "options", "find", "equals", "hasFeed", "_onOpen", "_onClose", "clear", "Promise", "all", "close", "_nextBlock", "t", "_running", "queues", "blocks", "peek", "filter", "isNonNullable", "length", "idx", "_selector", "undefined", "setTimeout", "stalled", "emit", "clearTimeout", "Error", "get", "message", "pop", "err", "warn", "wait", "_define_property", "ComplexMap", "PublicKey", "hash", "Trigger", "autoReset", "SubscriptionList", "Event", "createFeedWriter", "cb", "write", "data", "writeMessages", "writer", "messages", "receipts", "message", "push"]
7
7
  }
@@ -1 +1 @@
1
- {"inputs":{"packages/common/feed-store/src/feed-wrapper.ts":{"bytes":34043,"imports":[{"path":"node:util","kind":"import-statement","external":true},{"path":"streamx","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"packages/common/feed-store/src/feed-factory.ts":{"bytes":9099,"imports":[{"path":"lodash.defaultsdeep","kind":"import-statement","external":true},{"path":"@dxos/crypto","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/hypercore","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"packages/common/feed-store/src/feed-wrapper.ts","kind":"import-statement","original":"./feed-wrapper"}],"format":"esm"},"packages/common/feed-store/src/feed-queue.ts":{"bytes":19584,"imports":[{"path":"node:util","kind":"import-statement","external":true},{"path":"streamx","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"packages/common/feed-store/src/feed-iterator.ts":{"bytes":10127,"imports":[{"path":"race-as-promised","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"packages/common/feed-store/src/feed-queue.ts","kind":"import-statement","original":"./feed-queue"}],"format":"esm"},"packages/common/feed-store/src/feed-set-iterator.ts":{"bytes":20088,"imports":[{"path":"node:util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/common/feed-store/src/feed-iterator.ts","kind":"import-statement","original":"./feed-iterator"},{"path":"packages/common/feed-store/src/feed-queue.ts","kind":"import-statement","original":"./feed-queue"}],"format":"esm"},"packages/common/feed-store/src/feed-store.ts":{"bytes":12115,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"packages/common/feed-store/src/feed-writer.ts":{"bytes":2638,"imports":[],"format":"esm"},"packages/common/feed-store/src/types.ts":{"bytes":582,"imports":[],"format":"esm"},"packages/common/feed-store/src/index.ts":{"bytes":1156,"imports":[{"path":"packages/common/feed-store/src/feed-factory.ts","kind":"import-statement","original":"./feed-factory"},{"path":"packages/common/feed-store/src/feed-iterator.ts","kind":"import-statement","original":"./feed-iterator"},{"path":"packages/common/feed-store/src/feed-set-iterator.ts","kind":"import-statement","original":"./feed-set-iterator"},{"path":"packages/common/feed-store/src/feed-queue.ts","kind":"import-statement","original":"./feed-queue"},{"path":"packages/common/feed-store/src/feed-store.ts","kind":"import-statement","original":"./feed-store"},{"path":"packages/common/feed-store/src/feed-wrapper.ts","kind":"import-statement","original":"./feed-wrapper"},{"path":"packages/common/feed-store/src/feed-writer.ts","kind":"import-statement","original":"./feed-writer"},{"path":"packages/common/feed-store/src/types.ts","kind":"import-statement","original":"./types"}],"format":"esm"},"packages/common/feed-store/src/testing/mocks.ts":{"bytes":3449,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true}],"format":"esm"},"packages/common/feed-store/src/testing/test-generator.ts":{"bytes":5535,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/hypercore","kind":"import-statement","external":true},{"path":"@dxos/random","kind":"import-statement","external":true}],"format":"esm"},"packages/common/feed-store/src/testing/test-builder.ts":{"bytes":9638,"imports":[{"path":"@dxos/keyring","kind":"import-statement","external":true},{"path":"@dxos/random-access-storage","kind":"import-statement","external":true},{"path":"packages/common/feed-store/src/testing/test-generator.ts","kind":"import-statement","original":"./test-generator"},{"path":"packages/common/feed-store/src/feed-factory.ts","kind":"import-statement","original":"../feed-factory"},{"path":"packages/common/feed-store/src/feed-store.ts","kind":"import-statement","original":"../feed-store"}],"format":"esm"},"packages/common/feed-store/src/testing/index.ts":{"bytes":673,"imports":[{"path":"packages/common/feed-store/src/testing/mocks.ts","kind":"import-statement","original":"./mocks"},{"path":"packages/common/feed-store/src/testing/test-builder.ts","kind":"import-statement","original":"./test-builder"},{"path":"packages/common/feed-store/src/testing/test-generator.ts","kind":"import-statement","original":"./test-generator"}],"format":"esm"}},"outputs":{"packages/common/feed-store/dist/lib/node-esm/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":24428},"packages/common/feed-store/dist/lib/node-esm/index.mjs":{"imports":[{"path":"packages/common/feed-store/dist/lib/node-esm/chunk-AO5I2BX3.mjs","kind":"import-statement"},{"path":"race-as-promised","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true},{"path":"streamx","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"exports":["AbstractFeedIterator","FeedFactory","FeedIterator","FeedQueue","FeedSetIterator","FeedStore","FeedWrapper","createFeedWriter","defaultFeedSetIteratorOptions","defaultReadStreamOptions","writeMessages"],"entryPoint":"packages/common/feed-store/src/index.ts","inputs":{"packages/common/feed-store/src/index.ts":{"bytesInOutput":0},"packages/common/feed-store/src/feed-iterator.ts":{"bytesInOutput":2798},"packages/common/feed-store/src/feed-queue.ts":{"bytesInOutput":4925},"packages/common/feed-store/src/feed-set-iterator.ts":{"bytesInOutput":4933},"packages/common/feed-store/src/feed-writer.ts":{"bytesInOutput":273}},"bytes":13621},"packages/common/feed-store/dist/lib/node-esm/testing/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":9598},"packages/common/feed-store/dist/lib/node-esm/testing/index.mjs":{"imports":[{"path":"packages/common/feed-store/dist/lib/node-esm/chunk-AO5I2BX3.mjs","kind":"import-statement"},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/keyring","kind":"import-statement","external":true},{"path":"@dxos/random-access-storage","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/hypercore","kind":"import-statement","external":true},{"path":"@dxos/random","kind":"import-statement","external":true}],"exports":["MockFeedWriter","TestBuilder","TestGenerator","TestItemBuilder","defaultCodec","defaultTestBlockGenerator","defaultTestGenerator","defaultValueEncoding"],"entryPoint":"packages/common/feed-store/src/testing/index.ts","inputs":{"packages/common/feed-store/src/testing/mocks.ts":{"bytesInOutput":784},"packages/common/feed-store/src/testing/index.ts":{"bytesInOutput":0},"packages/common/feed-store/src/testing/test-builder.ts":{"bytesInOutput":1800},"packages/common/feed-store/src/testing/test-generator.ts":{"bytesInOutput":961}},"bytes":4144},"packages/common/feed-store/dist/lib/node-esm/chunk-AO5I2BX3.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":26156},"packages/common/feed-store/dist/lib/node-esm/chunk-AO5I2BX3.mjs":{"imports":[{"path":"node:util","kind":"import-statement","external":true},{"path":"streamx","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"lodash.defaultsdeep","kind":"import-statement","external":true},{"path":"@dxos/crypto","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/hypercore","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"exports":["FeedFactory","FeedStore","FeedWrapper"],"inputs":{"packages/common/feed-store/src/feed-wrapper.ts":{"bytesInOutput":8205},"packages/common/feed-store/src/feed-factory.ts":{"bytesInOutput":2015},"packages/common/feed-store/src/feed-store.ts":{"bytesInOutput":3129}},"bytes":13691}}}
1
+ {"inputs":{"src/feed-wrapper.ts":{"bytes":36897,"imports":[{"path":"node:util","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true},{"path":"streamx","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"src/feed-factory.ts":{"bytes":9571,"imports":[{"path":"lodash.defaultsdeep","kind":"import-statement","external":true},{"path":"@dxos/crypto","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/hypercore","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"src/feed-wrapper.ts","kind":"import-statement","original":"./feed-wrapper"}],"format":"esm"},"src/feed-queue.ts":{"bytes":20539,"imports":[{"path":"node:util","kind":"import-statement","external":true},{"path":"streamx","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"src/feed-iterator.ts":{"bytes":10629,"imports":[{"path":"race-as-promised","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"src/feed-queue.ts","kind":"import-statement","original":"./feed-queue"}],"format":"esm"},"src/feed-set-iterator.ts":{"bytes":20673,"imports":[{"path":"node:util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"src/feed-iterator.ts","kind":"import-statement","original":"./feed-iterator"},{"path":"src/feed-queue.ts","kind":"import-statement","original":"./feed-queue"}],"format":"esm"},"src/feed-store.ts":{"bytes":12603,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"src/feed-writer.ts":{"bytes":2625,"imports":[],"format":"esm"},"src/index.ts":{"bytes":1106,"imports":[{"path":"src/feed-factory.ts","kind":"import-statement","original":"./feed-factory"},{"path":"src/feed-iterator.ts","kind":"import-statement","original":"./feed-iterator"},{"path":"src/feed-set-iterator.ts","kind":"import-statement","original":"./feed-set-iterator"},{"path":"src/feed-queue.ts","kind":"import-statement","original":"./feed-queue"},{"path":"src/feed-store.ts","kind":"import-statement","original":"./feed-store"},{"path":"src/feed-wrapper.ts","kind":"import-statement","original":"./feed-wrapper"},{"path":"src/feed-writer.ts","kind":"import-statement","original":"./feed-writer"}],"format":"esm"},"src/testing/mocks.ts":{"bytes":3897,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true}],"format":"esm"},"src/testing/test-generator.ts":{"bytes":5965,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/hypercore","kind":"import-statement","external":true},{"path":"@dxos/random","kind":"import-statement","external":true}],"format":"esm"},"src/testing/test-builder.ts":{"bytes":10366,"imports":[{"path":"@dxos/keyring","kind":"import-statement","external":true},{"path":"@dxos/random-access-storage","kind":"import-statement","external":true},{"path":"src/feed-factory.ts","kind":"import-statement","original":"../feed-factory"},{"path":"src/feed-store.ts","kind":"import-statement","original":"../feed-store"},{"path":"src/testing/test-generator.ts","kind":"import-statement","original":"./test-generator"}],"format":"esm"},"src/testing/index.ts":{"bytes":660,"imports":[{"path":"src/testing/mocks.ts","kind":"import-statement","original":"./mocks"},{"path":"src/testing/test-builder.ts","kind":"import-statement","original":"./test-builder"},{"path":"src/testing/test-generator.ts","kind":"import-statement","original":"./test-generator"}],"format":"esm"}},"outputs":{"dist/lib/node-esm/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":25092},"dist/lib/node-esm/index.mjs":{"imports":[{"path":"dist/lib/node-esm/chunk-D4DVCY7Y.mjs","kind":"import-statement"},{"path":"race-as-promised","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true},{"path":"streamx","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"exports":["AbstractFeedIterator","FeedFactory","FeedIterator","FeedQueue","FeedSetIterator","FeedStore","FeedWrapper","createFeedWriter","defaultFeedSetIteratorOptions","defaultReadStreamOptions","writeMessages"],"entryPoint":"src/index.ts","inputs":{"src/index.ts":{"bytesInOutput":0},"src/feed-iterator.ts":{"bytesInOutput":3182},"src/feed-queue.ts":{"bytesInOutput":5641},"src/feed-set-iterator.ts":{"bytesInOutput":5488},"src/feed-writer.ts":{"bytesInOutput":273}},"bytes":15141},"dist/lib/node-esm/testing/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":9894},"dist/lib/node-esm/testing/index.mjs":{"imports":[{"path":"dist/lib/node-esm/chunk-D4DVCY7Y.mjs","kind":"import-statement"},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/keyring","kind":"import-statement","external":true},{"path":"@dxos/random-access-storage","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/hypercore","kind":"import-statement","external":true},{"path":"@dxos/random","kind":"import-statement","external":true}],"exports":["MockFeedWriter","TestBuilder","TestGenerator","TestItemBuilder","defaultCodec","defaultTestBlockGenerator","defaultTestGenerator","defaultValueEncoding"],"entryPoint":"src/testing/index.ts","inputs":{"src/testing/mocks.ts":{"bytesInOutput":1161},"src/testing/index.ts":{"bytesInOutput":0},"src/testing/test-builder.ts":{"bytesInOutput":2341},"src/testing/test-generator.ts":{"bytesInOutput":1307}},"bytes":5300},"dist/lib/node-esm/chunk-D4DVCY7Y.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":28365},"dist/lib/node-esm/chunk-D4DVCY7Y.mjs":{"imports":[{"path":"node:util","kind":"import-statement","external":true},{"path":"node:util","kind":"import-statement","external":true},{"path":"streamx","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"lodash.defaultsdeep","kind":"import-statement","external":true},{"path":"@dxos/crypto","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/hypercore","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/debug","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"exports":["FeedFactory","FeedStore","FeedWrapper"],"inputs":{"src/feed-wrapper.ts":{"bytesInOutput":9436},"src/feed-factory.ts":{"bytesInOutput":2403},"src/feed-store.ts":{"bytesInOutput":3498}},"bytes":15598}}}