@dxos/echo-pipeline 0.6.7 → 0.6.8-main.3be982f

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 (70) hide show
  1. package/dist/lib/browser/chunk-NE5LORNQ.mjs +2028 -0
  2. package/dist/lib/browser/chunk-NE5LORNQ.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-Q4B5JN6L.mjs +2150 -0
  4. package/dist/lib/browser/chunk-Q4B5JN6L.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-XPCF2V5U.mjs +31 -0
  6. package/dist/lib/browser/chunk-XPCF2V5U.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +16 -16
  8. package/dist/lib/browser/light.mjs +32 -0
  9. package/dist/lib/browser/light.mjs.map +7 -0
  10. package/dist/lib/browser/meta.json +1 -1
  11. package/dist/lib/browser/testing/index.mjs +3 -7
  12. package/dist/lib/browser/testing/index.mjs.map +3 -3
  13. package/dist/lib/node/chunk-5KNTTBQK.cjs +2146 -0
  14. package/dist/lib/node/chunk-5KNTTBQK.cjs.map +7 -0
  15. package/dist/lib/node/chunk-DZVH7HDD.cjs +43 -0
  16. package/dist/lib/node/chunk-DZVH7HDD.cjs.map +7 -0
  17. package/dist/lib/node/chunk-IHR4UMVA.cjs +2043 -0
  18. package/dist/lib/node/chunk-IHR4UMVA.cjs.map +7 -0
  19. package/dist/lib/node/index.cjs +35 -37
  20. package/dist/lib/node/index.cjs.map +2 -2
  21. package/dist/lib/node/light.cjs +52 -0
  22. package/dist/lib/node/light.cjs.map +7 -0
  23. package/dist/lib/node/meta.json +1 -1
  24. package/dist/lib/node/testing/index.cjs +12 -15
  25. package/dist/lib/node/testing/index.cjs.map +3 -3
  26. package/dist/types/src/automerge/automerge-host.d.ts.map +1 -1
  27. package/dist/types/src/automerge/network-protocol.d.ts.map +1 -1
  28. package/dist/types/src/common/codec.d.ts +0 -1
  29. package/dist/types/src/common/codec.d.ts.map +1 -1
  30. package/dist/types/src/common/feeds.d.ts.map +1 -1
  31. package/dist/types/src/common/index.d.ts +1 -0
  32. package/dist/types/src/common/index.d.ts.map +1 -1
  33. package/dist/types/src/common/space-id.d.ts +7 -0
  34. package/dist/types/src/common/space-id.d.ts.map +1 -0
  35. package/dist/types/src/db-host/index.d.ts +0 -2
  36. package/dist/types/src/db-host/index.d.ts.map +1 -1
  37. package/dist/types/src/light.d.ts +4 -0
  38. package/dist/types/src/light.d.ts.map +1 -0
  39. package/dist/types/src/pipeline/message-selector.d.ts.map +1 -1
  40. package/dist/types/src/space/space-manager.d.ts +1 -7
  41. package/dist/types/src/space/space-manager.d.ts.map +1 -1
  42. package/dist/types/src/space/space-protocol.d.ts +0 -1
  43. package/dist/types/src/space/space-protocol.d.ts.map +1 -1
  44. package/dist/types/src/space/space.d.ts +1 -10
  45. package/dist/types/src/space/space.d.ts.map +1 -1
  46. package/dist/types/src/testing/test-agent-builder.d.ts +0 -3
  47. package/dist/types/src/testing/test-agent-builder.d.ts.map +1 -1
  48. package/package.json +43 -33
  49. package/src/automerge/echo-network-adapter.ts +1 -1
  50. package/src/automerge/mesh-echo-replicator.ts +1 -1
  51. package/src/common/index.ts +1 -0
  52. package/src/common/space-id.ts +27 -0
  53. package/src/db-host/index.ts +0 -2
  54. package/src/light.ts +7 -0
  55. package/src/space/space-manager.ts +3 -19
  56. package/src/space/space.ts +2 -32
  57. package/src/testing/test-agent-builder.ts +0 -7
  58. package/dist/lib/browser/chunk-P6XSIJKM.mjs +0 -4281
  59. package/dist/lib/browser/chunk-P6XSIJKM.mjs.map +0 -7
  60. package/dist/lib/node/chunk-IYTGTZ7D.cjs +0 -4255
  61. package/dist/lib/node/chunk-IYTGTZ7D.cjs.map +0 -7
  62. package/dist/types/src/db-host/snapshot-manager.d.ts +0 -19
  63. package/dist/types/src/db-host/snapshot-manager.d.ts.map +0 -1
  64. package/dist/types/src/db-host/snapshot-store.d.ts +0 -16
  65. package/dist/types/src/db-host/snapshot-store.d.ts.map +0 -1
  66. package/dist/types/src/db-host/snapshot-store.test.d.ts +0 -2
  67. package/dist/types/src/db-host/snapshot-store.test.d.ts.map +0 -1
  68. package/src/db-host/snapshot-manager.ts +0 -54
  69. package/src/db-host/snapshot-store.test.ts +0 -31
  70. package/src/db-host/snapshot-store.ts +0 -61
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/common/codec.ts", "../../../src/common/feeds.ts", "../../../src/db-host/snapshot-manager.ts", "../../../src/db-host/snapshot-store.ts", "../../../src/db-host/documents-synchronizer.ts", "../../../src/automerge/collection-synchronizer.ts", "../../../src/space/auth.ts", "../../../src/pipeline/timeframe-clock.ts", "../../../src/pipeline/pipeline.ts", "../../../src/pipeline/message-selector.ts", "../../../src/space/space.ts", "../../../src/space/control-pipeline.ts", "../../../src/space/admission-discovery-extension.ts", "../../../src/space/space-protocol.ts", "../../../src/space/space-manager.ts", "../../../src/db-host/data-service.ts", "../../../src/automerge/automerge-host.ts", "../../../src/automerge/echo-network-adapter.ts", "../../../src/automerge/network-protocol.ts", "../../../src/automerge/heads-store.ts", "../../../src/automerge/leveldb-storage-adapter.ts", "../../../src/automerge/mesh-echo-replicator.ts", "../../../src/automerge/mesh-echo-replicator-connection.ts", "../../../src/automerge/space-collection.ts", "../../../src/automerge/echo-data-monitor.ts", "../../../src/metadata/metadata-store.ts"],
4
- "sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport { type Codec } from '@dxos/codec-protobuf';\nimport { createCodecEncoding } from '@dxos/hypercore';\nimport { schema } from '@dxos/protocols';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\n\n/**\n * Codec for feed messages.\n */\nexport const codec: Codec<FeedMessage> = schema.getCodecForType('dxos.echo.feed.FeedMessage');\n\n/**\n * Value encoding used by feed store.\n */\nexport const valueEncoding = createCodecEncoding(codec);\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { type FeedWriter } from '@dxos/feed-store';\nimport { invariant } from '@dxos/invariant';\nimport { type MaybePromise } from '@dxos/util';\n\n/**\n * Maps the written arguments onto a different message type.\n */\nexport const createMappedFeedWriter = <Source extends {}, Target extends {}>(\n mapper: (arg: Source) => MaybePromise<Target>,\n writer: FeedWriter<Target>,\n): FeedWriter<Source> => {\n invariant(mapper);\n invariant(writer);\n\n return {\n write: async (data: Source, options) => await writer.write(await mapper(data), options),\n };\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Context, cancelWithContext } from '@dxos/context';\nimport { PublicKey } from '@dxos/keys';\nimport { schema } from '@dxos/protocols';\nimport { BlobMeta } from '@dxos/protocols/proto/dxos/echo/blob';\nimport { type SpaceSnapshot } from '@dxos/protocols/proto/dxos/echo/snapshot';\nimport { type BlobStore, type BlobSync } from '@dxos/teleport-extension-object-sync';\n\nimport { type SnapshotStore } from './snapshot-store';\n\nconst SpaceSnapshot = schema.getCodecForType('dxos.echo.snapshot.SpaceSnapshot');\n\n/**\n * Snapshot manager for a specific space.\n */\nexport class SnapshotManager {\n constructor(\n private readonly _snapshotStore: SnapshotStore,\n private readonly _blobStore: BlobStore,\n private readonly _blobSync: BlobSync,\n ) {}\n\n private async _getBlob(blobId: Uint8Array): Promise<SpaceSnapshot> {\n const blob = await this._blobStore.get(blobId);\n return SpaceSnapshot.decode(blob);\n }\n\n async load(ctx: Context, id: string): Promise<SpaceSnapshot> {\n const blobId = PublicKey.fromHex(id).asUint8Array();\n const blobMeta = await this._blobStore.getMeta(blobId);\n if (blobMeta && blobMeta.state === BlobMeta.State.FULLY_PRESENT) {\n return this._getBlob(blobId);\n }\n\n // TODO(dmaretskyi): Remove once we fully migrate to blob store.\n const fallbackStore = await cancelWithContext(ctx, this._snapshotStore.loadSnapshot(id));\n if (fallbackStore) {\n return fallbackStore;\n }\n\n await this._blobSync.download(ctx, blobId);\n\n return this._getBlob(blobId);\n }\n\n async store(snapshot: SpaceSnapshot): Promise<string> {\n const { id } = await this._blobStore.set(SpaceSnapshot.encode(snapshot));\n await this._blobSync.notifyBlobAdded(id);\n return PublicKey.from(id).toHex();\n }\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { subtleCrypto } from '@dxos/crypto';\nimport { schema } from '@dxos/protocols';\nimport { type StoredSnapshotInfo } from '@dxos/protocols/proto/dxos/devtools/host';\nimport { type SpaceSnapshot } from '@dxos/protocols/proto/dxos/echo/snapshot';\nimport { type Directory } from '@dxos/random-access-storage';\n\nconst SpaceSnapshot = schema.getCodecForType('dxos.echo.snapshot.SpaceSnapshot');\n/**\n * @deprecated\n */\nexport class SnapshotStore {\n constructor(private readonly _directory: Directory) {}\n\n async saveSnapshot(snapshot: SpaceSnapshot): Promise<string> {\n const encoded = SpaceSnapshot.encode(snapshot);\n const key = await subtleCrypto.digest('SHA-256', encoded);\n const keyString = Buffer.from(key).toString('hex');\n\n const file = await this._directory.getOrCreateFile(keyString);\n try {\n await file.write(0, Buffer.from(encoded));\n } finally {\n await file.close();\n }\n\n return keyString;\n }\n\n async loadSnapshot(key: string): Promise<SpaceSnapshot | undefined> {\n const file = await this._directory.getOrCreateFile(key);\n try {\n const { size } = await file.stat();\n if (size === 0) {\n return undefined;\n }\n\n const buffer = await file.read(0, size);\n return SpaceSnapshot.decode(buffer);\n } finally {\n await file.close();\n }\n }\n\n async listSnapshots(): Promise<StoredSnapshotInfo[]> {\n const entries = await this._directory.list();\n\n return await Promise.all(\n entries.map(async (key) => {\n const { size } = await this._directory.getOrCreateFile(key).stat();\n return {\n key,\n size,\n };\n }),\n );\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { UpdateScheduler } from '@dxos/async';\nimport { next as A, type Heads } from '@dxos/automerge/automerge';\nimport { type Repo, type DocHandle, type DocumentId } from '@dxos/automerge/automerge-repo';\nimport { Resource } from '@dxos/context';\nimport { type SpaceDoc } from '@dxos/echo-protocol';\nimport { invariant } from '@dxos/invariant';\nimport { log } from '@dxos/log';\nimport { type BatchedDocumentUpdates, type DocumentUpdate } from '@dxos/protocols/proto/dxos/echo/service';\n\nconst MAX_UPDATE_FREQ = 10; // [updates/sec]\n\nexport type DocumentsSynchronizerParams = {\n repo: Repo;\n sendUpdates: (updates: BatchedDocumentUpdates) => void;\n};\n\ninterface DocSyncState {\n handle: DocHandle<SpaceDoc>;\n lastSentHead?: Heads;\n clearSubscriptions?: () => void;\n}\n\n/**\n * Manages a connection and replication between worker's Automerge Repo and the client's Repo.\n */\nexport class DocumentsSynchronizer extends Resource {\n private readonly _syncStates = new Map<DocumentId, DocSyncState>();\n /**\n * Documents that have pending updates.\n * Used to batch updates.\n */\n private readonly _pendingUpdates = new Set<DocumentId>();\n\n /**\n * Job that schedules if there are pending updates.\n */\n private _sendUpdatesJob?: UpdateScheduler = undefined;\n\n constructor(private readonly _params: DocumentsSynchronizerParams) {\n super();\n }\n\n addDocuments(documentIds: DocumentId[], retryCounter = 0) {\n if (retryCounter > 3) {\n log.warn('Failed to load document, retry limit reached', { documentIds });\n return;\n }\n\n for (const documentId of documentIds) {\n const doc = this._params.repo.find(documentId as DocumentId);\n doc\n .whenReady()\n .then(() => {\n this._startSync(doc);\n this._pendingUpdates.add(doc.documentId);\n this._sendUpdatesJob!.trigger();\n })\n .catch((error) => {\n log.warn('Failed to load document, wraparound', { documentId, error });\n this.addDocuments([documentId], retryCounter + 1);\n });\n }\n }\n\n removeDocuments(documentIds: DocumentId[]) {\n for (const documentId of documentIds) {\n this._syncStates.get(documentId)?.clearSubscriptions?.();\n this._syncStates.delete(documentId);\n this._pendingUpdates.delete(documentId);\n }\n }\n\n protected override async _open(): Promise<void> {\n this._sendUpdatesJob = new UpdateScheduler(this._ctx, this._checkAndSendUpdates.bind(this), {\n maxFrequency: MAX_UPDATE_FREQ,\n });\n }\n\n protected override async _close(): Promise<void> {\n await this._sendUpdatesJob!.join();\n this._syncStates.clear();\n }\n\n update(updates: DocumentUpdate[]) {\n for (const { documentId, mutation, isNew } of updates) {\n if (isNew) {\n const doc = this._params.repo.find(documentId as DocumentId);\n doc.update((doc) => A.loadIncremental(doc, mutation));\n this._startSync(doc);\n } else {\n this._writeMutation(documentId as DocumentId, mutation);\n }\n }\n }\n\n private _startSync(doc: DocHandle<SpaceDoc>) {\n if (this._syncStates.has(doc.documentId)) {\n log.info('Document already being synced', { documentId: doc.documentId });\n return;\n }\n\n const syncState: DocSyncState = { handle: doc };\n this._subscribeForChanges(syncState);\n this._syncStates.set(doc.documentId, syncState);\n }\n\n _subscribeForChanges(syncState: DocSyncState) {\n const handler = () => {\n this._pendingUpdates.add(syncState.handle.documentId);\n this._sendUpdatesJob!.trigger();\n };\n syncState.handle.on('heads-changed', handler);\n syncState.clearSubscriptions = () => syncState.handle.off('heads-changed', handler);\n }\n\n private async _checkAndSendUpdates() {\n const updates: DocumentUpdate[] = [];\n\n const docsWithPendingUpdates = Array.from(this._pendingUpdates);\n this._pendingUpdates.clear();\n\n for (const documentId of docsWithPendingUpdates) {\n const update = this._getPendingChanges(documentId);\n if (update) {\n updates.push({\n documentId,\n mutation: update,\n });\n }\n }\n\n if (updates.length > 0) {\n this._params.sendUpdates({ updates });\n }\n }\n\n private _getPendingChanges(documentId: DocumentId): Uint8Array | void {\n const syncState = this._syncStates.get(documentId);\n invariant(syncState, 'Sync state for document not found');\n const doc = syncState.handle.docSync();\n if (!doc) {\n return;\n }\n const mutation = syncState.lastSentHead ? A.saveSince(doc, syncState.lastSentHead) : A.save(doc);\n if (mutation.length === 0) {\n return;\n }\n syncState.lastSentHead = A.getHeads(doc);\n return mutation;\n }\n\n private _writeMutation(documentId: DocumentId, mutation: Uint8Array) {\n const syncState = this._syncStates.get(documentId);\n invariant(syncState, 'Sync state for document not found');\n syncState.handle.update((doc) => {\n const headsBefore = A.getHeads(doc);\n const newDoc = A.loadIncremental(doc, mutation);\n if (A.equals(headsBefore, syncState.lastSentHead)) {\n syncState.lastSentHead = A.getHeads(newDoc);\n }\n return newDoc;\n });\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { asyncReturn, Event, scheduleTask, scheduleTaskInterval } from '@dxos/async';\nimport { next as am } from '@dxos/automerge/automerge';\nimport type { DocumentId, PeerId } from '@dxos/automerge/automerge-repo';\nimport { Resource, type Context } from '@dxos/context';\nimport { defaultMap } from '@dxos/util';\n\nconst MIN_QUERY_INTERVAL = 5_000;\n\nconst POLL_INTERVAL = 30_000;\n\nexport type CollectionSynchronizerParams = {\n sendCollectionState: (collectionId: string, peerId: PeerId, state: CollectionState) => void;\n queryCollectionState: (collectionId: string, peerId: PeerId) => void;\n shouldSyncCollection: (collectionId: string, peerId: PeerId) => boolean;\n};\n\n/**\n * Implements collection sync protocol.\n */\nexport class CollectionSynchronizer extends Resource {\n private readonly _sendCollectionState: CollectionSynchronizerParams['sendCollectionState'];\n private readonly _queryCollectionState: CollectionSynchronizerParams['queryCollectionState'];\n private readonly _shouldSyncCollection: CollectionSynchronizerParams['shouldSyncCollection'];\n\n /**\n * CollectionId -> State.\n */\n private readonly _perCollectionStates = new Map<string, PerCollectionState>();\n\n private readonly _connectedPeers = new Set<PeerId>();\n\n public readonly remoteStateUpdated = new Event<{ collectionId: string; peerId: PeerId }>();\n\n constructor(params: CollectionSynchronizerParams) {\n super();\n this._sendCollectionState = params.sendCollectionState;\n this._queryCollectionState = params.queryCollectionState;\n this._shouldSyncCollection = params.shouldSyncCollection;\n }\n\n protected override async _open(ctx: Context): Promise<void> {\n scheduleTaskInterval(\n this._ctx,\n async () => {\n for (const collectionId of this._perCollectionStates.keys()) {\n this.refreshCollection(collectionId);\n await asyncReturn();\n }\n },\n POLL_INTERVAL,\n );\n }\n\n getRegisteredCollectionIds(): string[] {\n return [...this._perCollectionStates.keys()];\n }\n\n getLocalCollectionState(collectionId: string): CollectionState | undefined {\n return this._getPerCollectionState(collectionId).localState;\n }\n\n setLocalCollectionState(collectionId: string, state: CollectionState) {\n this._getPerCollectionState(collectionId).localState = state;\n\n queueMicrotask(async () => {\n if (!this._ctx.disposed) {\n this._refreshInterestedPeers(collectionId);\n this.refreshCollection(collectionId);\n }\n });\n }\n\n getRemoteCollectionStates(collectionId: string): ReadonlyMap<PeerId, CollectionState> {\n return this._getPerCollectionState(collectionId).remoteStates;\n }\n\n refreshCollection(collectionId: string) {\n let scheduleAnotherRefresh = false;\n const state = this._getPerCollectionState(collectionId);\n for (const peerId of this._connectedPeers) {\n if (state.interestedPeers.has(peerId)) {\n const lastQueried = state.lastQueried.get(peerId) ?? 0;\n if (Date.now() - lastQueried > MIN_QUERY_INTERVAL) {\n state.lastQueried.set(peerId, Date.now());\n this._queryCollectionState(collectionId, peerId);\n } else {\n scheduleAnotherRefresh = true;\n }\n }\n }\n if (scheduleAnotherRefresh) {\n scheduleTask(this._ctx, () => this.refreshCollection(collectionId), MIN_QUERY_INTERVAL);\n }\n }\n\n /**\n * Callback when a connection to a peer is established.\n */\n onConnectionOpen(peerId: PeerId) {\n this._connectedPeers.add(peerId);\n\n queueMicrotask(async () => {\n if (this._ctx.disposed) {\n return;\n }\n for (const [collectionId, state] of this._perCollectionStates.entries()) {\n if (this._shouldSyncCollection(collectionId, peerId)) {\n state.interestedPeers.add(peerId);\n state.lastQueried.set(peerId, Date.now());\n this._queryCollectionState(collectionId, peerId);\n }\n }\n });\n }\n\n /**\n * Callback when a connection to a peer is closed.\n */\n onConnectionClosed(peerId: PeerId) {\n this._connectedPeers.delete(peerId);\n\n for (const perCollectionState of this._perCollectionStates.values()) {\n perCollectionState.remoteStates.delete(peerId);\n }\n }\n\n /**\n * Callback when a peer queries the state of a collection.\n */\n onCollectionStateQueried(collectionId: string, peerId: PeerId) {\n const perCollectionState = this._getPerCollectionState(collectionId);\n\n if (perCollectionState.localState) {\n this._sendCollectionState(collectionId, peerId, perCollectionState.localState);\n }\n }\n\n /**\n * Callback when a peer sends the state of a collection.\n */\n onRemoteStateReceived(collectionId: string, peerId: PeerId, state: CollectionState) {\n const perCollectionState = this._getPerCollectionState(collectionId);\n perCollectionState.remoteStates.set(peerId, state);\n this.remoteStateUpdated.emit({ peerId, collectionId });\n }\n\n private _getPerCollectionState(collectionId: string): PerCollectionState {\n return defaultMap(this._perCollectionStates, collectionId, () => ({\n localState: undefined,\n remoteStates: new Map(),\n interestedPeers: new Set(),\n lastQueried: new Map(),\n }));\n }\n\n private _refreshInterestedPeers(collectionId: string) {\n for (const peerId of this._connectedPeers) {\n if (this._shouldSyncCollection(collectionId, peerId)) {\n this._getPerCollectionState(collectionId).interestedPeers.add(peerId);\n } else {\n this._getPerCollectionState(collectionId).interestedPeers.delete(peerId);\n }\n }\n }\n}\n\ntype PerCollectionState = {\n localState?: CollectionState;\n remoteStates: Map<PeerId, CollectionState>;\n interestedPeers: Set<PeerId>;\n lastQueried: Map<PeerId, number>;\n};\n\nexport type CollectionState = {\n /**\n * DocumentId -> Heads.\n */\n documents: Record<string, string[]>;\n};\n\nexport type CollectionStateDiff = {\n different: DocumentId[];\n};\n\nexport const diffCollectionState = (local: CollectionState, remote: CollectionState): CollectionStateDiff => {\n const allDocuments = new Set<DocumentId>([...Object.keys(local.documents), ...Object.keys(remote.documents)] as any);\n\n const different: DocumentId[] = [];\n for (const documentId of allDocuments) {\n if (\n !local.documents[documentId] ||\n !remote.documents[documentId] ||\n !am.equals(local.documents[documentId], remote.documents[documentId])\n ) {\n different.push(documentId as DocumentId);\n }\n }\n\n return { different };\n};\n", "//\n// Copyright 2019 DXOS.org\n//\n\nimport { runInContext, scheduleTask } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { randomBytes } from '@dxos/crypto';\nimport { invariant } from '@dxos/invariant';\nimport { log } from '@dxos/log';\nimport { schema } from '@dxos/protocols';\nimport { type AuthService } from '@dxos/protocols/proto/dxos/mesh/teleport/auth';\nimport { type ExtensionContext, RpcExtension } from '@dxos/teleport';\n\nexport type AuthProvider = (nonce: Uint8Array) => Promise<Uint8Array | undefined>;\n\nexport type AuthVerifier = (nonce: Uint8Array, credential: Uint8Array) => Promise<boolean>;\n\nexport type AuthExtensionParams = {\n provider: AuthProvider;\n verifier: AuthVerifier;\n onAuthSuccess: () => void;\n onAuthFailure: () => void;\n};\n\nexport class AuthExtension extends RpcExtension<Services, Services> {\n private readonly _ctx = new Context({\n onError: (err) => {\n log.catch(err);\n },\n });\n\n constructor(private readonly _authParams: AuthExtensionParams) {\n super({\n requested: {\n AuthService: schema.getService('dxos.mesh.teleport.auth.AuthService'),\n },\n exposed: {\n AuthService: schema.getService('dxos.mesh.teleport.auth.AuthService'),\n },\n timeout: 60 * 1000, // Long timeout because auth can wait for sync in certain cases.\n });\n }\n\n protected async getHandlers(): Promise<Services> {\n return {\n AuthService: {\n authenticate: async ({ challenge }) => {\n try {\n const credential = await this._authParams.provider(challenge);\n if (!credential) {\n throw new Error('auth rejected');\n }\n return { credential };\n } catch (err) {\n log.error('failed to generate auth credentials', err);\n throw new Error('auth rejected');\n }\n },\n },\n };\n }\n\n override async onOpen(context: ExtensionContext): Promise<void> {\n await super.onOpen(context);\n scheduleTask(this._ctx, async () => {\n try {\n const challenge = randomBytes(32);\n const { credential } = await this.rpc.AuthService.authenticate({ challenge });\n invariant(credential?.length > 0, 'invalid credential');\n const success = await this._authParams.verifier(challenge, credential);\n invariant(success, 'credential not verified');\n runInContext(this._ctx, () => this._authParams.onAuthSuccess());\n } catch (err) {\n log('auth failed', err);\n this.close();\n this._authParams.onAuthFailure();\n }\n });\n }\n\n override async onClose(): Promise<void> {\n await this._ctx.dispose();\n await super.onClose();\n }\n\n override async onAbort(): Promise<void> {\n await this._ctx.dispose();\n await super.onAbort();\n }\n}\n\ntype Services = { AuthService: AuthService };\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { Event } from '@dxos/async';\nimport { timed } from '@dxos/debug';\nimport { type FeedIndex } from '@dxos/feed-store';\nimport { type PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { Timeframe } from '@dxos/timeframe';\n\nexport const mapTimeframeToFeedIndexes = (timeframe: Timeframe): FeedIndex[] =>\n timeframe.frames().map(([feedKey, index]) => ({ feedKey, index }));\n\nexport const mapFeedIndexesToTimeframe = (indexes: FeedIndex[]): Timeframe =>\n new Timeframe(indexes.map(({ feedKey, index }) => [feedKey, index]));\n\nexport const startAfter = (timeframe: Timeframe): FeedIndex[] =>\n timeframe.frames().map(([feedKey, index]) => ({ feedKey, index: index + 1 }));\n\n/**\n * Keeps state of the last timeframe that was processed by ECHO.\n */\nexport class TimeframeClock {\n readonly update = new Event<Timeframe>();\n\n private _pendingTimeframe: Timeframe;\n\n constructor(private _timeframe = new Timeframe()) {\n this._pendingTimeframe = _timeframe;\n }\n\n /**\n * Timeframe that was processed by ECHO.\n */\n get timeframe() {\n return this._timeframe;\n }\n\n /**\n * Timeframe that is currently being processed by ECHO.\n * Will be equal to `timeframe` after the processing is complete.\n */\n get pendingTimeframe() {\n return this._pendingTimeframe;\n }\n\n setTimeframe(timeframe: Timeframe) {\n this._timeframe = timeframe;\n this._pendingTimeframe = timeframe;\n this.update.emit(this._timeframe);\n }\n\n updatePendingTimeframe(key: PublicKey, seq: number) {\n this._pendingTimeframe = Timeframe.merge(this._pendingTimeframe, new Timeframe([[key, seq]]));\n }\n\n updateTimeframe() {\n this._timeframe = this._pendingTimeframe;\n this.update.emit(this._timeframe);\n }\n\n hasGaps(timeframe: Timeframe) {\n const gaps = Timeframe.dependencies(timeframe, this._timeframe);\n return !gaps.isEmpty();\n }\n\n @timed(5_000)\n async waitUntilReached(target: Timeframe) {\n log('waitUntilReached', { target, current: this._timeframe });\n await this.update.waitForCondition(() => {\n log('check if reached', {\n target,\n current: this._timeframe,\n deps: Timeframe.dependencies(target, this._timeframe),\n });\n\n return Timeframe.dependencies(target, this._timeframe).isEmpty();\n });\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Event, sleepWithContext, synchronized, Trigger } from '@dxos/async';\nimport { Context, rejectOnDispose } from '@dxos/context';\nimport { failUndefined } from '@dxos/debug';\nimport { FeedSetIterator, type FeedWrapper, type FeedWriter } from '@dxos/feed-store';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type FeedMessageBlock } from '@dxos/protocols';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { Timeframe } from '@dxos/timeframe';\nimport { ComplexMap } from '@dxos/util';\n\nimport { createMessageSelector } from './message-selector';\nimport { mapFeedIndexesToTimeframe, startAfter, TimeframeClock } from './timeframe-clock';\nimport { createMappedFeedWriter } from '../common';\n\nexport type WaitUntilReachedTargetParams = {\n /**\n * For cancellation.\n */\n ctx?: Context;\n timeout?: number;\n\n /**\n * @default true\n */\n breakOnStall?: boolean;\n};\n\n/**\n * External state accessor.\n */\nexport class PipelineState {\n /**\n * @internal\n */\n _ctx = new Context();\n\n // TODO(dmaretskyi): Remove?.\n public readonly timeframeUpdate = this._timeframeClock.update;\n\n public readonly stalled = new Event();\n\n /**\n * @internal\n */\n _startTimeframe: Timeframe = new Timeframe();\n\n /**\n * Target timeframe we are waiting to reach.\n */\n private _targetTimeframe: Timeframe | undefined;\n\n /**\n * @internal\n */\n _reachedTargetPromise: Promise<void> | undefined;\n\n /**\n * @internal\n */\n _reachedTarget: boolean = false;\n\n constructor(\n private _feeds: ComplexMap<PublicKey, FeedWrapper<FeedMessage>>,\n private _timeframeClock: TimeframeClock,\n ) {}\n\n /**\n * Latest theoretical timeframe based on the last mutation in each feed.\n * NOTE: This might never be reached if the mutation dependencies\n */\n // TODO(dmaretskyi): Rename `totalTimeframe`? or `lastTimeframe`.\n get endTimeframe() {\n return mapFeedIndexesToTimeframe(\n Array.from(this._feeds.values())\n .filter((feed) => feed.length > 0)\n .map((feed) => ({\n feedKey: feed.key,\n index: feed.length - 1,\n })),\n );\n }\n\n get startTimeframe() {\n return this._startTimeframe;\n }\n\n get timeframe() {\n return this._timeframeClock.timeframe;\n }\n\n get pendingTimeframe() {\n return this._timeframeClock.pendingTimeframe;\n }\n\n get targetTimeframe() {\n return this._targetTimeframe ? this._targetTimeframe : new Timeframe();\n }\n\n get reachedTarget() {\n return this._reachedTarget;\n }\n\n get feeds() {\n return Array.from(this._feeds.values());\n }\n\n async waitUntilTimeframe(target: Timeframe) {\n await this._timeframeClock.waitUntilReached(target);\n }\n\n setTargetTimeframe(target: Timeframe) {\n this._targetTimeframe = target;\n }\n\n /**\n * Wait until the pipeline processes all messages in the feed and reaches the target timeframe if that is set.\n *\n * This function will resolve immediately if the pipeline is stalled.\n *\n * @param timeout Timeout in milliseconds to specify the maximum wait time.\n */\n async waitUntilReachedTargetTimeframe({\n ctx = new Context(),\n timeout,\n breakOnStall = true,\n }: WaitUntilReachedTargetParams = {}) {\n log('waitUntilReachedTargetTimeframe', {\n timeout,\n current: this.timeframe,\n target: this.targetTimeframe,\n });\n\n this._reachedTargetPromise ??= Promise.race([\n this._timeframeClock.update.waitForCondition(() => {\n return Timeframe.dependencies(this.targetTimeframe, this.timeframe).isEmpty();\n }),\n ...(breakOnStall ? [this.stalled.discardParameter().waitForCount(1)] : []),\n ]);\n\n let done = false;\n\n if (timeout) {\n return Promise.race([\n rejectOnDispose(ctx),\n rejectOnDispose(this._ctx),\n this._reachedTargetPromise.then(() => {\n done = true;\n this._reachedTarget = true;\n }),\n sleepWithContext(this._ctx, timeout).then(() => {\n if (done) {\n return;\n }\n\n log.warn('waitUntilReachedTargetTimeframe timed out', {\n timeout,\n current: this.timeframe,\n target: this.targetTimeframe,\n dependencies: Timeframe.dependencies(this.targetTimeframe, this.timeframe),\n });\n }),\n ]);\n } else {\n return this._reachedTargetPromise;\n }\n }\n}\n\n// TODO(mykola): Extract to `@dxos/echo-protocol`\nexport interface PipelineAccessor {\n state: PipelineState;\n writer: FeedWriter<FeedMessage.Payload>;\n}\n\n/**\n * A multi-reader pipeline that operates on feeds.\n * Might have a single writable feed.\n * Has a timeframe clock to handle message ordering.\n *\n * NOTE:\n * - Feeds passed in must have value encoding consistent with the type expected by the iterator/writer.\n *\n * # Usage examples\n *\n * ## Create a new space.\n *\n * 1. Generate space key, genesis feed key.\n * 2. Create and open pipeline reading from {}.\n * 3. Create and add the writable genesis feed.\n * 4. Write the initial sequence of control and credential messages.\n *\n * ## Load an existing space from storage\n *\n * 1. Load space key, genesis feed key, get starting timeframe from saved snapshot.\n * 2. Create and open pipeline reading from the initial timeframe.\n * 3. Open and add the genesis feed.\n * 4. Once the writable feed is added, the pipeline becomes writable.\n *\n * ## Join an existing space created by another agent/device.\n *\n * 1. Get the space key, genesis feed key from another agent.\n * 2. (optionally) Download the snapshot from another agent.\n * 3. Create and open pipeline.\n * 4. Generate the writable feed key.\n * 5. Wait for the writable feed to be added.\n */\nexport class Pipeline implements PipelineAccessor {\n private readonly _timeframeClock = new TimeframeClock(new Timeframe());\n private readonly _feeds = new ComplexMap<PublicKey, FeedWrapper<FeedMessage>>(PublicKey.hash);\n\n // External state accessor.\n private readonly _state: PipelineState = new PipelineState(this._feeds, this._timeframeClock);\n\n // Waits for the message consumer to process the message and yield control back to the pipeline.\n private readonly _processingTrigger = new Trigger().wake();\n private readonly _pauseTrigger = new Trigger().wake();\n\n // Pending downloads.\n private readonly _downloads = new ComplexMap<FeedWrapper<FeedMessage>, any>((value) => PublicKey.hash(value.key));\n\n // Inbound feed stream.\n private _feedSetIterator?: FeedSetIterator<FeedMessage>;\n\n // Outbound feed writer.\n private _writer: FeedWriter<FeedMessage.Payload> | undefined;\n\n private _isStopping = false;\n private _isStarted = false;\n private _isBeingConsumed = false;\n private _isPaused = false;\n\n get state() {\n return this._state;\n }\n\n get writer(): FeedWriter<FeedMessage.Payload> {\n invariant(this._writer, 'Writer not set.');\n return this._writer;\n }\n\n hasFeed(feedKey: PublicKey) {\n return this._feeds.has(feedKey);\n }\n\n getFeeds(): FeedWrapper<FeedMessage>[] {\n return this._feedSetIterator!.feeds;\n }\n\n // NOTE: This cannot be synchronized with `stop` because stop waits for the mutation processing to complete,\n // which might be opening feeds during the mutation processing, which w\n async addFeed(feed: FeedWrapper<FeedMessage>) {\n this._feeds.set(feed.key, feed);\n\n if (this._feedSetIterator) {\n await this._feedSetIterator.addFeed(feed);\n }\n\n if (this._isStarted && !this._isPaused) {\n this._setFeedDownloadState(feed);\n }\n }\n\n setWriteFeed(feed: FeedWrapper<FeedMessage>) {\n invariant(!this._writer, 'Writer already set.');\n invariant(feed.properties.writable, 'Feed must be writable.');\n\n this._writer = createMappedFeedWriter<FeedMessage.Payload, FeedMessage>(\n (payload: FeedMessage.Payload) => ({\n timeframe: this._timeframeClock.timeframe,\n payload,\n }),\n feed.createFeedWriter(),\n );\n }\n\n @synchronized\n async start() {\n invariant(!this._isStarted, 'Pipeline is already started.');\n log('starting...');\n await this._initIterator();\n await this._feedSetIterator!.open();\n this._isStarted = true;\n log('started');\n\n if (!this._isPaused) {\n for (const feed of this._feeds.values()) {\n this._setFeedDownloadState(feed);\n }\n }\n }\n\n @synchronized\n async stop() {\n log('stopping...');\n this._isStopping = true;\n for (const [feed, handle] of this._downloads.entries()) {\n feed.undownload(handle);\n }\n this._downloads.clear();\n await this._feedSetIterator?.close();\n await this._processingTrigger.wait(); // Wait for the in-flight message to be processed.\n await this._state._ctx.dispose();\n this._state._ctx = new Context();\n this._state._reachedTargetPromise = undefined;\n this._state._reachedTarget = false;\n this._isStarted = false;\n log('stopped');\n }\n\n /**\n * @param timeframe Timeframe of already processed messages.\n * The pipeline will start processing messages AFTER this timeframe.\n */\n @synchronized\n async setCursor(timeframe: Timeframe) {\n invariant(!this._isStarted || this._isPaused, 'Invalid state.');\n\n this._state._startTimeframe = timeframe;\n this._timeframeClock.setTimeframe(timeframe);\n\n // Cancel downloads of mutations before the cursor.\n if (this._feedSetIterator) {\n await this._feedSetIterator.close();\n await this._initIterator();\n await this._feedSetIterator.open();\n }\n }\n\n /**\n * Calling pause while processing will cause a deadlock.\n */\n @synchronized\n async pause() {\n if (this._isPaused) {\n return;\n }\n\n this._pauseTrigger.reset();\n await this._processingTrigger.wait();\n this._isPaused = true;\n }\n\n @synchronized\n async unpause() {\n invariant(this._isPaused, 'Pipeline is not paused.');\n\n this._pauseTrigger.wake();\n this._isPaused = false;\n\n for (const feed of this._feeds.values()) {\n this._setFeedDownloadState(feed);\n }\n }\n\n /**\n * Starts to iterate over the ordered messages from the added feeds.\n * Updates the timeframe clock after the message has bee processed.\n */\n async *consume(): AsyncIterable<FeedMessageBlock> {\n invariant(!this._isBeingConsumed, 'Pipeline is already being consumed.');\n this._isBeingConsumed = true;\n\n invariant(this._feedSetIterator, 'Iterator not initialized.');\n let lastFeedSetIterator = this._feedSetIterator;\n let iterable = lastFeedSetIterator[Symbol.asyncIterator]();\n\n while (!this._isStopping) {\n await this._pauseTrigger.wait();\n\n // Iterator might have been changed while we were waiting for the processing to complete.\n if (lastFeedSetIterator !== this._feedSetIterator) {\n invariant(this._feedSetIterator, 'Iterator not initialized.');\n lastFeedSetIterator = this._feedSetIterator;\n iterable = lastFeedSetIterator[Symbol.asyncIterator]();\n }\n\n // Will be canceled when the iterator gets closed.\n const { done, value } = await iterable.next();\n if (!done) {\n const block = value ?? failUndefined();\n this._processingTrigger.reset();\n this._timeframeClock.updatePendingTimeframe(PublicKey.from(block.feedKey), block.seq);\n yield block;\n this._processingTrigger.wake();\n this._timeframeClock.updateTimeframe();\n }\n }\n\n // TODO(burdon): Test re-entrant?\n this._isBeingConsumed = false;\n }\n\n private _setFeedDownloadState(feed: FeedWrapper<FeedMessage>) {\n let handle = this._downloads.get(feed); // TODO(burdon): Always undefined?\n if (handle) {\n feed.undownload(handle);\n }\n\n const timeframe = this._state._startTimeframe;\n const seq = timeframe.get(feed.key) ?? -1;\n log('download', { feed: feed.key.truncate(), seq, length: feed.length });\n handle = feed.download({ start: seq + 1, linear: true }, (err: any, data: any) => {\n if (err) {\n // log.warn(err); // TODO(burdon): Feed is closed/Download was cancelled.\n } else {\n log.info('downloaded', { data }); // TODO(burdon): Never called.\n }\n });\n\n this._downloads.set(feed, handle);\n }\n\n private async _initIterator() {\n this._feedSetIterator = new FeedSetIterator<FeedMessage>(createMessageSelector(this._timeframeClock), {\n start: startAfter(this._timeframeClock.timeframe),\n stallTimeout: 1000,\n });\n\n this._feedSetIterator.stalled.on((iterator) => {\n log.warn(`Stalled after ${iterator.options.stallTimeout}ms with ${iterator.size} feeds.`);\n this._state.stalled.emit();\n });\n\n for (const feed of this._feeds.values()) {\n await this._feedSetIterator.addFeed(feed);\n }\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { type FeedBlock, type FeedBlockSelector } from '@dxos/feed-store';\nimport { invariant } from '@dxos/invariant';\nimport { log } from '@dxos/log';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\n\nimport { type TimeframeClock } from './timeframe-clock';\n\n/**\n * The MessageSelector makes sure that we read in a trusted order.\n * The first message we wish to process is the SpaceGenesis, which will admit a Feed.\n * As we encounter and process FeedAdmit messages those are added to the Space's trust,\n * and we begin processing messages from them as well.\n */\nexport const createMessageSelector = (timeframeClock: TimeframeClock): FeedBlockSelector<FeedMessage> => {\n return (messages: FeedBlock<FeedMessage>[]) => {\n // Pick the first candidate with a valid timeframe that has no gaps.\n for (let i = 0; i < messages.length; i++) {\n const {\n data: { timeframe },\n } = messages[i];\n invariant(timeframe);\n\n if (!timeframeClock.hasGaps(timeframe)) {\n return i;\n }\n }\n\n // Not ready for this message yet.\n log('Skipping...');\n };\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Event, scheduleMicroTask, synchronized, trackLeaks } from '@dxos/async';\nimport { type Context, LifecycleState, Resource } from '@dxos/context';\nimport { type DelegateInvitationCredential, type FeedInfo, type MemberInfo } from '@dxos/credentials';\nimport { subtleCrypto } from '@dxos/crypto';\nimport { type FeedOptions, type FeedWrapper } from '@dxos/feed-store';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey, SpaceId } from '@dxos/keys';\nimport { log, logInfo } from '@dxos/log';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { AdmittedFeed, type Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { type Timeframe } from '@dxos/timeframe';\nimport { trace } from '@dxos/tracing';\nimport { type AsyncCallback, Callback, ComplexMap } from '@dxos/util';\n\nimport { ControlPipeline } from './control-pipeline';\nimport { type SpaceProtocol } from './space-protocol';\nimport { type SnapshotManager } from '../db-host';\nimport { type MetadataStore } from '../metadata';\nimport { type PipelineAccessor } from '../pipeline';\n\n// TODO(burdon): Factor out?\ntype FeedProvider = (feedKey: PublicKey, opts?: FeedOptions) => Promise<FeedWrapper<FeedMessage>>;\n\nexport type SpaceParams = {\n id: SpaceId;\n spaceKey: PublicKey;\n protocol: SpaceProtocol;\n genesisFeed: FeedWrapper<FeedMessage>;\n feedProvider: FeedProvider;\n metadataStore: MetadataStore;\n snapshotManager: SnapshotManager;\n memberKey: PublicKey;\n\n // TODO(dmaretskyi): Superseded by epochs.\n snapshotId?: string | undefined;\n\n onDelegatedInvitationStatusChange: (invitation: DelegateInvitationCredential, isActive: boolean) => Promise<void>;\n onMemberRolesChanged: (member: MemberInfo[]) => Promise<void>;\n};\n\nexport type CreatePipelineParams = {\n start: Timeframe;\n // designation: AdmittedFeed.Designation;\n};\n\n/**\n * Spaces are globally addressable databases with access control.\n */\n// TODO(dmaretskyi): Extract database stuff.\n@trackLeaks('open', 'close')\n@trace.resource()\nexport class Space extends Resource {\n public readonly onCredentialProcessed = new Callback<AsyncCallback<Credential>>();\n public readonly stateUpdate = new Event();\n @trace.info()\n public readonly protocol: SpaceProtocol;\n\n private readonly _id: SpaceId;\n private readonly _key: PublicKey;\n private readonly _genesisFeedKey: PublicKey;\n private readonly _feedProvider: FeedProvider;\n @trace.info()\n private readonly _controlPipeline: ControlPipeline;\n\n private readonly _snapshotManager: SnapshotManager;\n\n private _controlFeed?: FeedWrapper<FeedMessage>;\n private _dataFeed?: FeedWrapper<FeedMessage>;\n\n constructor(params: SpaceParams) {\n super();\n invariant(params.spaceKey && params.feedProvider);\n this._id = params.id;\n this._key = params.spaceKey;\n this._genesisFeedKey = params.genesisFeed.key;\n this._feedProvider = params.feedProvider;\n this._snapshotManager = params.snapshotManager;\n\n this._controlPipeline = new ControlPipeline({\n spaceKey: params.spaceKey,\n genesisFeed: params.genesisFeed,\n feedProvider: params.feedProvider,\n metadataStore: params.metadataStore,\n });\n\n // TODO(dmaretskyi): Feed set abstraction.\n this._controlPipeline.onFeedAdmitted.set(async (info) => {\n // Enable sparse replication to not download mutations covered by prior epochs.\n const sparse = info.assertion.designation === AdmittedFeed.Designation.DATA;\n\n if (!info.key.equals(params.genesisFeed.key)) {\n scheduleMicroTask(this._ctx, async () => {\n await this.protocol.addFeed(await params.feedProvider(info.key, { sparse }));\n });\n }\n });\n\n this._controlPipeline.onCredentialProcessed.set(async (credential) => {\n await this.onCredentialProcessed.callIfSet(credential);\n log('onCredentialProcessed', { credential });\n this.stateUpdate.emit();\n });\n this._controlPipeline.onDelegatedInvitation.set(async (invitation) => {\n log('onDelegatedInvitation', { invitation });\n await params.onDelegatedInvitationStatusChange(invitation, true);\n });\n this._controlPipeline.onDelegatedInvitationRemoved.set(async (invitation) => {\n log('onDelegatedInvitationRemoved', { invitation });\n await params.onDelegatedInvitationStatusChange(invitation, false);\n });\n this._controlPipeline.onMemberRoleChanged.set(async (changedMembers) => {\n log('onMemberRoleChanged', () => ({ changedMembers: changedMembers.map((m) => [m.key, m.role]) }));\n await params.onMemberRolesChanged(changedMembers);\n });\n\n // Start replicating the genesis feed.\n this.protocol = params.protocol;\n }\n\n @logInfo\n @trace.info()\n get id() {\n return this._id;\n }\n\n @logInfo\n @trace.info()\n get key() {\n return this._key;\n }\n\n get isOpen() {\n return this._lifecycleState === LifecycleState.OPEN;\n }\n\n get genesisFeedKey(): PublicKey {\n return this._genesisFeedKey;\n }\n\n get controlFeedKey() {\n return this._controlFeed?.key;\n }\n\n get dataFeedKey() {\n return this._dataFeed?.key;\n }\n\n get spaceState() {\n return this._controlPipeline.spaceState;\n }\n\n /**\n * @test-only\n */\n get controlPipeline(): PipelineAccessor {\n return this._controlPipeline.pipeline;\n }\n\n get snapshotManager(): SnapshotManager {\n return this._snapshotManager;\n }\n\n async setControlFeed(feed: FeedWrapper<FeedMessage>) {\n invariant(!this._controlFeed, 'Control feed already set.');\n this._controlFeed = feed;\n await this._controlPipeline.setWriteFeed(feed);\n return this;\n }\n\n async setDataFeed(feed: FeedWrapper<FeedMessage>) {\n invariant(!this._dataFeed, 'Data feed already set.');\n this._dataFeed = feed;\n return this;\n }\n\n /**\n * Use for diagnostics.\n */\n getControlFeeds(): FeedInfo[] {\n return Array.from(this._controlPipeline.spaceState.feeds.values());\n }\n\n @trace.span()\n protected override async _open(ctx: Context) {\n log('opening...');\n\n // Order is important.\n await this._controlPipeline.start();\n await this.protocol.start();\n await this.protocol.addFeed(await this._feedProvider(this._genesisFeedKey));\n\n log('opened');\n }\n\n @synchronized\n protected override async _close() {\n log('closing...', { key: this._key });\n\n // Closes in reverse order to open.\n await this.protocol.stop();\n await this._controlPipeline.stop();\n\n log('closed');\n }\n}\n\nconst SPACE_IDS_CACHE = new ComplexMap<PublicKey, SpaceId>(PublicKey.hash);\n\n/**\n * Space keys are generated by creating a keypair, and then taking the first 20 bytes of the SHA-256 hash of the public key and encoding them to multibase RFC4648 base-32 format (prefixed with B, see Multibase Table).\n * Inspired by how ethereum addresses are derived.\n */\nexport const createIdFromSpaceKey = async (spaceKey: PublicKey): Promise<SpaceId> => {\n const cachedValue = SPACE_IDS_CACHE.get(spaceKey);\n if (cachedValue !== undefined) {\n return cachedValue;\n }\n\n const digest = await subtleCrypto.digest('SHA-256', spaceKey.asUint8Array());\n\n const bytes = new Uint8Array(digest).slice(0, SpaceId.byteLength);\n const spaceId = SpaceId.encode(bytes);\n SPACE_IDS_CACHE.set(spaceKey, spaceId);\n return spaceId;\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { DeferredTask, sleepWithContext, trackLeaks } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport {\n SpaceStateMachine,\n type SpaceState,\n type MemberInfo,\n type FeedInfo,\n type DelegateInvitationCredential,\n} from '@dxos/credentials';\nimport { type FeedWrapper } from '@dxos/feed-store';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type FeedMessageBlock } from '@dxos/protocols';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type ControlPipelineSnapshot } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport { AdmittedFeed, type Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { Timeframe } from '@dxos/timeframe';\nimport { TimeSeriesCounter, TimeUsageCounter, trace } from '@dxos/tracing';\nimport { type AsyncCallback, Callback, tracer } from '@dxos/util';\n\nimport { type MetadataStore } from '../metadata';\nimport { Pipeline, type PipelineAccessor } from '../pipeline';\n\nexport type ControlPipelineParams = {\n spaceKey: PublicKey;\n genesisFeed: FeedWrapper<FeedMessage>;\n feedProvider: (feedKey: PublicKey) => Promise<FeedWrapper<FeedMessage>>;\n metadataStore: MetadataStore;\n};\n\nconst TIMEFRAME_SAVE_DEBOUNCE_INTERVAL = 500;\n\nconst CONTROL_PIPELINE_SNAPSHOT_DELAY = 10_000;\n\nconst USE_SNAPSHOTS = true;\n\n/**\n * Processes HALO credentials, which include genesis and invitations.\n */\n@trace.resource()\n@trackLeaks('start', 'stop')\nexport class ControlPipeline {\n private readonly _ctx = new Context();\n private readonly _pipeline: Pipeline;\n private readonly _spaceStateMachine: SpaceStateMachine;\n\n private readonly _spaceKey: PublicKey;\n private readonly _metadata: MetadataStore;\n private _targetTimeframe?: Timeframe;\n private _lastTimeframeSaveTime: number = Date.now();\n\n public readonly onFeedAdmitted = new Callback<AsyncCallback<FeedInfo>>();\n public readonly onMemberRoleChanged: Callback<AsyncCallback<MemberInfo[]>>;\n public readonly onCredentialProcessed: Callback<AsyncCallback<Credential>>;\n public readonly onDelegatedInvitation: Callback<AsyncCallback<DelegateInvitationCredential>>;\n public readonly onDelegatedInvitationRemoved: Callback<AsyncCallback<DelegateInvitationCredential>>;\n\n @trace.metricsCounter()\n private _usage = new TimeUsageCounter();\n\n @trace.metricsCounter()\n private _mutations = new TimeSeriesCounter();\n\n private _snapshotTask = new DeferredTask(this._ctx, async () => {\n await sleepWithContext(this._ctx, CONTROL_PIPELINE_SNAPSHOT_DELAY);\n await this._saveSnapshot();\n });\n\n constructor({ spaceKey, genesisFeed, feedProvider, metadataStore }: ControlPipelineParams) {\n this._spaceKey = spaceKey;\n this._metadata = metadataStore;\n this._pipeline = new Pipeline();\n void this._pipeline.addFeed(genesisFeed); // TODO(burdon): Require async open/close?\n\n this._spaceStateMachine = new SpaceStateMachine(spaceKey);\n this._spaceStateMachine.onFeedAdmitted.set(async (info) => {\n // log('feed admitted', { info });\n log('feed admitted', { key: info.key });\n\n // TODO(burdon): Check not stopping.\n if (info.assertion.designation === AdmittedFeed.Designation.CONTROL && !info.key.equals(genesisFeed.key)) {\n queueMicrotask(async () => {\n try {\n const feed = await feedProvider(info.key);\n if (!this._pipeline.hasFeed(feed.key)) {\n await this._pipeline.addFeed(feed);\n }\n } catch (err: any) {\n log.catch(err);\n }\n });\n }\n\n await this.onFeedAdmitted.callIfSet(info);\n });\n\n this.onMemberRoleChanged = this._spaceStateMachine.onMemberRoleChanged;\n this.onCredentialProcessed = this._spaceStateMachine.onCredentialProcessed;\n this.onDelegatedInvitation = this._spaceStateMachine.onDelegatedInvitation;\n this.onDelegatedInvitationRemoved = this._spaceStateMachine.onDelegatedInvitationRemoved;\n }\n\n get spaceState(): SpaceState {\n return this._spaceStateMachine;\n }\n\n get pipeline(): PipelineAccessor {\n return this._pipeline;\n }\n\n async setWriteFeed(feed: FeedWrapper<FeedMessage>) {\n await this._pipeline.addFeed(feed);\n this._pipeline.setWriteFeed(feed);\n }\n\n @trace.span({ showInBrowserTimeline: true })\n async start() {\n const snapshot = this._metadata.getSpaceControlPipelineSnapshot(this._spaceKey);\n log('load snapshot', { key: this._spaceKey, present: !!snapshot, tf: snapshot?.timeframe });\n if (USE_SNAPSHOTS && snapshot) {\n await this._processSnapshot(snapshot);\n }\n\n log('starting...');\n setTimeout(async () => {\n void this._consumePipeline(new Context());\n });\n\n await this._pipeline.start();\n log('started');\n }\n\n private async _processSnapshot(snapshot: ControlPipelineSnapshot) {\n await this._pipeline.setCursor(snapshot.timeframe);\n\n for (const message of snapshot.messages ?? []) {\n const result = await this._spaceStateMachine.process(message.credential, {\n sourceFeed: message.feedKey,\n skipVerification: true,\n });\n\n if (!result) {\n log.warn('credential processing failed from snapshot', { message });\n }\n }\n }\n\n private async _saveSnapshot() {\n await this._pipeline.pause();\n const snapshot: ControlPipelineSnapshot = {\n timeframe: this._pipeline.state.timeframe,\n messages: this._spaceStateMachine.credentialEntries.map((entry) => ({\n feedKey: entry.sourceFeed,\n credential: entry.credential,\n })),\n };\n await this._pipeline.unpause();\n\n log('save snapshot', { key: this._spaceKey, snapshot });\n await this._metadata.setSpaceControlPipelineSnapshot(this._spaceKey, snapshot);\n }\n\n @trace.span()\n private async _consumePipeline(ctx: Context) {\n for await (const msg of this._pipeline.consume()) {\n const span = this._usage.beginRecording();\n this._mutations.inc();\n\n try {\n await this._processMessage(ctx, msg);\n } catch (err: any) {\n log.catch(err);\n }\n\n span.end();\n }\n }\n\n @trace.span()\n private async _processMessage(ctx: Context, msg: FeedMessageBlock) {\n // log('processing', { msg });\n log('processing', { key: msg.feedKey, seq: msg.seq });\n if (msg.data.payload.credential) {\n const timer = tracer.mark('dxos.echo.pipeline.control');\n const result = await this._spaceStateMachine.process(msg.data.payload.credential.credential, {\n sourceFeed: PublicKey.from(msg.feedKey),\n });\n\n timer.end();\n if (!result) {\n log.warn('processing failed', { msg });\n } else {\n await this._noteTargetStateIfNeeded(this._pipeline.state.pendingTimeframe);\n }\n\n this._snapshotTask.schedule();\n }\n }\n\n private async _noteTargetStateIfNeeded(timeframe: Timeframe) {\n // TODO(dmaretskyi): Replace this with a proper debounce/throttle.\n\n if (Date.now() - this._lastTimeframeSaveTime > TIMEFRAME_SAVE_DEBOUNCE_INTERVAL) {\n this._lastTimeframeSaveTime = Date.now();\n\n await this._saveTargetTimeframe(timeframe);\n }\n }\n\n async stop() {\n log('stopping...');\n await this._ctx.dispose();\n await this._pipeline.stop();\n await this._saveTargetTimeframe(this._pipeline.state.timeframe);\n log('stopped');\n }\n\n private async _saveTargetTimeframe(timeframe: Timeframe) {\n try {\n const newTimeframe = Timeframe.merge(this._targetTimeframe ?? new Timeframe(), timeframe);\n await this._metadata.setSpaceControlLatestTimeframe(this._spaceKey, newTimeframe);\n this._targetTimeframe = newTimeframe;\n } catch (err: any) {\n log(err);\n }\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { scheduleTask, type Trigger } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { ProtocolError, schema } from '@dxos/protocols';\nimport { type Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport {\n type AdmissionDiscoveryService,\n type GetAdmissionCredentialResponse,\n type GetAdmissionCredentialRequest,\n} from '@dxos/protocols/proto/dxos/mesh/teleport';\nimport { type ExtensionContext, RpcExtension } from '@dxos/teleport';\n\nimport { type Space } from './space';\n\n/**\n * Guest's side for a connection to a concrete peer in p2p network during invitation.\n */\nexport class CredentialRetrieverExtension extends RpcExtension<\n { AdmissionDiscoveryService: AdmissionDiscoveryService },\n {}\n> {\n private _ctx = new Context();\n\n constructor(\n private readonly _request: GetAdmissionCredentialRequest,\n private readonly _onResult: Trigger<Credential>,\n ) {\n super({\n requested: {\n AdmissionDiscoveryService: schema.getService('dxos.mesh.teleport.AdmissionDiscoveryService'),\n },\n });\n }\n\n protected override async getHandlers(): Promise<{}> {\n return {};\n }\n\n override async onOpen(context: ExtensionContext) {\n await super.onOpen(context);\n scheduleTask(this._ctx, async () => {\n try {\n const result = await this.rpc.AdmissionDiscoveryService.getAdmissionCredential(this._request);\n this._onResult.wake(result.admissionCredential);\n } catch (err: any) {\n context.close(err);\n }\n });\n }\n\n override async onClose() {\n await this._ctx.dispose();\n }\n\n override async onAbort(): Promise<void> {\n await this._ctx.dispose();\n }\n}\n\nexport class CredentialServerExtension extends RpcExtension<\n {},\n { AdmissionDiscoveryService: AdmissionDiscoveryService }\n> {\n constructor(private readonly _space: Space) {\n super({\n exposed: {\n AdmissionDiscoveryService: schema.getService('dxos.mesh.teleport.AdmissionDiscoveryService'),\n },\n });\n }\n\n protected override async getHandlers(): Promise<{ AdmissionDiscoveryService: AdmissionDiscoveryService }> {\n return {\n AdmissionDiscoveryService: {\n getAdmissionCredential: async (\n request: GetAdmissionCredentialRequest,\n ): Promise<GetAdmissionCredentialResponse> => {\n const memberInfo = this._space.spaceState.members.get(request.memberKey);\n if (!memberInfo?.credential) {\n throw new ProtocolError('Space member not found.', request);\n }\n return { admissionCredential: memberInfo.credential };\n },\n },\n };\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { type Event } from '@dxos/async';\nimport { discoveryKey, subtleCrypto } from '@dxos/crypto';\nimport { type FeedWrapper } from '@dxos/feed-store';\nimport { PublicKey } from '@dxos/keys';\nimport { log, logInfo } from '@dxos/log';\nimport {\n MMSTTopology,\n type SwarmNetworkManager,\n type SwarmConnection,\n type WireProtocol,\n type WireProtocolParams,\n type WireProtocolProvider,\n} from '@dxos/network-manager';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type MuxerStats, Teleport } from '@dxos/teleport';\nimport { type BlobStore, BlobSync } from '@dxos/teleport-extension-object-sync';\nimport { ReplicatorExtension } from '@dxos/teleport-extension-replicator';\nimport { trace } from '@dxos/tracing';\nimport { CallbackCollection, ComplexMap, type AsyncCallback } from '@dxos/util';\n\nimport { AuthExtension, type AuthProvider, type AuthVerifier } from './auth';\n\nexport const MOCK_AUTH_PROVIDER: AuthProvider = async (nonce: Uint8Array) => Buffer.from('mock');\nexport const MOCK_AUTH_VERIFIER: AuthVerifier = async (nonce: Uint8Array, credential: Uint8Array) => true;\n\n// TODO(burdon): Reconcile with SigningContext (define types together).\nexport interface SwarmIdentity {\n peerKey: PublicKey;\n credentialProvider: AuthProvider;\n credentialAuthenticator: AuthVerifier;\n}\n\nexport type SpaceProtocolOptions = {\n topic: PublicKey; // TODO(burdon): Rename?\n swarmIdentity: SwarmIdentity;\n networkManager: SwarmNetworkManager;\n\n blobStore: BlobStore;\n\n onFeed?: (feed: FeedWrapper<FeedMessage>) => Promise<void>;\n\n /**\n * Called when new session is authenticated.\n * Additional extensions can be added here.\n */\n onSessionAuth?: (session: Teleport) => void;\n onAuthFailure?: (session: Teleport) => void;\n\n disableP2pReplication?: boolean;\n};\n\n/**\n * Manages Teleport protocol stream creation and joining swarms with replication and presence extensions.\n */\n@trace.resource()\nexport class SpaceProtocol {\n private readonly _networkManager: SwarmNetworkManager;\n private readonly _swarmIdentity: SwarmIdentity;\n private readonly _onSessionAuth?: (session: Teleport) => void;\n private readonly _onAuthFailure?: (session: Teleport) => void;\n\n public readonly blobSync: BlobSync;\n\n private readonly _disableP2pReplication: boolean;\n\n @logInfo\n @trace.info()\n private readonly _topic: Promise<PublicKey>;\n\n @trace.info()\n private readonly _spaceKey: PublicKey;\n\n private readonly _feeds = new Set<FeedWrapper<FeedMessage>>();\n private readonly _sessions = new ComplexMap<PublicKey, SpaceProtocolSession>(PublicKey.hash);\n // TODO(burdon): Move to config (with sensible defaults).\n private readonly _topology = new MMSTTopology({\n originateConnections: 4,\n maxPeers: 10,\n sampleSize: 20,\n });\n\n private _connection?: SwarmConnection;\n\n public readonly feedAdded = new CallbackCollection<AsyncCallback<FeedWrapper<FeedMessage>>>();\n\n get sessions(): ReadonlyMap<PublicKey, SpaceProtocolSession> {\n return this._sessions;\n }\n\n get feeds(): ReadonlySet<FeedWrapper<FeedMessage>> {\n return this._feeds;\n }\n\n @logInfo\n private get _ownPeerKey() {\n return this._swarmIdentity.peerKey;\n }\n\n constructor({\n topic,\n swarmIdentity,\n networkManager,\n onSessionAuth,\n onAuthFailure,\n blobStore,\n disableP2pReplication,\n }: SpaceProtocolOptions) {\n this._spaceKey = topic;\n this._networkManager = networkManager;\n this._swarmIdentity = swarmIdentity;\n this._onSessionAuth = onSessionAuth;\n this._onAuthFailure = onAuthFailure;\n this.blobSync = new BlobSync({ blobStore });\n\n // TODO(burdon): Async race condition? Move to start?\n this._topic = subtleCrypto.digest('SHA-256', topic.asBuffer()).then(discoveryKey).then(PublicKey.from);\n\n this._disableP2pReplication = disableP2pReplication ?? false;\n }\n\n // TODO(burdon): Create abstraction for Space (e.g., add keys and have provider).\n async addFeed(feed: FeedWrapper<FeedMessage>) {\n log('addFeed', { key: feed.key });\n\n this._feeds.add(feed);\n for (const session of this._sessions.values()) {\n session.replicator.addFeed(feed);\n }\n\n await this.feedAdded.callSerial(feed);\n }\n\n // TODO(burdon): Rename open? Common open/close interfaces for all services?\n async start() {\n if (this._connection) {\n return;\n }\n\n // TODO(burdon): Document why empty buffer.\n const credentials = await this._swarmIdentity.credentialProvider(Buffer.from(''));\n\n await this.blobSync.open();\n\n log('starting...');\n const topic = await this._topic;\n this._connection = await this._networkManager.joinSwarm({\n protocolProvider: this._createProtocolProvider(credentials),\n peerId: this._swarmIdentity.peerKey,\n topic,\n topology: this._topology,\n label: `swarm ${topic.truncate()} for space ${this._spaceKey.truncate()}`,\n });\n\n log('started');\n }\n\n public updateTopology() {\n this._topology.forceUpdate();\n }\n\n async stop() {\n await this.blobSync.close();\n\n if (this._connection) {\n log('stopping...');\n await this._connection.close();\n log('stopped');\n }\n }\n\n private _createProtocolProvider(credentials: Uint8Array | undefined): WireProtocolProvider {\n return (wireParams) => {\n const session = new SpaceProtocolSession({\n wireParams,\n swarmIdentity: this._swarmIdentity,\n onSessionAuth: this._onSessionAuth,\n onAuthFailure: this._onAuthFailure,\n blobSync: this.blobSync,\n disableP2pReplication: this._disableP2pReplication,\n });\n this._sessions.set(wireParams.remotePeerId, session);\n\n for (const feed of this._feeds) {\n session.replicator.addFeed(feed);\n }\n\n return session;\n };\n }\n}\n\nexport type SpaceProtocolSessionParams = {\n wireParams: WireProtocolParams;\n swarmIdentity: SwarmIdentity;\n\n blobSync: BlobSync;\n\n /**\n * Called when new session is authenticated.\n * Additional extensions can be added here.\n */\n onSessionAuth?: (session: Teleport) => void;\n\n onAuthFailure?: (session: Teleport) => void;\n\n disableP2pReplication?: boolean;\n};\n\nexport enum AuthStatus {\n INITIAL = 'INITIAL',\n SUCCESS = 'SUCCESS',\n FAILURE = 'FAILURE',\n}\n\n// TODO(dmaretskyi): Move to a separate file.\n/**\n * Represents a single connection to a remote peer\n */\nexport class SpaceProtocolSession implements WireProtocol {\n @logInfo\n private readonly _wireParams: WireProtocolParams;\n\n private readonly _disableP2pReplication: boolean;\n\n private readonly _onSessionAuth?: (session: Teleport) => void;\n private readonly _onAuthFailure?: (session: Teleport) => void;\n private readonly _swarmIdentity: SwarmIdentity;\n private readonly _blobSync: BlobSync;\n\n private readonly _teleport: Teleport;\n\n // TODO(dmaretskyi): Start with upload=false when switching it on the fly works.\n public readonly replicator = new ReplicatorExtension().setOptions({ upload: true });\n\n private _authStatus = AuthStatus.INITIAL;\n\n @logInfo\n get authStatus() {\n return this._authStatus;\n }\n\n get stats(): Event<MuxerStats> {\n return this._teleport.stats;\n }\n\n // TODO(dmaretskyi): Allow to pass in extra extensions.\n constructor({\n wireParams,\n swarmIdentity,\n onSessionAuth,\n onAuthFailure,\n blobSync,\n disableP2pReplication,\n }: SpaceProtocolSessionParams) {\n this._wireParams = wireParams;\n this._swarmIdentity = swarmIdentity;\n this._onSessionAuth = onSessionAuth;\n this._onAuthFailure = onAuthFailure;\n this._blobSync = blobSync;\n\n this._teleport = new Teleport(wireParams);\n\n this._disableP2pReplication = disableP2pReplication ?? false;\n }\n\n get stream() {\n return this._teleport.stream;\n }\n\n async open(sessionId?: PublicKey): Promise<void> {\n await this._teleport.open(sessionId);\n this._teleport.addExtension(\n 'dxos.mesh.teleport.auth',\n new AuthExtension({\n provider: this._swarmIdentity.credentialProvider,\n verifier: this._swarmIdentity.credentialAuthenticator,\n onAuthSuccess: () => {\n log('Peer authenticated');\n this._authStatus = AuthStatus.SUCCESS;\n this._onSessionAuth?.(this._teleport);\n // TODO(dmaretskyi): Configure replicator to upload.\n },\n onAuthFailure: () => {\n this._authStatus = AuthStatus.FAILURE;\n this._onAuthFailure?.(this._teleport);\n },\n }),\n );\n\n if (!this._disableP2pReplication) {\n this._teleport.addExtension('dxos.mesh.teleport.replicator', this.replicator);\n }\n this._teleport.addExtension('dxos.mesh.teleport.blobsync', this._blobSync.createExtension());\n }\n\n async close(): Promise<void> {\n log('close');\n await this._teleport.close();\n }\n\n async abort(): Promise<void> {\n await this._teleport.abort();\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { synchronized, trackLeaks, Trigger } from '@dxos/async';\nimport { type DelegateInvitationCredential, type MemberInfo } from '@dxos/credentials';\nimport { failUndefined } from '@dxos/debug';\nimport { type FeedStore } from '@dxos/feed-store';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type SwarmNetworkManager } from '@dxos/network-manager';\nimport { trace } from '@dxos/protocols';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type SpaceMetadata } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport type { Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { type Teleport } from '@dxos/teleport';\nimport { type BlobStore } from '@dxos/teleport-extension-object-sync';\nimport { ComplexMap } from '@dxos/util';\n\nimport { CredentialRetrieverExtension } from './admission-discovery-extension';\nimport { Space, createIdFromSpaceKey } from './space';\nimport { SpaceProtocol, type SwarmIdentity } from './space-protocol';\nimport { SnapshotManager, type SnapshotStore } from '../db-host';\nimport { type MetadataStore } from '../metadata';\n\nexport type SpaceManagerParams = {\n feedStore: FeedStore<FeedMessage>;\n networkManager: SwarmNetworkManager;\n metadataStore: MetadataStore;\n\n /**\n * @deprecated Replaced by BlobStore.\n */\n snapshotStore: SnapshotStore;\n\n blobStore: BlobStore;\n\n disableP2pReplication?: boolean;\n};\n\nexport type ConstructSpaceParams = {\n metadata: SpaceMetadata;\n swarmIdentity: SwarmIdentity;\n memberKey: PublicKey;\n /**\n * Called when connection auth passed successful.\n */\n onAuthorizedConnection: (session: Teleport) => void;\n onAuthFailure?: (session: Teleport) => void;\n onDelegatedInvitationStatusChange: (invitation: DelegateInvitationCredential, isActive: boolean) => Promise<void>;\n onMemberRolesChanged: (member: MemberInfo[]) => Promise<void>;\n};\n\nexport type RequestSpaceAdmissionCredentialParams = {\n spaceKey: PublicKey;\n identityKey: PublicKey;\n swarmIdentity: SwarmIdentity;\n timeout: number;\n};\n\n/**\n * Manages a collection of ECHO (Data) Spaces.\n */\n@trackLeaks('open', 'close')\nexport class SpaceManager {\n private readonly _spaces = new ComplexMap<PublicKey, Space>(PublicKey.hash);\n private readonly _feedStore: FeedStore<FeedMessage>;\n private readonly _networkManager: SwarmNetworkManager;\n private readonly _metadataStore: MetadataStore;\n private readonly _snapshotStore: SnapshotStore;\n private readonly _blobStore: BlobStore;\n private readonly _instanceId = PublicKey.random().toHex();\n private readonly _disableP2pReplication: boolean;\n\n constructor({\n feedStore,\n networkManager,\n metadataStore,\n snapshotStore,\n blobStore,\n disableP2pReplication,\n }: SpaceManagerParams) {\n // TODO(burdon): Assert.\n this._feedStore = feedStore;\n this._networkManager = networkManager;\n this._metadataStore = metadataStore;\n this._snapshotStore = snapshotStore;\n this._blobStore = blobStore;\n this._disableP2pReplication = disableP2pReplication ?? false;\n }\n\n // TODO(burdon): Remove.\n get spaces() {\n return this._spaces;\n }\n\n @synchronized\n async open() {}\n\n @synchronized\n async close() {\n await Promise.all([...this._spaces.values()].map((space) => space.close()));\n }\n\n async constructSpace({\n metadata,\n swarmIdentity,\n onAuthorizedConnection,\n onAuthFailure,\n onDelegatedInvitationStatusChange,\n onMemberRolesChanged,\n memberKey,\n }: ConstructSpaceParams) {\n log.trace('dxos.echo.space-manager.construct-space', trace.begin({ id: this._instanceId }));\n log('constructing space...', { spaceKey: metadata.genesisFeedKey });\n\n // The genesis feed will be the same as the control feed if the space was created by the local agent.\n const genesisFeed = await this._feedStore.openFeed(metadata.genesisFeedKey ?? failUndefined());\n\n const spaceKey = metadata.key;\n const spaceId = await createIdFromSpaceKey(spaceKey);\n const protocol = new SpaceProtocol({\n topic: spaceKey,\n swarmIdentity,\n networkManager: this._networkManager,\n onSessionAuth: onAuthorizedConnection,\n onAuthFailure,\n blobStore: this._blobStore,\n disableP2pReplication: this._disableP2pReplication,\n });\n const snapshotManager = new SnapshotManager(this._snapshotStore, this._blobStore, protocol.blobSync);\n\n const space = new Space({\n id: spaceId,\n spaceKey,\n protocol,\n genesisFeed,\n feedProvider: (feedKey, opts) => this._feedStore.openFeed(feedKey, opts),\n metadataStore: this._metadataStore,\n snapshotManager,\n memberKey,\n onDelegatedInvitationStatusChange,\n onMemberRolesChanged,\n });\n this._spaces.set(space.key, space);\n\n log.trace('dxos.echo.space-manager.construct-space', trace.end({ id: this._instanceId }));\n return space;\n }\n\n public async requestSpaceAdmissionCredential(params: RequestSpaceAdmissionCredentialParams): Promise<Credential> {\n const traceKey = 'dxos.echo.space-manager.request-space-admission';\n log.trace(traceKey, trace.begin({ id: this._instanceId }));\n log('requesting space admission credential...', { spaceKey: params.spaceKey });\n\n const onCredentialResolved = new Trigger<Credential>();\n const protocol = new SpaceProtocol({\n topic: params.spaceKey,\n swarmIdentity: params.swarmIdentity,\n networkManager: this._networkManager,\n onSessionAuth: (session: Teleport) => {\n session.addExtension(\n 'dxos.mesh.teleport.admission-discovery',\n new CredentialRetrieverExtension(\n { spaceKey: params.spaceKey, memberKey: params.identityKey },\n onCredentialResolved,\n ),\n );\n },\n onAuthFailure: (session: Teleport) => session.close(),\n blobStore: this._blobStore,\n disableP2pReplication: this._disableP2pReplication,\n });\n\n try {\n await protocol.start();\n const credential = await onCredentialResolved.wait({ timeout: params.timeout });\n log.trace(traceKey, trace.end({ id: this._instanceId }));\n return credential;\n } catch (err: any) {\n log.trace(traceKey, trace.error({ id: this._instanceId, error: err }));\n throw err;\n } finally {\n await protocol.stop();\n }\n }\n}\n", "//\n// Copyright 2021 DXOS.org\n//\n\nimport { type DocumentId } from '@dxos/automerge/automerge-repo';\nimport { type RequestOptions, Stream } from '@dxos/codec-protobuf';\nimport { invariant } from '@dxos/invariant';\nimport { SpaceId } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport {\n type DataService,\n type FlushRequest,\n type SubscribeRequest,\n type BatchedDocumentUpdates,\n type UpdateSubscriptionRequest,\n type GetDocumentHeadsRequest,\n type GetDocumentHeadsResponse,\n type ReIndexHeadsRequest,\n type WaitUntilHeadsReplicatedRequest,\n type UpdateRequest,\n type GetSpaceSyncStateRequest,\n type SpaceSyncState,\n} from '@dxos/protocols/proto/dxos/echo/service';\n\nimport { DocumentsSynchronizer } from './documents-synchronizer';\nimport { deriveCollectionIdFromSpaceId, type AutomergeHost } from '../automerge';\n\nexport type DataServiceParams = {\n automergeHost: AutomergeHost;\n updateIndexes: () => Promise<void>;\n};\n\n/**\n * Data sync between client and services.\n */\n// TODO(burdon): Move to client-services.\nexport class DataServiceImpl implements DataService {\n /**\n * Map of subscriptions.\n * subscriptionId -> DocumentsSynchronizer\n */\n private readonly _subscriptions = new Map<string, DocumentsSynchronizer>();\n\n private readonly _automergeHost: AutomergeHost;\n private readonly _updateIndexes: () => Promise<void>;\n\n constructor(params: DataServiceParams) {\n this._automergeHost = params.automergeHost;\n this._updateIndexes = params.updateIndexes;\n }\n\n subscribe(request: SubscribeRequest): Stream<BatchedDocumentUpdates> {\n return new Stream<BatchedDocumentUpdates>(({ next, ready }) => {\n const synchronizer = new DocumentsSynchronizer({\n repo: this._automergeHost.repo,\n sendUpdates: (updates) => next(updates),\n });\n synchronizer\n .open()\n .then(() => {\n this._subscriptions.set(request.subscriptionId, synchronizer);\n ready();\n })\n .catch((err) => log.catch(err));\n return () => synchronizer.close();\n });\n }\n\n async updateSubscription(request: UpdateSubscriptionRequest) {\n const synchronizer = this._subscriptions.get(request.subscriptionId);\n invariant(synchronizer, 'Subscription not found');\n\n if (request.addIds?.length) {\n await synchronizer.addDocuments(request.addIds as DocumentId[]);\n }\n if (request.removeIds?.length) {\n await synchronizer.removeDocuments(request.removeIds as DocumentId[]);\n }\n }\n\n async update(request: UpdateRequest): Promise<void> {\n if (!request.updates) {\n return;\n }\n const synchronizer = this._subscriptions.get(request.subscriptionId);\n invariant(synchronizer, 'Subscription not found');\n\n synchronizer.update(request.updates);\n }\n\n async flush(request: FlushRequest): Promise<void> {\n await this._automergeHost.flush(request);\n }\n\n async getDocumentHeads(request: GetDocumentHeadsRequest): Promise<GetDocumentHeadsResponse> {\n const documentIds = request.documentIds;\n if (!documentIds) {\n return { heads: { entries: [] } };\n }\n const heads = await this._automergeHost.getHeads(documentIds as DocumentId[]);\n return {\n heads: {\n entries: heads.map((heads, idx) => ({ documentId: documentIds[idx], heads })),\n },\n };\n }\n\n async waitUntilHeadsReplicated(\n request: WaitUntilHeadsReplicatedRequest,\n options?: RequestOptions | undefined,\n ): Promise<void> {\n await this._automergeHost.waitUntilHeadsReplicated(request.heads);\n }\n\n async reIndexHeads(request: ReIndexHeadsRequest, options?: RequestOptions): Promise<void> {\n await this._automergeHost.reIndexHeads((request.documentIds ?? []) as DocumentId[]);\n }\n\n async updateIndexes() {\n await this._updateIndexes();\n }\n\n async getSpaceSyncState(\n request: GetSpaceSyncStateRequest,\n options?: RequestOptions | undefined,\n ): Promise<SpaceSyncState> {\n invariant(SpaceId.isValid(request.spaceId));\n const collectionId = deriveCollectionIdFromSpaceId(request.spaceId);\n const state = await this._automergeHost.getCollectionSyncState(collectionId);\n\n return {\n peers: state.peers.map((peer) => ({\n peerId: peer.peerId,\n documentsToReconcile: peer.differentDocuments,\n })),\n };\n }\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Event, asyncTimeout } from '@dxos/async';\nimport {\n getBackend,\n getHeads,\n isAutomerge,\n equals as headsEquals,\n save,\n type Doc,\n type Heads,\n} from '@dxos/automerge/automerge';\nimport {\n type DocHandleChangePayload,\n Repo,\n type AnyDocumentId,\n type DocHandle,\n type DocumentId,\n type PeerCandidatePayload,\n type PeerDisconnectedPayload,\n type PeerId,\n type StorageAdapterInterface,\n type StorageKey,\n} from '@dxos/automerge/automerge-repo';\nimport { Context, Resource, cancelWithContext, type Lifecycle } from '@dxos/context';\nimport { type SpaceDoc } from '@dxos/echo-protocol';\nimport { type IndexMetadataStore } from '@dxos/indexing';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { type LevelDB } from '@dxos/kv-store';\nimport { log } from '@dxos/log';\nimport { objectPointerCodec } from '@dxos/protocols';\nimport { type DocHeadsList, type FlushRequest } from '@dxos/protocols/proto/dxos/echo/service';\nimport { trace } from '@dxos/tracing';\n\nimport { CollectionSynchronizer, diffCollectionState, type CollectionState } from './collection-synchronizer';\nimport { type EchoDataMonitor } from './echo-data-monitor';\nimport { EchoNetworkAdapter, isEchoPeerMetadata } from './echo-network-adapter';\nimport { type EchoReplicator, type RemoteDocumentExistenceCheckParams } from './echo-replicator';\nimport { HeadsStore } from './heads-store';\nimport { LevelDBStorageAdapter, type BeforeSaveParams } from './leveldb-storage-adapter';\n\nexport type AutomergeHostParams = {\n db: LevelDB;\n\n indexMetadataStore: IndexMetadataStore;\n dataMonitor?: EchoDataMonitor;\n};\n\nexport type LoadDocOptions = {\n timeout?: number;\n};\n\nexport type CreateDocOptions = {\n /**\n * Import the document together with its history.\n */\n preserveHistory?: boolean;\n};\n\n/**\n * Abstracts over the AutomergeRepo.\n */\n@trace.resource()\nexport class AutomergeHost extends Resource {\n private readonly _db: LevelDB;\n private readonly _indexMetadataStore: IndexMetadataStore;\n private readonly _echoNetworkAdapter: EchoNetworkAdapter;\n\n private readonly _collectionSynchronizer = new CollectionSynchronizer({\n queryCollectionState: this._queryCollectionState.bind(this),\n sendCollectionState: this._sendCollectionState.bind(this),\n shouldSyncCollection: this._shouldSyncCollection.bind(this),\n });\n\n private _repo!: Repo;\n private _storage!: StorageAdapterInterface & Lifecycle;\n private readonly _headsStore: HeadsStore;\n\n @trace.info()\n private _peerId!: PeerId;\n\n constructor({ db, indexMetadataStore, dataMonitor }: AutomergeHostParams) {\n super();\n this._db = db;\n this._storage = new LevelDBStorageAdapter({\n db: db.sublevel('automerge'),\n callbacks: {\n beforeSave: async (params) => this._beforeSave(params),\n afterSave: async (key) => this._afterSave(key),\n },\n monitor: dataMonitor,\n });\n this._echoNetworkAdapter = new EchoNetworkAdapter({\n getContainingSpaceForDocument: this._getContainingSpaceForDocument.bind(this),\n isDocumentInRemoteCollection: this._isDocumentInRemoteCollection.bind(this),\n onCollectionStateQueried: this._onCollectionStateQueried.bind(this),\n onCollectionStateReceived: this._onCollectionStateReceived.bind(this),\n monitor: dataMonitor,\n });\n this._headsStore = new HeadsStore({ db: db.sublevel('heads') });\n this._indexMetadataStore = indexMetadataStore;\n }\n\n protected override async _open() {\n // TODO(burdon): Should this be stable?\n this._peerId = `host-${PublicKey.random().toHex()}` as PeerId;\n\n await this._storage.open?.();\n\n // Construct the automerge repo.\n this._repo = new Repo({\n peerId: this._peerId as PeerId,\n sharePolicy: this._sharePolicy.bind(this),\n storage: this._storage,\n network: [\n // Upstream swarm.\n this._echoNetworkAdapter,\n ],\n });\n\n Event.wrap(this._echoNetworkAdapter, 'peer-candidate').on(this._ctx, ((e: PeerCandidatePayload) =>\n this._onPeerConnected(e.peerId)) as any);\n Event.wrap(this._echoNetworkAdapter, 'peer-disconnected').on(this._ctx, ((e: PeerDisconnectedPayload) =>\n this._onPeerDisconnected(e.peerId)) as any);\n\n this._collectionSynchronizer.remoteStateUpdated.on(this._ctx, ({ collectionId, peerId }) => {\n this._onRemoteCollectionStateUpdated(collectionId, peerId);\n });\n\n await this._echoNetworkAdapter.open();\n await this._collectionSynchronizer.open();\n await this._echoNetworkAdapter.open();\n await this._echoNetworkAdapter.whenConnected();\n }\n\n protected override async _close() {\n await this._collectionSynchronizer.close();\n await this._storage.close?.();\n await this._echoNetworkAdapter.close();\n await this._ctx.dispose();\n }\n\n /**\n * @deprecated To be abstracted away.\n */\n get repo(): Repo {\n return this._repo;\n }\n\n get peerId(): PeerId {\n return this._peerId;\n }\n\n get loadedDocsCount(): number {\n return Object.keys(this._repo.handles).length;\n }\n\n async addReplicator(replicator: EchoReplicator) {\n await this._echoNetworkAdapter.addReplicator(replicator);\n }\n\n async removeReplicator(replicator: EchoReplicator) {\n await this._echoNetworkAdapter.removeReplicator(replicator);\n }\n\n /**\n * Loads the document handle from the repo and waits for it to be ready.\n */\n async loadDoc<T>(ctx: Context, documentId: AnyDocumentId, opts?: LoadDocOptions): Promise<DocHandle<T>> {\n let handle: DocHandle<T> | undefined;\n if (typeof documentId === 'string') {\n // NOTE: documentId might also be a URL, in which case this lookup will fail.\n handle = this._repo.handles[documentId as DocumentId];\n }\n if (!handle) {\n handle = this._repo.find(documentId as DocumentId);\n }\n\n // `whenReady` creates a timeout so we guard it with an if to skip it if the handle is already ready.\n if (!handle.isReady()) {\n if (!opts?.timeout) {\n await cancelWithContext(ctx, handle.whenReady());\n } else {\n await cancelWithContext(ctx, asyncTimeout(handle.whenReady(), opts.timeout));\n }\n }\n\n return handle;\n }\n\n /**\n * Create new persisted document.\n */\n createDoc<T>(initialValue?: T | Doc<T>, opts?: CreateDocOptions): DocHandle<T> {\n if (opts?.preserveHistory) {\n if (!isAutomerge(initialValue)) {\n throw new TypeError('Initial value must be an Automerge document');\n }\n // TODO(dmaretskyi): There's a more efficient way.\n return this._repo.import(save(initialValue as Doc<T>));\n } else {\n return this._repo.create(initialValue);\n }\n }\n\n async waitUntilHeadsReplicated(heads: DocHeadsList): Promise<void> {\n const entries = heads.entries;\n if (!entries?.length) {\n return;\n }\n const documentIds = entries.map((entry) => entry.documentId as DocumentId);\n const documentHeads = await this.getHeads(documentIds);\n const headsToWait = entries.filter((entry, index) => {\n const targetHeads = entry.heads;\n if (!targetHeads || targetHeads.length === 0) {\n return false;\n }\n const currentHeads = documentHeads[index];\n return !(currentHeads !== null && headsEquals(currentHeads, targetHeads));\n });\n if (headsToWait.length > 0) {\n await Promise.all(\n headsToWait.map(async (entry, index) => {\n const handle = await this.loadDoc(Context.default(), entry.documentId as DocumentId);\n await waitForHeads(handle, entry.heads!);\n }),\n );\n }\n\n // Flush to disk handles loaded to memory also so that the indexer can pick up the changes.\n await this._repo.flush(documentIds.filter((documentId) => !!this._repo.handles[documentId]));\n }\n\n async reIndexHeads(documentIds: DocumentId[]) {\n for (const documentId of documentIds) {\n log.info('re-indexing heads for document', { documentId });\n const handle = this._repo.find(documentId);\n await handle.whenReady(['ready', 'requesting']);\n if (handle.inState(['requesting'])) {\n log.warn('document is not available locally, skipping', { documentId });\n continue; // Handle not available locally.\n }\n\n const doc = handle.docSync();\n invariant(doc);\n\n const heads = getHeads(doc);\n const batch = this._db.batch();\n this._headsStore.setHeads(documentId, heads, batch);\n await batch.write();\n }\n log.info('done re-indexing heads');\n }\n\n // TODO(dmaretskyi): Share based on HALO permissions and space affinity.\n // Hosts, running in the worker, don't share documents unless requested by other peers.\n // NOTE: If both peers return sharePolicy=false the replication will not happen\n // https://github.com/automerge/automerge-repo/pull/292\n private async _sharePolicy(peerId: PeerId, documentId?: DocumentId): Promise<boolean> {\n if (peerId.startsWith('client-')) {\n return false; // Only send docs to clients if they are requested.\n }\n\n if (!documentId) {\n return false;\n }\n\n const peerMetadata = this.repo.peerMetadataByPeerId[peerId];\n if (isEchoPeerMetadata(peerMetadata)) {\n return this._echoNetworkAdapter.shouldAdvertise(peerId, { documentId });\n }\n\n return false;\n }\n\n private async _beforeSave({ path, batch }: BeforeSaveParams) {\n const handle = this._repo.handles[path[0] as DocumentId];\n if (!handle) {\n return;\n }\n const doc = handle.docSync();\n if (!doc) {\n return;\n }\n\n const heads = getHeads(doc);\n this._headsStore.setHeads(handle.documentId, heads, batch);\n\n const spaceKey = getSpaceKeyFromDoc(doc) ?? undefined;\n const objectIds = Object.keys(doc.objects ?? {});\n const encodedIds = objectIds.map((objectId) =>\n objectPointerCodec.encode({ documentId: handle.documentId, objectId, spaceKey }),\n );\n const idToLastHash = new Map(encodedIds.map((id) => [id, heads]));\n this._indexMetadataStore.markDirty(idToLastHash, batch);\n }\n\n private _shouldSyncCollection(collectionId: string, peerId: PeerId): boolean {\n const peerMetadata = this._repo.peerMetadataByPeerId[peerId];\n if (isEchoPeerMetadata(peerMetadata)) {\n return this._echoNetworkAdapter.shouldSyncCollection(peerId, { collectionId });\n }\n\n return false;\n }\n\n /**\n * Called by AutomergeStorageAdapter after levelDB batch commit.\n */\n private async _afterSave(path: StorageKey) {\n this._indexMetadataStore.notifyMarkedDirty();\n\n const documentId = path[0] as DocumentId;\n const document = this._repo.handles[documentId]?.docSync();\n if (document) {\n const heads = getHeads(document);\n this._onHeadsChanged(documentId, heads);\n }\n }\n\n @trace.info({ depth: null })\n private _automergePeers() {\n return this._repo.peers;\n }\n\n private async _isDocumentInRemoteCollection(params: RemoteDocumentExistenceCheckParams): Promise<boolean> {\n for (const collectionId of this._collectionSynchronizer.getRegisteredCollectionIds()) {\n const remoteCollections = this._collectionSynchronizer.getRemoteCollectionStates(collectionId);\n const remotePeerDocs = remoteCollections.get(params.peerId as PeerId)?.documents;\n if (remotePeerDocs && params.documentId in remotePeerDocs) {\n return true;\n }\n }\n return false;\n }\n\n private async _getContainingSpaceForDocument(documentId: string): Promise<PublicKey | null> {\n const doc = this._repo.handles[documentId as any]?.docSync();\n if (!doc) {\n return null;\n }\n\n const spaceKeyHex = getSpaceKeyFromDoc(doc);\n if (!spaceKeyHex) {\n return null;\n }\n\n return PublicKey.from(spaceKeyHex);\n }\n\n /**\n * Flush documents to disk.\n */\n @trace.span({ showInBrowserTimeline: true })\n async flush({ documentIds }: FlushRequest = {}): Promise<void> {\n // Note: Sync protocol for client and services ensures that all handles should have all changes.\n\n await this._repo.flush(documentIds as DocumentId[] | undefined);\n }\n\n async getHeads(documentIds: DocumentId[]): Promise<(Heads | undefined)[]> {\n const result: (Heads | undefined)[] = [];\n const storeRequestIds: DocumentId[] = [];\n const storeResultIndices: number[] = [];\n for (const documentId of documentIds) {\n const doc = this._repo.handles[documentId]?.docSync();\n if (doc) {\n result.push(getHeads(doc));\n } else {\n storeRequestIds.push(documentId);\n storeResultIndices.push(result.length);\n result.push(undefined);\n }\n }\n if (storeRequestIds.length > 0) {\n const storedHeads = await this._headsStore.getHeads(storeRequestIds);\n for (let i = 0; i < storedHeads.length; i++) {\n result[storeResultIndices[i]] = storedHeads[i];\n }\n }\n return result;\n }\n\n //\n // Collection sync.\n //\n\n getLocalCollectionState(collectionId: string): CollectionState | undefined {\n return this._collectionSynchronizer.getLocalCollectionState(collectionId);\n }\n\n getRemoteCollectionStates(collectionId: string): ReadonlyMap<PeerId, CollectionState> {\n return this._collectionSynchronizer.getRemoteCollectionStates(collectionId);\n }\n\n refreshCollection(collectionId: string) {\n this._collectionSynchronizer.refreshCollection(collectionId);\n }\n\n async getCollectionSyncState(collectionId: string): Promise<CollectionSyncState> {\n const result: CollectionSyncState = {\n peers: [],\n };\n\n const localState = this.getLocalCollectionState(collectionId);\n const remoteState = this.getRemoteCollectionStates(collectionId);\n\n if (!localState) {\n return result;\n }\n\n for (const [peerId, state] of remoteState) {\n const diff = diffCollectionState(localState, state);\n result.peers.push({\n peerId,\n differentDocuments: diff.different.length,\n });\n }\n\n return result;\n }\n\n /**\n * Update the local collection state based on the locally stored document heads.\n */\n async updateLocalCollectionState(collectionId: string, documentIds: DocumentId[]) {\n const heads = await this.getHeads(documentIds);\n const documents: Record<DocumentId, Heads> = Object.fromEntries(\n heads.map((heads, index) => [documentIds[index], heads ?? []]),\n );\n this._collectionSynchronizer.setLocalCollectionState(collectionId, { documents });\n }\n\n private _onCollectionStateQueried(collectionId: string, peerId: PeerId) {\n this._collectionSynchronizer.onCollectionStateQueried(collectionId, peerId);\n }\n\n private _onCollectionStateReceived(collectionId: string, peerId: PeerId, state: unknown) {\n this._collectionSynchronizer.onRemoteStateReceived(collectionId, peerId, decodeCollectionState(state));\n }\n\n private _queryCollectionState(collectionId: string, peerId: PeerId) {\n this._echoNetworkAdapter.queryCollectionState(collectionId, peerId);\n }\n\n private _sendCollectionState(collectionId: string, peerId: PeerId, state: CollectionState) {\n this._echoNetworkAdapter.sendCollectionState(collectionId, peerId, encodeCollectionState(state));\n }\n\n private _onPeerConnected(peerId: PeerId) {\n this._collectionSynchronizer.onConnectionOpen(peerId);\n }\n\n private _onPeerDisconnected(peerId: PeerId) {\n this._collectionSynchronizer.onConnectionClosed(peerId);\n }\n\n private _onRemoteCollectionStateUpdated(collectionId: string, peerId: PeerId) {\n const localState = this._collectionSynchronizer.getLocalCollectionState(collectionId);\n const remoteState = this._collectionSynchronizer.getRemoteCollectionStates(collectionId).get(peerId);\n\n if (!localState || !remoteState) {\n return;\n }\n\n const { different } = diffCollectionState(localState, remoteState);\n\n if (different.length === 0) {\n return;\n }\n\n log.info('replication documents after collection sync', {\n count: different.length,\n });\n\n // Load the documents that are different.\n for (const documentId of different) {\n this._repo.find(documentId);\n }\n }\n\n private _onHeadsChanged(documentId: DocumentId, heads: Heads) {\n for (const collectionId of this._collectionSynchronizer.getRegisteredCollectionIds()) {\n const state = this._collectionSynchronizer.getLocalCollectionState(collectionId);\n if (state?.documents[documentId]) {\n const newState = structuredClone(state);\n newState.documents[documentId] = heads;\n this._collectionSynchronizer.setLocalCollectionState(collectionId, newState);\n }\n }\n }\n}\n\nexport const getSpaceKeyFromDoc = (doc: Doc<SpaceDoc>): string | null => {\n // experimental_spaceKey is set on old documents, new ones are created with doc.access.spaceKey\n const rawSpaceKey = doc.access?.spaceKey ?? (doc as any).experimental_spaceKey;\n if (rawSpaceKey == null) {\n return null;\n }\n\n return String(rawSpaceKey);\n};\n\nconst waitForHeads = async (handle: DocHandle<SpaceDoc>, heads: Heads) => {\n const unavailableHeads = new Set(heads);\n\n await handle.whenReady();\n await Event.wrap<DocHandleChangePayload<SpaceDoc>>(handle, 'change').waitForCondition(() => {\n // Check if unavailable heads became available.\n for (const changeHash of unavailableHeads.values()) {\n if (changeIsPresentInDoc(handle.docSync(), changeHash)) {\n unavailableHeads.delete(changeHash);\n }\n }\n\n return unavailableHeads.size === 0;\n });\n};\n\nconst changeIsPresentInDoc = (doc: Doc<any>, changeHash: string): boolean => {\n return !!getBackend(doc).getChangeByHash(changeHash);\n};\n\nconst decodeCollectionState = (state: unknown): CollectionState => {\n invariant(typeof state === 'object' && state !== null, 'Invalid state');\n\n return state as CollectionState;\n};\n\nconst encodeCollectionState = (state: CollectionState): unknown => {\n return state;\n};\n\nexport type CollectionSyncState = {\n peers: PeerSyncState[];\n};\n\nexport type PeerSyncState = {\n peerId: PeerId;\n differentDocuments: number;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { synchronized, Trigger } from '@dxos/async';\nimport { NetworkAdapter, type Message, type PeerId, type PeerMetadata } from '@dxos/automerge/automerge-repo';\nimport { LifecycleState } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { type PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { nonNullable } from '@dxos/util';\n\nimport {\n type EchoReplicator,\n type RemoteDocumentExistenceCheckParams,\n type ReplicatorConnection,\n type ShouldAdvertiseParams,\n type ShouldSyncCollectionParams,\n} from './echo-replicator';\nimport {\n isCollectionQueryMessage,\n isCollectionStateMessage,\n type CollectionQueryMessage,\n type CollectionStateMessage,\n} from './network-protocol';\nimport { createIdFromSpaceKey } from '../space';\n\nexport interface NetworkDataMonitor {\n recordPeerConnected(peerId: string): void;\n recordPeerDisconnected(peerId: string): void;\n recordMessageSent(message: Message, duration: number): void;\n recordMessageReceived(message: Message): void;\n recordMessageSendingFailed(message: Message): void;\n}\n\nexport type EchoNetworkAdapterParams = {\n getContainingSpaceForDocument: (documentId: string) => Promise<PublicKey | null>;\n isDocumentInRemoteCollection: (params: RemoteDocumentExistenceCheckParams) => Promise<boolean>;\n onCollectionStateQueried: (collectionId: string, peerId: PeerId) => void;\n onCollectionStateReceived: (collectionId: string, peerId: PeerId, state: unknown) => void;\n monitor?: NetworkDataMonitor;\n};\n\n/**\n * Manages a set of {@link EchoReplicator} instances.\n */\nexport class EchoNetworkAdapter extends NetworkAdapter {\n private readonly _replicators = new Set<EchoReplicator>();\n /**\n * Remote peer id -> connection.\n */\n private readonly _connections = new Map<PeerId, ConnectionEntry>();\n private _lifecycleState: LifecycleState = LifecycleState.CLOSED;\n private readonly _connected = new Trigger();\n\n constructor(private readonly _params: EchoNetworkAdapterParams) {\n super();\n }\n\n override connect(peerId: PeerId, peerMetadata?: PeerMetadata | undefined): void {\n this.peerId = peerId;\n this.peerMetadata = peerMetadata;\n this._connected.wake();\n }\n\n override send(message: Message): void {\n this._send(message);\n }\n\n override disconnect(): void {\n // No-op\n }\n\n @synchronized\n async open() {\n if (this._lifecycleState === LifecycleState.OPEN) {\n return;\n }\n this._lifecycleState = LifecycleState.OPEN;\n\n log('emit ready');\n this.emit('ready', {\n network: this,\n });\n }\n\n @synchronized\n async close() {\n if (this._lifecycleState === LifecycleState.CLOSED) {\n return this;\n }\n\n for (const replicator of this._replicators) {\n await replicator.disconnect();\n }\n this._replicators.clear();\n\n this._lifecycleState = LifecycleState.CLOSED;\n }\n\n async whenConnected() {\n await this._connected.wait({ timeout: 10_000 });\n }\n\n @synchronized\n async addReplicator(replicator: EchoReplicator) {\n invariant(this._lifecycleState === LifecycleState.OPEN);\n invariant(this.peerId);\n invariant(!this._replicators.has(replicator));\n\n this._replicators.add(replicator);\n await replicator.connect({\n peerId: this.peerId,\n onConnectionOpen: this._onConnectionOpen.bind(this),\n onConnectionClosed: this._onConnectionClosed.bind(this),\n onConnectionAuthScopeChanged: this._onConnectionAuthScopeChanged.bind(this),\n isDocumentInRemoteCollection: this._params.isDocumentInRemoteCollection,\n getContainingSpaceForDocument: this._params.getContainingSpaceForDocument,\n getContainingSpaceIdForDocument: async (documentId) => {\n const key = await this._params.getContainingSpaceForDocument(documentId);\n return key ? createIdFromSpaceKey(key) : null;\n },\n });\n }\n\n @synchronized\n async removeReplicator(replicator: EchoReplicator) {\n invariant(this._lifecycleState === LifecycleState.OPEN);\n invariant(this._replicators.has(replicator));\n await replicator.disconnect();\n this._replicators.delete(replicator);\n }\n\n async shouldAdvertise(peerId: PeerId, params: ShouldAdvertiseParams): Promise<boolean> {\n const connection = this._connections.get(peerId);\n if (!connection) {\n return false;\n }\n\n return connection.connection.shouldAdvertise(params);\n }\n\n shouldSyncCollection(peerId: PeerId, params: ShouldSyncCollectionParams): boolean {\n const connection = this._connections.get(peerId);\n if (!connection) {\n return false;\n }\n\n return connection.connection.shouldSyncCollection(params);\n }\n\n queryCollectionState(collectionId: string, targetId: PeerId): void {\n const message: CollectionQueryMessage = {\n type: 'collection-query',\n senderId: this.peerId as PeerId,\n targetId,\n collectionId,\n };\n this._send(message);\n }\n\n sendCollectionState(collectionId: string, targetId: PeerId, state: unknown): void {\n const message: CollectionStateMessage = {\n type: 'collection-state',\n senderId: this.peerId as PeerId,\n targetId,\n collectionId,\n state,\n };\n this._send(message);\n }\n\n private _send(message: Message) {\n const connectionEntry = this._connections.get(message.targetId);\n if (!connectionEntry) {\n throw new Error('Connection not found.');\n }\n\n const writeStart = Date.now();\n // TODO(dmaretskyi): Find a way to enforce backpressure on AM-repo.\n connectionEntry.writer\n .write(message)\n .then(() => {\n const durationMs = Date.now() - writeStart;\n this._params.monitor?.recordMessageSent(message, durationMs);\n })\n .catch((err) => {\n if (connectionEntry.isOpen) {\n log.catch(err);\n }\n this._params.monitor?.recordMessageSendingFailed(message);\n });\n }\n\n // TODO(dmaretskyi): Remove.\n getPeersInterestedInCollection(collectionId: string): PeerId[] {\n return Array.from(this._connections.values())\n .map((connection) => {\n return connection.connection.shouldSyncCollection({ collectionId })\n ? (connection.connection.peerId as PeerId)\n : null;\n })\n .filter(nonNullable);\n }\n\n private _onConnectionOpen(connection: ReplicatorConnection) {\n log('Connection opened', { peerId: connection.peerId });\n invariant(!this._connections.has(connection.peerId as PeerId));\n const reader = connection.readable.getReader();\n const writer = connection.writable.getWriter();\n const connectionEntry: ConnectionEntry = { connection, reader, writer, isOpen: true };\n this._connections.set(connection.peerId as PeerId, connectionEntry);\n\n queueMicrotask(async () => {\n try {\n while (true) {\n // TODO(dmaretskyi): Find a way to enforce backpressure on AM-repo.\n const { done, value } = await reader.read();\n if (done) {\n break;\n }\n\n this._onMessage(value);\n }\n } catch (err) {\n if (connectionEntry.isOpen) {\n log.catch(err);\n }\n }\n });\n\n log('emit peer-candidate', { peerId: connection.peerId });\n this._emitPeerCandidate(connection);\n this._params.monitor?.recordPeerConnected(connection.peerId);\n }\n\n private _onMessage(message: Message) {\n if (isCollectionQueryMessage(message)) {\n this._params.onCollectionStateQueried(message.collectionId, message.senderId);\n } else if (isCollectionStateMessage(message)) {\n this._params.onCollectionStateReceived(message.collectionId, message.senderId, message.state);\n } else {\n this.emit('message', message);\n }\n this._params.monitor?.recordMessageReceived(message);\n }\n\n /**\n * Trigger doc-synchronizer shared documents set recalculation. Happens on peer-candidate.\n * TODO(y): replace with a proper API call when sharePolicy update becomes supported by automerge-repo\n */\n private _onConnectionAuthScopeChanged(connection: ReplicatorConnection) {\n log('Connection auth scope changed', { peerId: connection.peerId });\n const entry = this._connections.get(connection.peerId as PeerId);\n invariant(entry);\n this.emit('peer-disconnected', { peerId: connection.peerId as PeerId });\n this._emitPeerCandidate(connection);\n }\n\n private _onConnectionClosed(connection: ReplicatorConnection) {\n log('Connection closed', { peerId: connection.peerId });\n const entry = this._connections.get(connection.peerId as PeerId);\n invariant(entry);\n\n entry.isOpen = false;\n this.emit('peer-disconnected', { peerId: connection.peerId as PeerId });\n this._params.monitor?.recordPeerDisconnected(connection.peerId);\n\n void entry.reader.cancel().catch((err) => log.catch(err));\n void entry.writer.abort().catch((err) => log.catch(err));\n\n this._connections.delete(connection.peerId as PeerId);\n }\n\n private _emitPeerCandidate(connection: ReplicatorConnection) {\n this.emit('peer-candidate', {\n peerId: connection.peerId as PeerId,\n peerMetadata: createEchoPeerMetadata(),\n });\n }\n}\n\ntype ConnectionEntry = {\n connection: ReplicatorConnection;\n reader: ReadableStreamDefaultReader<Message>;\n writer: WritableStreamDefaultWriter<Message>;\n isOpen: boolean;\n};\n\nexport const createEchoPeerMetadata = (): PeerMetadata =>\n ({\n // TODO(dmaretskyi): Refactor this.\n dxos_peerSource: 'EchoNetworkAdapter',\n }) as any;\n\nexport const isEchoPeerMetadata = (metadata: PeerMetadata): boolean =>\n (metadata as any)?.dxos_peerSource === 'EchoNetworkAdapter';\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport type { Message } from '@dxos/automerge/automerge-repo';\nimport {\n type CollectionQueryMessage,\n type CollectionStateMessage,\n MESSAGE_TYPE_COLLECTION_QUERY,\n MESSAGE_TYPE_COLLECTION_STATE,\n} from '@dxos/protocols';\n\nexport { type CollectionStateMessage, type CollectionQueryMessage };\n\nexport const isCollectionQueryMessage = (message: Message): message is CollectionQueryMessage =>\n message.type === MESSAGE_TYPE_COLLECTION_QUERY;\n\nexport const isCollectionStateMessage = (message: Message): message is CollectionStateMessage =>\n message.type === MESSAGE_TYPE_COLLECTION_STATE;\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport type { Heads } from '@dxos/automerge/automerge';\nimport type { DocumentId } from '@dxos/automerge/automerge-repo';\nimport { headsEncoding } from '@dxos/indexing';\nimport type { BatchLevel, SublevelDB } from '@dxos/kv-store';\n\nexport type HeadsStoreParams = {\n db: SublevelDB;\n};\n\nexport class HeadsStore {\n private readonly _db: SublevelDB;\n\n constructor({ db }: HeadsStoreParams) {\n this._db = db;\n }\n\n setHeads(documentId: DocumentId, heads: Heads, batch: BatchLevel) {\n batch.put<DocumentId, Heads>(documentId, heads, {\n sublevel: this._db,\n keyEncoding: 'utf8',\n valueEncoding: headsEncoding,\n });\n }\n\n // TODO(dmaretskyi): Make batched.\n async getHeads(documentIds: DocumentId[]): Promise<Array<Heads | undefined>> {\n return this._db.getMany<DocumentId, Heads>(documentIds, {\n keyEncoding: 'utf8',\n valueEncoding: headsEncoding,\n });\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n// s\n\nimport { type MixedEncoding } from 'level-transcoder';\n\nimport { type StorageAdapterInterface, type Chunk, type StorageKey } from '@dxos/automerge/automerge-repo';\nimport { LifecycleState, Resource } from '@dxos/context';\nimport { type BatchLevel, type SublevelDB } from '@dxos/kv-store';\nimport { type MaybePromise } from '@dxos/util';\n\nexport interface StorageAdapterDataMonitor {\n recordBytesStored(count: number): void;\n recordBytesLoaded(count: number): void;\n recordLoadDuration(durationMs: number): void;\n recordStoreDuration(durationMs: number): void;\n}\n\nexport type LevelDBStorageAdapterParams = {\n db: SublevelDB;\n callbacks?: StorageCallbacks;\n monitor?: StorageAdapterDataMonitor;\n};\n\nexport type BeforeSaveParams = { path: StorageKey; batch: BatchLevel };\n\nexport interface StorageCallbacks {\n beforeSave(params: BeforeSaveParams): MaybePromise<void>;\n afterSave(path: StorageKey): MaybePromise<void>;\n}\n\nexport class LevelDBStorageAdapter extends Resource implements StorageAdapterInterface {\n constructor(private readonly _params: LevelDBStorageAdapterParams) {\n super();\n }\n\n async load(keyArray: StorageKey): Promise<Uint8Array | undefined> {\n try {\n if (this._lifecycleState !== LifecycleState.OPEN) {\n // TODO(mykola): this should be an error.\n return undefined;\n }\n const startMs = Date.now();\n const chunk = await this._params.db.get<StorageKey, Uint8Array>(keyArray, { ...encodingOptions });\n this._params.monitor?.recordBytesLoaded(chunk.byteLength);\n this._params.monitor?.recordLoadDuration(Date.now() - startMs);\n return chunk;\n } catch (err: any) {\n if (isLevelDbNotFoundError(err)) {\n return undefined;\n }\n throw err;\n }\n }\n\n async save(keyArray: StorageKey, binary: Uint8Array): Promise<void> {\n if (this._lifecycleState !== LifecycleState.OPEN) {\n return undefined;\n }\n const startMs = Date.now();\n const batch = this._params.db.batch();\n\n await this._params.callbacks?.beforeSave?.({ path: keyArray, batch });\n batch.put<StorageKey, Uint8Array>(keyArray, Buffer.from(binary), {\n ...encodingOptions,\n });\n await batch.write();\n this._params.monitor?.recordBytesStored(binary.byteLength);\n\n await this._params.callbacks?.afterSave?.(keyArray);\n this._params.monitor?.recordStoreDuration(Date.now() - startMs);\n }\n\n async remove(keyArray: StorageKey): Promise<void> {\n if (this._lifecycleState !== LifecycleState.OPEN) {\n return undefined;\n }\n await this._params.db.del<StorageKey>(keyArray, { ...encodingOptions });\n }\n\n async loadRange(keyPrefix: StorageKey): Promise<Chunk[]> {\n if (this._lifecycleState !== LifecycleState.OPEN) {\n return [];\n }\n const startMs = Date.now();\n const result: Chunk[] = [];\n for await (const [key, value] of this._params.db.iterator<StorageKey, Uint8Array>({\n gte: keyPrefix,\n lte: [...keyPrefix, '\\uffff'],\n ...encodingOptions,\n })) {\n result.push({\n key,\n data: value,\n });\n this._params.monitor?.recordBytesLoaded(value.byteLength);\n }\n this._params.monitor?.recordLoadDuration(Date.now() - startMs);\n return result;\n }\n\n async removeRange(keyPrefix: StorageKey): Promise<void> {\n if (this._lifecycleState !== LifecycleState.OPEN) {\n return undefined;\n }\n const batch = this._params.db.batch();\n\n for await (const [key] of this._params.db.iterator<StorageKey, Uint8Array>({\n gte: keyPrefix,\n lte: [...keyPrefix, '\\uffff'],\n ...encodingOptions,\n })) {\n batch.del<StorageKey>(key, { ...encodingOptions });\n }\n await batch.write();\n }\n}\n\nconst keyEncoder: MixedEncoding<StorageKey, Uint8Array, StorageKey> = {\n encode: (key: StorageKey): Uint8Array =>\n Buffer.from(key.map((k) => k.replaceAll('%', '%25').replaceAll('-', '%2D')).join('-')),\n decode: (key: Uint8Array): StorageKey =>\n Buffer.from(key)\n .toString()\n .split('-')\n .map((k) => k.replaceAll('%2D', '-').replaceAll('%25', '%')),\n format: 'buffer',\n};\n\nexport const encodingOptions = {\n keyEncoding: keyEncoder,\n valueEncoding: 'buffer',\n};\n\nconst isLevelDbNotFoundError = (err: any): boolean => err.code === 'LEVEL_NOT_FOUND';\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey, type SpaceId } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport {\n type AutomergeReplicator,\n type AutomergeReplicatorFactory,\n} from '@dxos/teleport-extension-automerge-replicator';\nimport { ComplexSet, defaultMap } from '@dxos/util';\n\nimport { type EchoReplicator, type EchoReplicatorContext, type ShouldAdvertiseParams } from './echo-replicator';\nimport { MeshReplicatorConnection } from './mesh-echo-replicator-connection';\nimport { getSpaceIdFromCollectionId } from './space-collection';\nimport { createIdFromSpaceKey } from '../space';\n\n// TODO(dmaretskyi): Move out of @dxos/echo-pipeline.\n\n/**\n * Used to replicate with other peers over the network.\n */\nexport class MeshEchoReplicator implements EchoReplicator {\n private readonly _connections = new Set<MeshReplicatorConnection>();\n /**\n * Using automerge peerId as a key.\n */\n private readonly _connectionsPerPeer = new Map<string, MeshReplicatorConnection>();\n\n /**\n * spaceId -> deviceKey[]\n */\n private readonly _authorizedDevices = new Map<SpaceId, ComplexSet<PublicKey>>();\n\n private _context: EchoReplicatorContext | null = null;\n\n async connect(context: EchoReplicatorContext): Promise<void> {\n this._context = context;\n }\n\n async disconnect() {\n for (const connection of this._connectionsPerPeer.values()) {\n this._context?.onConnectionClosed(connection);\n }\n for (const connection of this._connections) {\n await connection.close();\n }\n this._connections.clear();\n this._connectionsPerPeer.clear();\n\n this._context = null;\n }\n\n createExtension(extensionFactory?: AutomergeReplicatorFactory): AutomergeReplicator {\n invariant(this._context);\n\n const connection: MeshReplicatorConnection = new MeshReplicatorConnection({\n ownPeerId: this._context.peerId,\n replicatorFactory: extensionFactory,\n onRemoteConnected: async () => {\n log('onRemoteConnected', { peerId: connection.peerId });\n invariant(this._context);\n\n if (this._connectionsPerPeer.has(connection.peerId)) {\n this._context.onConnectionAuthScopeChanged(connection);\n } else {\n this._connectionsPerPeer.set(connection.peerId, connection);\n this._context.onConnectionOpen(connection);\n connection.enable();\n }\n },\n onRemoteDisconnected: async () => {\n log('onRemoteDisconnected', { peerId: connection.peerId });\n this._context?.onConnectionClosed(connection);\n this._connectionsPerPeer.delete(connection.peerId);\n connection.disable();\n this._connections.delete(connection);\n },\n shouldAdvertise: async (params: ShouldAdvertiseParams) => {\n log('shouldAdvertise', { peerId: connection.peerId, documentId: params.documentId });\n invariant(this._context);\n try {\n const spaceKey = await this._context.getContainingSpaceForDocument(params.documentId);\n if (!spaceKey) {\n const remoteDocumentExists = await this._context.isDocumentInRemoteCollection({\n documentId: params.documentId,\n peerId: connection.peerId,\n });\n log('document not found locally for share policy check, accepting the remote document', {\n peerId: connection.peerId,\n documentId: params.documentId,\n remoteDocumentExists,\n });\n // If a document is not present locally return true if another peer claims to have it.\n // Simply returning true will add the peer to \"generous peers list\" for this document which will\n // start replication of the document after we receive, even if the peer is not in the corresponding space.\n return remoteDocumentExists;\n }\n\n const spaceId = await createIdFromSpaceKey(spaceKey);\n\n const authorizedDevices = this._authorizedDevices.get(spaceId);\n\n if (!connection.remoteDeviceKey) {\n log('device key not found for share policy check', {\n peerId: connection.peerId,\n documentId: params.documentId,\n });\n return false;\n }\n\n const isAuthorized = authorizedDevices?.has(connection.remoteDeviceKey) ?? false;\n log('share policy check', {\n localPeer: this._context.peerId,\n remotePeer: connection.peerId,\n documentId: params.documentId,\n deviceKey: connection.remoteDeviceKey,\n spaceKey,\n isAuthorized,\n });\n return isAuthorized;\n } catch (err) {\n log.catch(err);\n return false;\n }\n },\n shouldSyncCollection: ({ collectionId }) => {\n const spaceId = getSpaceIdFromCollectionId(collectionId);\n\n const authorizedDevices = this._authorizedDevices.get(spaceId);\n\n if (!connection.remoteDeviceKey) {\n log('device key not found for collection sync check', {\n peerId: connection.peerId,\n collectionId,\n });\n return false;\n }\n\n const isAuthorized = authorizedDevices?.has(connection.remoteDeviceKey) ?? false;\n return isAuthorized;\n },\n });\n this._connections.add(connection);\n\n return connection.replicatorExtension;\n }\n\n async authorizeDevice(spaceKey: PublicKey, deviceKey: PublicKey) {\n log('authorizeDevice', { spaceKey, deviceKey });\n const spaceId = await createIdFromSpaceKey(spaceKey);\n defaultMap(this._authorizedDevices, spaceId, () => new ComplexSet(PublicKey.hash)).add(deviceKey);\n for (const connection of this._connections) {\n if (connection.remoteDeviceKey && connection.remoteDeviceKey.equals(deviceKey)) {\n if (this._connectionsPerPeer.has(connection.peerId)) {\n this._context?.onConnectionAuthScopeChanged(connection);\n }\n }\n }\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport * as A from '@dxos/automerge/automerge';\nimport { cbor, type Message } from '@dxos/automerge/automerge-repo';\nimport { Resource } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { type PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { AutomergeReplicator, type AutomergeReplicatorFactory } from '@dxos/teleport-extension-automerge-replicator';\n\nimport type { ReplicatorConnection, ShouldAdvertiseParams, ShouldSyncCollectionParams } from './echo-replicator';\n\nconst DEFAULT_FACTORY: AutomergeReplicatorFactory = (params) => new AutomergeReplicator(...params);\n\nexport type MeshReplicatorConnectionParams = {\n ownPeerId: string;\n onRemoteConnected: () => void;\n onRemoteDisconnected: () => void;\n shouldAdvertise: (params: ShouldAdvertiseParams) => Promise<boolean>;\n shouldSyncCollection: (params: ShouldSyncCollectionParams) => boolean;\n replicatorFactory?: AutomergeReplicatorFactory;\n};\n\nexport class MeshReplicatorConnection extends Resource implements ReplicatorConnection {\n public readable: ReadableStream<Message>;\n public writable: WritableStream<Message>;\n public remoteDeviceKey: PublicKey | null = null;\n\n public readonly replicatorExtension: AutomergeReplicator;\n\n private _remotePeerId: string | null = null;\n private _isEnabled = false;\n\n constructor(private readonly _params: MeshReplicatorConnectionParams) {\n super();\n\n let readableStreamController!: ReadableStreamDefaultController<Message>;\n this.readable = new ReadableStream<Message>({\n start: (controller) => {\n readableStreamController = controller;\n this._ctx.onDispose(() => controller.close());\n },\n });\n\n this.writable = new WritableStream<Message>({\n write: async (message: Message, controller) => {\n invariant(this._isEnabled, 'Writing to a disabled connection');\n try {\n logSendSync(message);\n await this.replicatorExtension.sendSyncMessage({ payload: cbor.encode(message) });\n } catch (err) {\n controller.error(err);\n this._disconnectIfEnabled();\n }\n },\n });\n\n const createAutomergeReplicator = this._params.replicatorFactory ?? DEFAULT_FACTORY;\n this.replicatorExtension = createAutomergeReplicator([\n {\n peerId: this._params.ownPeerId,\n },\n {\n onStartReplication: async (info, remotePeerId /** Teleport ID */) => {\n // Note: We store only one extension per peer.\n // There can be a case where two connected peers have more than one teleport connection between them\n // and each of them uses different teleport connections to send messages.\n // It works because we receive messages from all teleport connections and Automerge Repo dedup them.\n // TODO(mykola): Use only one teleport connection per peer.\n\n // TODO(dmaretskyi): Critical bug.\n // - two peers get connected via swarm 1\n // - they get connected via swarm 2\n // - swarm 1 gets disconnected\n // - automerge repo thinks that peer 2 got disconnected even though swarm 2 is still active\n\n this.remoteDeviceKey = remotePeerId;\n\n // Set automerge id.\n this._remotePeerId = info.id;\n\n log('onStartReplication', { id: info.id, thisPeerId: this.peerId, remotePeerId: remotePeerId.toHex() });\n\n this._params.onRemoteConnected();\n },\n onSyncMessage: async ({ payload }) => {\n if (!this._isEnabled) {\n return;\n }\n const message = cbor.decode(payload) as Message;\n // Note: automerge Repo dedup messages.\n readableStreamController.enqueue(message);\n },\n onClose: async () => {\n this._disconnectIfEnabled();\n },\n },\n ]);\n }\n\n private _disconnectIfEnabled() {\n if (this._isEnabled) {\n this._params.onRemoteDisconnected();\n }\n }\n\n get peerId(): string {\n invariant(this._remotePeerId != null, 'Remote peer has not connected yet.');\n return this._remotePeerId;\n }\n\n async shouldAdvertise(params: ShouldAdvertiseParams): Promise<boolean> {\n return this._params.shouldAdvertise(params);\n }\n\n shouldSyncCollection(params: ShouldSyncCollectionParams): boolean {\n return this._params.shouldSyncCollection(params);\n }\n\n /**\n * Start exchanging messages with the remote peer.\n * Call after the remote peer has connected.\n */\n enable() {\n invariant(this._remotePeerId != null, 'Remote peer has not connected yet.');\n this._isEnabled = true;\n }\n\n /**\n * Stop exchanging messages with the remote peer.\n */\n disable() {\n this._isEnabled = false;\n }\n}\n\nconst logSendSync = (message: Message) => {\n log('sendSyncMessage', () => {\n const decodedSyncMessage = message.type === 'sync' && message.data ? A.decodeSyncMessage(message.data) : undefined;\n return {\n sync: decodedSyncMessage && {\n headsLength: decodedSyncMessage.heads.length,\n requesting: decodedSyncMessage.need.length > 0,\n sendingChanges: decodedSyncMessage.changes.length > 0,\n },\n type: message.type,\n from: message.senderId,\n to: message.targetId,\n };\n });\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { invariant } from '@dxos/invariant';\nimport { SpaceId } from '@dxos/keys';\n\nexport const deriveCollectionIdFromSpaceId = (spaceId: SpaceId): string => `space:${spaceId}`;\n\nexport const getSpaceIdFromCollectionId = (collectionId: string): SpaceId => {\n const spaceId = collectionId.replace(/^space:/, '');\n invariant(SpaceId.isValid(spaceId));\n return spaceId;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Message } from '@dxos/automerge/automerge-repo';\nimport { type TimeAware, trace } from '@dxos/tracing';\nimport { CircularBuffer, mapValues, SlidingWindowSummary, type SlidingWindowSummaryConfig } from '@dxos/util';\n\nimport { type NetworkDataMonitor } from './echo-network-adapter';\nimport { type StorageAdapterDataMonitor } from './leveldb-storage-adapter';\nimport { isCollectionQueryMessage, isCollectionStateMessage } from './network-protocol';\n\nconst PER_SECOND_RATE_AVG_WINDOW_SIZE = 5;\nconst DEFAULT_AVG_WINDOW_SIZE = 25;\n\nexport type EchoDataMonitorOptions = {\n timeSeriesLength: number;\n};\n\n@trace.resource()\nexport class EchoDataMonitor implements StorageAdapterDataMonitor, NetworkDataMonitor, TimeAware {\n private _lastTick = 0;\n\n private _activeCounters = createLocalCounters();\n private _lastCompleteCounters: LocalCounters | undefined;\n private readonly _localTimeSeries = createLocalTimeSeries();\n private readonly _storageAverages = createStorageAverages();\n private readonly _replicationAverages = createNetworkAverages();\n private readonly _sizeByMessageType: { [type: string]: SlidingWindowSummary } = {};\n private readonly _lastReceivedMessages = new CircularBuffer<StoredMessage>(100);\n private readonly _lastSentMessages = new CircularBuffer<StoredMessage>(100);\n\n private _connectionsCount = 0;\n\n constructor(private readonly _params: EchoDataMonitorOptions = { timeSeriesLength: 30 }) {}\n\n public tick(timeMs: number) {\n this._advanceTimeWindow(timeMs - this._lastTick);\n this._lastTick = timeMs;\n }\n\n public computeStats(): EchoDataStats {\n return {\n meta: {\n rateAverageOverSeconds: PER_SECOND_RATE_AVG_WINDOW_SIZE,\n },\n storage: {\n reads: {\n payloadSize: this._storageAverages.loadedChunkSize.average(),\n opDuration: this._storageAverages.loadDuration.average(),\n countPerSecond: this._storageAverages.loadsPerSecond.average(),\n },\n writes: {\n payloadSize: this._storageAverages.storedChunkSize.average(),\n opDuration: this._storageAverages.storeDuration.average(),\n countPerSecond: this._storageAverages.storesPerSecond.average(),\n },\n },\n replicator: {\n connections: this._connectionsCount,\n receivedMessages: {\n payloadSize: this._replicationAverages.receivedMessageSize.average(),\n countPerSecond: this._replicationAverages.receivedPerSecond.average(),\n },\n sentMessages: {\n payloadSize: this._replicationAverages.sentMessageSize.average(),\n opDuration: this._replicationAverages.sendDuration.average(),\n countPerSecond: this._replicationAverages.sentPerSecond.average(),\n failedPerSecond: this._replicationAverages.sendsFailedPerSecond.average(),\n },\n countByMessageType: this._computeMessageHistogram('type'),\n avgSizeByMessageType: mapValues(this._sizeByMessageType, (summary) => summary.average()),\n },\n };\n }\n\n public get connectionsCount() {\n return this._connectionsCount;\n }\n\n /**\n * @internal\n */\n get lastPerSecondStats() {\n return this._lastCompleteCounters;\n }\n\n /**\n * @internal\n */\n get timeSeries() {\n return { ...this._localTimeSeries.storage, ...this._localTimeSeries.replication };\n }\n\n /**\n * @internal\n */\n get messagesByPeerId() {\n return this._computeMessageHistogram('peerId');\n }\n\n private _advanceTimeWindow(millisPassed: number) {\n const oldMetrics = Object.freeze(this._activeCounters);\n this._activeCounters = createLocalCounters();\n this._lastCompleteCounters = oldMetrics;\n for (const peerId of Object.keys(oldMetrics.byPeerId)) {\n this._activeCounters.byPeerId[peerId] = createMessageCounter();\n }\n this._addToTimeSeries(oldMetrics.replication, this._localTimeSeries.replication);\n this._addToTimeSeries(oldMetrics.storage, this._localTimeSeries.storage);\n // Prevent skewed measurements of incomplete buckets / after CPU freezes.\n if (Math.abs(millisPassed - 1000) < 100) {\n this._reportPerSecondRate(oldMetrics);\n }\n }\n\n private _addToTimeSeries<T extends object>(values: T, timeSeries: TimeSeries<T>) {\n for (const [key, value] of Object.entries(values)) {\n const values: (typeof value)[] = (timeSeries as any)[key];\n values.push(value);\n if (values.length > this._params.timeSeriesLength) {\n values.shift();\n }\n }\n }\n\n private _reportPerSecondRate(metrics: LocalCounters) {\n const toReport: [string, number, SlidingWindowSummary][] = [\n ['storage.load', metrics.storage.loadedChunks, this._storageAverages.loadsPerSecond],\n ['storage.store', metrics.storage.storedChunks, this._storageAverages.storesPerSecond],\n ['network.receive', metrics.replication.received, this._replicationAverages.receivedPerSecond],\n ['network.send', metrics.replication.sent, this._replicationAverages.sentPerSecond],\n ];\n for (const [metricName, metric, summary] of toReport) {\n summary.record(metric);\n if (metric > 0) {\n trace.metrics.distribution(`dxos.echo.${metricName}-rate`, metric);\n trace.metrics.increment(`dxos.echo.${metricName}`, 1, { tags: { status: 'busy' } });\n } else {\n trace.metrics.increment(`dxos.echo.${metricName}`, 1, { tags: { status: 'idle' } });\n }\n }\n this._replicationAverages.sendsFailedPerSecond.record(metrics.replication.failed);\n }\n\n public recordPeerConnected(peerId: string) {\n this._activeCounters.byPeerId[peerId] = createMessageCounter();\n this._connectionsCount++;\n }\n\n public recordPeerDisconnected(peerId: string) {\n this._connectionsCount--;\n delete this._activeCounters.byPeerId[peerId];\n }\n\n public recordBytesStored(count: number) {\n this._activeCounters.storage.storedChunks++;\n this._activeCounters.storage.storedBytes += count;\n this._storageAverages.storedChunkSize.record(count);\n trace.metrics.distribution('dxos.echo.storage.bytes-stored', count, { unit: 'bytes' });\n }\n\n public recordLoadDuration(durationMs: number): void {\n this._storageAverages.loadDuration.record(durationMs);\n }\n\n public recordStoreDuration(durationMs: number): void {\n this._storageAverages.storeDuration.record(durationMs);\n }\n\n public recordBytesLoaded(count: number) {\n this._activeCounters.storage.loadedChunks++;\n this._activeCounters.storage.loadedBytes += count;\n this._storageAverages.loadedChunkSize.record(count);\n trace.metrics.distribution('dxos.echo.storage.bytes-loaded', count, { unit: 'bytes' });\n }\n\n public recordMessageSent(message: Message, duration: number) {\n let metricsGroupName;\n const bytes = getByteCount(message);\n const tags = { type: message.type };\n if (isAutomergeProtocolMessage(message)) {\n this._activeCounters.replication.sent++;\n this._replicationAverages.sendDuration.record(duration);\n this._replicationAverages.sentMessageSize.record(bytes);\n metricsGroupName = 'replication';\n } else {\n metricsGroupName = 'collection-sync';\n }\n trace.metrics.distribution(`dxos.echo.${metricsGroupName}.bytes-sent`, bytes, { unit: 'bytes', tags });\n trace.metrics.distribution(`dxos.echo.${metricsGroupName}.send-duration`, duration, { unit: 'millisecond', tags });\n trace.metrics.increment(`dxos.echo.${metricsGroupName}.send-status`, 1, { tags: { ...tags, success: true } });\n const { messageSize, messageCounts } = this._getStatsForType(message);\n messageSize.record(bytes);\n messageCounts.sent++;\n this._lastSentMessages.push({ type: message.type, peerId: message.targetId });\n }\n\n public recordMessageReceived(message: Message) {\n const bytes = getByteCount(message);\n const tags = { type: message.type };\n if (isAutomergeProtocolMessage(message)) {\n this._activeCounters.replication.received++;\n this._replicationAverages.receivedMessageSize.record(bytes);\n trace.metrics.distribution('dxos.echo.replication.bytes-received', bytes, { unit: 'bytes', tags });\n } else {\n trace.metrics.distribution('dxos.echo.collection-sync.bytes-received', bytes, { unit: 'bytes', tags });\n }\n const { messageSize, messageCounts } = this._getStatsForType(message);\n messageSize.record(bytes);\n messageCounts.received++;\n this._lastReceivedMessages.push({ type: message.type, peerId: message.senderId });\n }\n\n public recordMessageSendingFailed(message: Message) {\n const tags = { type: message.type, success: false };\n if (isAutomergeProtocolMessage(message)) {\n this._activeCounters.replication.failed++;\n trace.metrics.increment('dxos.echo.replication.send-status', 1, { unit: 'bytes', tags });\n } else {\n trace.metrics.increment('dxos.echo.collection-sync.send-status', 1, { unit: 'bytes', tags });\n }\n const { messageCounts } = this._getStatsForType(message);\n messageCounts.failed++;\n }\n\n private _getStatsForType(message: Message) {\n const messageSize = (this._sizeByMessageType[message.type] ??= createSlidingWindow());\n const messageCounts = (this._activeCounters.byType[message.type] ??= createMessageCounter());\n return { messageCounts, messageSize };\n }\n\n private _computeMessageHistogram(groupKey: keyof StoredMessage): MessageAttributeHistogram {\n const result: MessageAttributeHistogram = {};\n for (const receivedMessage of this._lastReceivedMessages) {\n const counters = (result[receivedMessage[groupKey]] ??= { received: 0, sent: 0 });\n counters.received++;\n }\n for (const receivedMessage of this._lastSentMessages) {\n const counters = (result[receivedMessage[groupKey]] ??= { received: 0, sent: 0 });\n counters.sent++;\n }\n return result;\n }\n}\n\ntype BaseDataOpStats = {\n payloadSize: number;\n countPerSecond: number;\n};\n\nexport type TimedDataOpStats = BaseDataOpStats & { opDuration: number };\n\ntype TimeSeries<T extends object> = { [key in keyof T]: T[key][] };\n\ntype StorageCounts = {\n storedChunks: number;\n storedBytes: number;\n loadedChunks: number;\n loadedBytes: number;\n};\ntype StorageCountTimeSeries = TimeSeries<StorageCounts>;\n\ntype MessageCounts = {\n sent: number;\n received: number;\n failed: number;\n};\ntype MessageCountTimeSeries = TimeSeries<MessageCounts>;\n\ntype MessageAttributeHistogram = {\n [messageType: string]: {\n received: number;\n sent: number;\n };\n};\n\nexport type EchoDataStats = {\n meta: {\n rateAverageOverSeconds: number;\n };\n storage: {\n reads: TimedDataOpStats;\n writes: TimedDataOpStats;\n };\n replicator: {\n connections: number;\n receivedMessages: BaseDataOpStats;\n sentMessages: TimedDataOpStats & { failedPerSecond: number };\n avgSizeByMessageType: { [messageType: string]: number };\n countByMessageType: MessageAttributeHistogram;\n };\n};\n\ntype StoredMessage = { type: string; peerId: string };\n\ntype StorageAverages = {\n storedChunkSize: SlidingWindowSummary;\n storesPerSecond: SlidingWindowSummary;\n loadedChunkSize: SlidingWindowSummary;\n loadsPerSecond: SlidingWindowSummary;\n loadDuration: SlidingWindowSummary;\n storeDuration: SlidingWindowSummary;\n};\n\ntype NetworkAverages = {\n receivedMessageSize: SlidingWindowSummary;\n receivedPerSecond: SlidingWindowSummary;\n sentMessageSize: SlidingWindowSummary;\n sentPerSecond: SlidingWindowSummary;\n sendDuration: SlidingWindowSummary;\n sendsFailedPerSecond: SlidingWindowSummary;\n};\n\ntype LocalCounters = {\n storage: StorageCounts;\n replication: MessageCounts;\n byPeerId: { [peerId: string]: MessageCounts };\n byType: { [type: string]: MessageCounts };\n};\n\ntype LocalTimeSeries = {\n storage: StorageCountTimeSeries;\n replication: MessageCountTimeSeries;\n};\n\nconst isAutomergeProtocolMessage = (message: Message) => {\n return !(isCollectionQueryMessage(message) || isCollectionStateMessage(message));\n};\n\nconst createSlidingWindow = (overrides?: SlidingWindowSummaryConfig) =>\n new SlidingWindowSummary({ dataPoints: DEFAULT_AVG_WINDOW_SIZE, precision: 2, ...overrides });\n\nconst createLocalCounters = (): LocalCounters => ({\n storage: { loadedBytes: 0, storedBytes: 0, storedChunks: 0, loadedChunks: 0 },\n replication: createMessageCounter(),\n byPeerId: {},\n byType: {},\n});\n\nconst createLocalTimeSeries = (): LocalTimeSeries => ({\n storage: { loadedBytes: [], storedBytes: [], storedChunks: [], loadedChunks: [] },\n replication: { sent: [], failed: [], received: [] },\n});\n\nconst createMessageCounter = (): MessageCounts => ({ sent: 0, received: 0, failed: 0 });\n\nconst createNetworkAverages = (): NetworkAverages => ({\n receivedMessageSize: createSlidingWindow(),\n sentMessageSize: createSlidingWindow(),\n sendDuration: createSlidingWindow(),\n receivedPerSecond: createSlidingWindow({ dataPoints: PER_SECOND_RATE_AVG_WINDOW_SIZE }),\n sentPerSecond: createSlidingWindow({ dataPoints: PER_SECOND_RATE_AVG_WINDOW_SIZE }),\n sendsFailedPerSecond: createSlidingWindow({ dataPoints: PER_SECOND_RATE_AVG_WINDOW_SIZE }),\n});\n\nconst createStorageAverages = (): StorageAverages => ({\n storedChunkSize: createSlidingWindow(),\n loadedChunkSize: createSlidingWindow(),\n loadDuration: createSlidingWindow(),\n storeDuration: createSlidingWindow(),\n loadsPerSecond: createSlidingWindow({ dataPoints: PER_SECOND_RATE_AVG_WINDOW_SIZE }),\n storesPerSecond: createSlidingWindow({ dataPoints: PER_SECOND_RATE_AVG_WINDOW_SIZE }),\n});\n\nconst getByteCount = (message: Message): number => {\n return (\n message.type.length +\n message.senderId.length +\n message.targetId.length +\n (message.data?.byteLength ?? 0) +\n (message.documentId?.length ?? 0)\n );\n};\n", "//\n// Copyright 2021 DXOS.org\n//\n\nimport CRC32 from 'crc-32';\n\nimport { Event, scheduleTaskInterval, synchronized } from '@dxos/async';\nimport { type Codec } from '@dxos/codec-protobuf';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { DataCorruptionError, STORAGE_VERSION, schema } from '@dxos/protocols';\nimport { Invitation, SpaceState } from '@dxos/protocols/proto/dxos/client/services';\nimport {\n type ControlPipelineSnapshot,\n type EchoMetadata,\n type SpaceMetadata,\n type IdentityRecord,\n type SpaceCache,\n type LargeSpaceMetadata,\n} from '@dxos/protocols/proto/dxos/echo/metadata';\nimport { type Directory, type File } from '@dxos/random-access-storage';\nimport { type Timeframe } from '@dxos/timeframe';\nimport { ComplexMap, arrayToBuffer, forEachAsync, isNotNullOrUndefined } from '@dxos/util';\n\nconst EXPIRED_INVITATION_CLEANUP_INTERVAL = 60 * 60 * 1000; // 1 hour\n\nexport interface AddSpaceOptions {\n key: PublicKey;\n genesisFeed: PublicKey;\n}\n\nconst emptyEchoMetadata = (): EchoMetadata => ({\n version: STORAGE_VERSION,\n spaces: [],\n created: new Date(),\n updated: new Date(),\n});\n\nconst emptyLargeSpaceMetadata = (): LargeSpaceMetadata => ({});\n\nconst EchoMetadata = schema.getCodecForType('dxos.echo.metadata.EchoMetadata');\nconst LargeSpaceMetadata = schema.getCodecForType('dxos.echo.metadata.LargeSpaceMetadata');\n\nexport class MetadataStore {\n private _metadata: EchoMetadata = emptyEchoMetadata();\n private _spaceLargeMetadata = new ComplexMap<PublicKey, LargeSpaceMetadata>(PublicKey.hash);\n\n private _metadataFile?: File = undefined;\n\n public readonly update = new Event<EchoMetadata>();\n private readonly _invitationCleanupCtx = new Context();\n\n /**\n * @internal\n */\n readonly _directory: Directory;\n\n constructor(directory: Directory) {\n this._directory = directory;\n }\n\n get metadata(): EchoMetadata {\n return this._metadata;\n }\n\n get version(): number {\n return this._metadata.version ?? 0;\n }\n\n /**\n * Returns a list of currently saved spaces. The list and objects in it can be modified addSpace and\n * addSpaceFeed functions.\n */\n get spaces(): SpaceMetadata[] {\n return this._metadata.spaces ?? [];\n }\n\n private async _readFile<T>(file: File, codec: Codec<T>): Promise<T | undefined> {\n try {\n const { size: fileLength } = await file.stat();\n if (fileLength < 8) {\n return;\n }\n // Loading file size from first 4 bytes.\n const dataSize = fromBytesInt32(await file.read(0, 4));\n const checksum = fromBytesInt32(await file.read(4, 4));\n log('loaded', { size: dataSize, checksum, name: file.filename });\n\n if (fileLength < dataSize + 8) {\n throw new DataCorruptionError('Metadata size is smaller than expected.', { fileLength, dataSize });\n }\n\n const data = await file.read(8, dataSize);\n\n const calculatedChecksum = CRC32.buf(data);\n if (calculatedChecksum !== checksum) {\n throw new DataCorruptionError('Metadata checksum is invalid.');\n }\n\n return codec.decode(data);\n } finally {\n await file.close();\n }\n }\n\n /**\n * @internal\n */\n async _writeFile<T>(file: File, codec: Codec<T>, data: T): Promise<void> {\n const encoded = arrayToBuffer(codec.encode(data));\n const checksum = CRC32.buf(encoded);\n\n const result = Buffer.alloc(8 + encoded.length);\n\n result.writeInt32LE(encoded.length, 0);\n result.writeInt32LE(checksum, 4);\n encoded.copy(result, 8);\n\n // NOTE: This must be done in one write operation, otherwise the file can be corrupted.\n await file.write(0, result);\n\n log('saved', { size: encoded.length, checksum });\n }\n\n async close() {\n await this._invitationCleanupCtx.dispose();\n await this.flush();\n await this._metadataFile?.close();\n this._metadataFile = undefined;\n this._metadata = emptyEchoMetadata();\n this._spaceLargeMetadata.clear();\n }\n\n /**\n * Loads metadata from persistent storage.\n */\n @synchronized\n async load(): Promise<void> {\n if (!this._metadataFile || this._metadataFile.closed) {\n this._metadataFile = this._directory.getOrCreateFile('EchoMetadata');\n }\n\n try {\n const metadata = await this._readFile(this._metadataFile, EchoMetadata);\n if (metadata) {\n this._metadata = metadata;\n }\n\n // post-processing\n this._metadata.spaces?.forEach((space) => {\n space.state ??= SpaceState.SPACE_ACTIVE;\n });\n } catch (err: any) {\n log.error('failed to load metadata', { err });\n this._metadata = emptyEchoMetadata();\n }\n\n await forEachAsync(\n [this._metadata.identity?.haloSpace.key, ...(this._metadata.spaces?.map((space) => space.key) ?? [])].filter(\n isNotNullOrUndefined,\n ),\n async (key) => {\n try {\n await this._loadSpaceLargeMetadata(key);\n } catch (err: any) {\n log.error('failed to load space large metadata', { err });\n }\n },\n );\n\n // Cleanup expired persistent invitations.\n scheduleTaskInterval(\n this._invitationCleanupCtx,\n async () => {\n for (const invitation of this._metadata.invitations ?? []) {\n if (hasInvitationExpired(invitation) || isLegacyInvitationFormat(invitation)) {\n await this.removeInvitation(invitation.invitationId);\n }\n }\n },\n EXPIRED_INVITATION_CLEANUP_INTERVAL,\n );\n }\n\n @synchronized\n private async _save(): Promise<void> {\n const data: EchoMetadata = {\n ...this._metadata,\n version: STORAGE_VERSION,\n created: this._metadata.created ?? new Date(),\n updated: new Date(),\n };\n this.update.emit(data);\n\n const file = this._directory.getOrCreateFile('EchoMetadata');\n\n await this._writeFile(file, EchoMetadata, data);\n }\n\n private async _loadSpaceLargeMetadata(key: PublicKey): Promise<void> {\n const file = this._directory.getOrCreateFile(`space_${key.toHex()}_large`);\n try {\n const metadata = await this._readFile(file, LargeSpaceMetadata);\n if (metadata) {\n this._spaceLargeMetadata.set(key, metadata);\n }\n } catch (err: any) {\n log.error('failed to load space large metadata', { err });\n }\n }\n\n @synchronized\n private async _saveSpaceLargeMetadata(key: PublicKey): Promise<void> {\n const data = this._getLargeSpaceMetadata(key);\n const file = this._directory.getOrCreateFile(`space_${key.toHex()}_large`);\n await this._writeFile(file, LargeSpaceMetadata, data);\n }\n\n async flush() {\n await this._directory.flush();\n }\n\n _getSpace(spaceKey: PublicKey): SpaceMetadata {\n if (this._metadata.identity?.haloSpace.key.equals(spaceKey)) {\n // Check if the space is the identity space.\n return this._metadata.identity.haloSpace;\n }\n\n const space = this.spaces.find((space) => space.key === spaceKey);\n invariant(space, 'Space not found');\n return space;\n }\n\n private _getLargeSpaceMetadata(key: PublicKey): LargeSpaceMetadata {\n let entry = this._spaceLargeMetadata.get(key);\n if (entry) {\n return entry;\n }\n\n entry = emptyLargeSpaceMetadata();\n this._spaceLargeMetadata.set(key, entry);\n return entry;\n }\n\n /**\n * Clears storage - doesn't work for now.\n */\n async clear(): Promise<void> {\n log('clearing all metadata');\n await this._directory.delete();\n this._metadata = emptyEchoMetadata();\n }\n\n getIdentityRecord(): IdentityRecord | undefined {\n return this._metadata.identity;\n }\n\n async setIdentityRecord(record: IdentityRecord) {\n invariant(!this._metadata.identity, 'Cannot overwrite existing identity in metadata');\n\n this._metadata.identity = record;\n await this._save();\n await this.flush();\n }\n\n getInvitations(): Invitation[] {\n return this._metadata.invitations ?? [];\n }\n\n async addInvitation(invitation: Invitation) {\n if (this._metadata.invitations?.find((i) => i.invitationId === invitation.invitationId)) {\n return;\n }\n\n (this._metadata.invitations ??= []).push(invitation);\n await this._save();\n await this.flush();\n }\n\n async removeInvitation(invitationId: string) {\n this._metadata.invitations = (this._metadata.invitations ?? []).filter((i) => i.invitationId !== invitationId);\n await this._save();\n await this.flush();\n }\n\n async addSpace(record: SpaceMetadata) {\n invariant(\n !(this._metadata.spaces ?? []).find((space) => space.key === record.key),\n 'Cannot overwrite existing space in metadata',\n );\n\n (this._metadata.spaces ??= []).push(record);\n await this._save();\n await this.flush();\n }\n\n async setSpaceDataLatestTimeframe(spaceKey: PublicKey, timeframe: Timeframe) {\n this._getSpace(spaceKey).dataTimeframe = timeframe;\n await this._save();\n }\n\n async setSpaceControlLatestTimeframe(spaceKey: PublicKey, timeframe: Timeframe) {\n this._getSpace(spaceKey).controlTimeframe = timeframe;\n await this._save();\n await this.flush();\n }\n\n async setCache(spaceKey: PublicKey, cache: SpaceCache) {\n this._getSpace(spaceKey).cache = cache;\n await this._save();\n }\n\n async setWritableFeedKeys(spaceKey: PublicKey, controlFeedKey: PublicKey, dataFeedKey: PublicKey) {\n const space = this._getSpace(spaceKey);\n space.controlFeedKey = controlFeedKey;\n space.dataFeedKey = dataFeedKey;\n await this._save();\n await this.flush();\n }\n\n async setSpaceState(spaceKey: PublicKey, state: SpaceState) {\n this._getSpace(spaceKey).state = state;\n await this._save();\n await this.flush();\n }\n\n getSpaceControlPipelineSnapshot(spaceKey: PublicKey): ControlPipelineSnapshot | undefined {\n return this._getLargeSpaceMetadata(spaceKey).controlPipelineSnapshot;\n }\n\n async setSpaceControlPipelineSnapshot(spaceKey: PublicKey, snapshot: ControlPipelineSnapshot) {\n this._getLargeSpaceMetadata(spaceKey).controlPipelineSnapshot = snapshot;\n await this._saveSpaceLargeMetadata(spaceKey);\n await this.flush();\n }\n}\n\nconst fromBytesInt32 = (buf: Buffer) => buf.readInt32LE(0);\n\nexport const hasInvitationExpired = (invitation: Invitation): boolean => {\n return Boolean(\n invitation.created &&\n invitation.lifetime &&\n invitation.lifetime !== 0 &&\n invitation.created.getTime() + invitation.lifetime * 1000 < Date.now(),\n );\n};\n\n// TODO: remove once \"multiuse\" type invitations get removed from local metadata of existing profiles\nconst isLegacyInvitationFormat = (invitation: Invitation): boolean => {\n return invitation.type === Invitation.Type.MULTIUSE;\n};\n"],
5
- "mappings": "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",
6
- "names": ["createCodecEncoding", "schema", "codec", "schema", "getCodecForType", "valueEncoding", "createCodecEncoding", "invariant", "createMappedFeedWriter", "mapper", "writer", "write", "data", "options", "cancelWithContext", "PublicKey", "schema", "BlobMeta", "SpaceSnapshot", "schema", "getCodecForType", "SnapshotManager", "constructor", "_snapshotStore", "_blobStore", "_blobSync", "_getBlob", "blobId", "blob", "get", "decode", "load", "ctx", "id", "PublicKey", "fromHex", "asUint8Array", "blobMeta", "getMeta", "state", "BlobMeta", "State", "FULLY_PRESENT", "fallbackStore", "cancelWithContext", "loadSnapshot", "download", "store", "snapshot", "set", "encode", "notifyBlobAdded", "from", "toHex", "subtleCrypto", "schema", "SpaceSnapshot", "schema", "getCodecForType", "SnapshotStore", "constructor", "_directory", "saveSnapshot", "snapshot", "encoded", "encode", "key", "subtleCrypto", "digest", "keyString", "Buffer", "from", "toString", "file", "getOrCreateFile", "write", "close", "loadSnapshot", "size", "stat", "undefined", "buffer", "read", "decode", "listSnapshots", "entries", "list", "Promise", "all", "map", "UpdateScheduler", "next", "A", "Resource", "invariant", "log", "MAX_UPDATE_FREQ", "DocumentsSynchronizer", "constructor", "_params", "_syncStates", "Map", "_pendingUpdates", "Set", "_sendUpdatesJob", "undefined", "addDocuments", "documentIds", "retryCounter", "warn", "documentId", "doc", "repo", "find", "whenReady", "then", "_startSync", "add", "trigger", "catch", "error", "removeDocuments", "get", "clearSubscriptions", "delete", "_open", "_ctx", "_checkAndSendUpdates", "bind", "maxFrequency", "_close", "join", "clear", "update", "updates", "mutation", "isNew", "loadIncremental", "_writeMutation", "has", "info", "syncState", "handle", "_subscribeForChanges", "set", "handler", "on", "off", "docsWithPendingUpdates", "Array", "from", "_getPendingChanges", "push", "length", "sendUpdates", "docSync", "lastSentHead", "saveSince", "save", "getHeads", "headsBefore", "newDoc", "equals", "asyncReturn", "Event", "scheduleTask", "scheduleTaskInterval", "next", "am", "Resource", "defaultMap", "MIN_QUERY_INTERVAL", "POLL_INTERVAL", "CollectionSynchronizer", "Resource", "constructor", "params", "_perCollectionStates", "Map", "_connectedPeers", "Set", "remoteStateUpdated", "Event", "_sendCollectionState", "sendCollectionState", "_queryCollectionState", "queryCollectionState", "_shouldSyncCollection", "shouldSyncCollection", "_open", "ctx", "scheduleTaskInterval", "_ctx", "collectionId", "keys", "refreshCollection", "asyncReturn", "getRegisteredCollectionIds", "getLocalCollectionState", "_getPerCollectionState", "localState", "setLocalCollectionState", "state", "queueMicrotask", "disposed", "_refreshInterestedPeers", "getRemoteCollectionStates", "remoteStates", "scheduleAnotherRefresh", "peerId", "interestedPeers", "has", "lastQueried", "get", "Date", "now", "set", "scheduleTask", "onConnectionOpen", "add", "entries", "onConnectionClosed", "delete", "perCollectionState", "values", "onCollectionStateQueried", "onRemoteStateReceived", "emit", "defaultMap", "undefined", "diffCollectionState", "local", "remote", "allDocuments", "Object", "documents", "different", "documentId", "am", "equals", "push", "runInContext", "scheduleTask", "Context", "randomBytes", "invariant", "log", "schema", "RpcExtension", "AuthExtension", "constructor", "_authParams", "requested", "AuthService", "getService", "exposed", "timeout", "_ctx", "onError", "err", "catch", "getHandlers", "authenticate", "challenge", "credential", "provider", "Error", "error", "onOpen", "context", "rpc", "length", "success", "verifier", "onAuthSuccess", "close", "onAuthFailure", "onClose", "dispose", "onAbort", "Event", "timed", "log", "Timeframe", "mapTimeframeToFeedIndexes", "timeframe", "frames", "map", "feedKey", "index", "mapFeedIndexesToTimeframe", "indexes", "startAfter", "TimeframeClock", "constructor", "_timeframe", "update", "_pendingTimeframe", "pendingTimeframe", "setTimeframe", "emit", "updatePendingTimeframe", "key", "seq", "merge", "updateTimeframe", "hasGaps", "gaps", "dependencies", "isEmpty", "waitUntilReached", "target", "current", "waitForCondition", "deps", "Event", "sleepWithContext", "synchronized", "Trigger", "Context", "rejectOnDispose", "failUndefined", "FeedSetIterator", "invariant", "PublicKey", "log", "Timeframe", "ComplexMap", "invariant", "log", "createMessageSelector", "timeframeClock", "messages", "i", "length", "data", "timeframe", "hasGaps", "PipelineState", "constructor", "_feeds", "_timeframeClock", "_ctx", "Context", "timeframeUpdate", "update", "stalled", "Event", "_startTimeframe", "Timeframe", "_reachedTarget", "endTimeframe", "mapFeedIndexesToTimeframe", "Array", "from", "values", "filter", "feed", "length", "map", "feedKey", "key", "index", "startTimeframe", "timeframe", "pendingTimeframe", "targetTimeframe", "_targetTimeframe", "reachedTarget", "feeds", "waitUntilTimeframe", "target", "waitUntilReached", "setTargetTimeframe", "waitUntilReachedTargetTimeframe", "ctx", "timeout", "breakOnStall", "log", "current", "_reachedTargetPromise", "Promise", "race", "waitForCondition", "dependencies", "isEmpty", "discardParameter", "waitForCount", "done", "rejectOnDispose", "then", "sleepWithContext", "warn", "Pipeline", "TimeframeClock", "ComplexMap", "PublicKey", "hash", "_state", "_processingTrigger", "Trigger", "wake", "_pauseTrigger", "_downloads", "value", "_isStopping", "_isStarted", "_isBeingConsumed", "_isPaused", "state", "writer", "invariant", "_writer", "hasFeed", "has", "getFeeds", "_feedSetIterator", "addFeed", "set", "_setFeedDownloadState", "setWriteFeed", "properties", "writable", "createMappedFeedWriter", "payload", "createFeedWriter", "start", "_initIterator", "open", "stop", "handle", "entries", "undownload", "clear", "close", "wait", "dispose", "undefined", "setCursor", "setTimeframe", "pause", "reset", "unpause", "consume", "lastFeedSetIterator", "iterable", "Symbol", "asyncIterator", "next", "block", "failUndefined", "updatePendingTimeframe", "seq", "updateTimeframe", "get", "truncate", "download", "linear", "err", "data", "info", "FeedSetIterator", "createMessageSelector", "startAfter", "stallTimeout", "on", "iterator", "options", "size", "emit", "synchronized", "Event", "scheduleMicroTask", "synchronized", "trackLeaks", "LifecycleState", "Resource", "subtleCrypto", "invariant", "PublicKey", "SpaceId", "log", "logInfo", "AdmittedFeed", "trace", "Callback", "ComplexMap", "DeferredTask", "sleepWithContext", "trackLeaks", "Context", "SpaceStateMachine", "PublicKey", "log", "AdmittedFeed", "Timeframe", "TimeSeriesCounter", "TimeUsageCounter", "trace", "Callback", "tracer", "TIMEFRAME_SAVE_DEBOUNCE_INTERVAL", "CONTROL_PIPELINE_SNAPSHOT_DELAY", "USE_SNAPSHOTS", "ControlPipeline", "constructor", "spaceKey", "genesisFeed", "feedProvider", "metadataStore", "_ctx", "Context", "_lastTimeframeSaveTime", "Date", "now", "onFeedAdmitted", "Callback", "_usage", "TimeUsageCounter", "_mutations", "TimeSeriesCounter", "_snapshotTask", "DeferredTask", "sleepWithContext", "_saveSnapshot", "_spaceKey", "_metadata", "_pipeline", "Pipeline", "addFeed", "_spaceStateMachine", "SpaceStateMachine", "set", "info", "log", "key", "assertion", "designation", "AdmittedFeed", "Designation", "CONTROL", "equals", "queueMicrotask", "feed", "hasFeed", "err", "catch", "callIfSet", "onMemberRoleChanged", "onCredentialProcessed", "onDelegatedInvitation", "onDelegatedInvitationRemoved", "spaceState", "pipeline", "setWriteFeed", "start", "snapshot", "getSpaceControlPipelineSnapshot", "present", "tf", "timeframe", "_processSnapshot", "setTimeout", "_consumePipeline", "setCursor", "message", "messages", "result", "process", "credential", "sourceFeed", "feedKey", "skipVerification", "warn", "pause", "state", "credentialEntries", "map", "entry", "unpause", "setSpaceControlPipelineSnapshot", "ctx", "msg", "consume", "span", "beginRecording", "inc", "_processMessage", "end", "seq", "data", "payload", "timer", "tracer", "mark", "PublicKey", "from", "_noteTargetStateIfNeeded", "pendingTimeframe", "schedule", "_saveTargetTimeframe", "stop", "dispose", "newTimeframe", "Timeframe", "merge", "_targetTimeframe", "setSpaceControlLatestTimeframe", "trace", "metricsCounter", "showInBrowserTimeline", "resource", "trackLeaks", "Space", "Resource", "constructor", "params", "onCredentialProcessed", "Callback", "stateUpdate", "Event", "invariant", "spaceKey", "feedProvider", "_id", "id", "_key", "_genesisFeedKey", "genesisFeed", "key", "_feedProvider", "_snapshotManager", "snapshotManager", "_controlPipeline", "ControlPipeline", "metadataStore", "onFeedAdmitted", "set", "info", "sparse", "assertion", "designation", "AdmittedFeed", "Designation", "DATA", "equals", "scheduleMicroTask", "_ctx", "protocol", "addFeed", "credential", "callIfSet", "log", "emit", "onDelegatedInvitation", "invitation", "onDelegatedInvitationStatusChange", "onDelegatedInvitationRemoved", "onMemberRoleChanged", "changedMembers", "map", "m", "role", "onMemberRolesChanged", "isOpen", "_lifecycleState", "LifecycleState", "OPEN", "genesisFeedKey", "controlFeedKey", "_controlFeed", "dataFeedKey", "_dataFeed", "spaceState", "controlPipeline", "pipeline", "setControlFeed", "feed", "setWriteFeed", "setDataFeed", "getControlFeeds", "Array", "from", "feeds", "values", "_open", "ctx", "start", "_close", "stop", "trace", "logInfo", "span", "synchronized", "trackLeaks", "resource", "SPACE_IDS_CACHE", "ComplexMap", "PublicKey", "hash", "createIdFromSpaceKey", "cachedValue", "get", "undefined", "digest", "subtleCrypto", "asUint8Array", "bytes", "Uint8Array", "slice", "SpaceId", "byteLength", "spaceId", "encode", "scheduleTask", "Context", "ProtocolError", "schema", "RpcExtension", "CredentialRetrieverExtension", "constructor", "_request", "_onResult", "requested", "AdmissionDiscoveryService", "getService", "_ctx", "getHandlers", "onOpen", "context", "result", "rpc", "getAdmissionCredential", "wake", "admissionCredential", "err", "close", "onClose", "dispose", "onAbort", "CredentialServerExtension", "_space", "exposed", "request", "memberInfo", "spaceState", "members", "get", "memberKey", "credential", "discoveryKey", "subtleCrypto", "PublicKey", "log", "logInfo", "MMSTTopology", "Teleport", "BlobSync", "ReplicatorExtension", "trace", "CallbackCollection", "ComplexMap", "MOCK_AUTH_PROVIDER", "nonce", "Buffer", "from", "MOCK_AUTH_VERIFIER", "credential", "SpaceProtocol", "constructor", "topic", "swarmIdentity", "networkManager", "onSessionAuth", "onAuthFailure", "blobStore", "disableP2pReplication", "_feeds", "Set", "_sessions", "ComplexMap", "PublicKey", "hash", "_topology", "MMSTTopology", "originateConnections", "maxPeers", "sampleSize", "feedAdded", "CallbackCollection", "_spaceKey", "_networkManager", "_swarmIdentity", "_onSessionAuth", "_onAuthFailure", "blobSync", "BlobSync", "_topic", "subtleCrypto", "digest", "asBuffer", "then", "discoveryKey", "_disableP2pReplication", "sessions", "feeds", "_ownPeerKey", "peerKey", "addFeed", "feed", "log", "key", "add", "session", "values", "replicator", "callSerial", "start", "_connection", "credentials", "credentialProvider", "open", "joinSwarm", "protocolProvider", "_createProtocolProvider", "peerId", "topology", "label", "truncate", "updateTopology", "forceUpdate", "stop", "close", "wireParams", "SpaceProtocolSession", "set", "remotePeerId", "logInfo", "trace", "info", "resource", "AuthStatus", "ReplicatorExtension", "setOptions", "upload", "_authStatus", "_wireParams", "_blobSync", "_teleport", "Teleport", "authStatus", "stats", "stream", "sessionId", "addExtension", "AuthExtension", "provider", "verifier", "credentialAuthenticator", "onAuthSuccess", "createExtension", "abort", "synchronized", "trackLeaks", "Trigger", "failUndefined", "PublicKey", "log", "trace", "ComplexMap", "Stream", "invariant", "SpaceId", "log", "Event", "asyncTimeout", "getBackend", "getHeads", "isAutomerge", "equals", "headsEquals", "save", "Repo", "Context", "Resource", "cancelWithContext", "invariant", "PublicKey", "log", "objectPointerCodec", "trace", "synchronized", "Trigger", "NetworkAdapter", "LifecycleState", "invariant", "log", "nonNullable", "MESSAGE_TYPE_COLLECTION_QUERY", "MESSAGE_TYPE_COLLECTION_STATE", "isCollectionQueryMessage", "message", "type", "MESSAGE_TYPE_COLLECTION_QUERY", "isCollectionStateMessage", "MESSAGE_TYPE_COLLECTION_STATE", "EchoNetworkAdapter", "NetworkAdapter", "constructor", "_params", "_replicators", "Set", "_connections", "Map", "_lifecycleState", "LifecycleState", "CLOSED", "_connected", "Trigger", "connect", "peerId", "peerMetadata", "wake", "send", "message", "_send", "disconnect", "open", "OPEN", "log", "emit", "network", "close", "replicator", "clear", "whenConnected", "wait", "timeout", "addReplicator", "invariant", "has", "add", "onConnectionOpen", "_onConnectionOpen", "bind", "onConnectionClosed", "_onConnectionClosed", "onConnectionAuthScopeChanged", "_onConnectionAuthScopeChanged", "isDocumentInRemoteCollection", "getContainingSpaceForDocument", "getContainingSpaceIdForDocument", "documentId", "key", "createIdFromSpaceKey", "removeReplicator", "delete", "shouldAdvertise", "params", "connection", "get", "shouldSyncCollection", "queryCollectionState", "collectionId", "targetId", "type", "senderId", "sendCollectionState", "state", "connectionEntry", "Error", "writeStart", "Date", "now", "writer", "write", "then", "durationMs", "monitor", "recordMessageSent", "catch", "err", "isOpen", "recordMessageSendingFailed", "getPeersInterestedInCollection", "Array", "from", "values", "map", "filter", "nonNullable", "reader", "readable", "getReader", "writable", "getWriter", "set", "queueMicrotask", "done", "value", "read", "_onMessage", "_emitPeerCandidate", "recordPeerConnected", "isCollectionQueryMessage", "onCollectionStateQueried", "isCollectionStateMessage", "onCollectionStateReceived", "recordMessageReceived", "entry", "recordPeerDisconnected", "cancel", "abort", "createEchoPeerMetadata", "synchronized", "dxos_peerSource", "isEchoPeerMetadata", "metadata", "headsEncoding", "HeadsStore", "constructor", "db", "_db", "setHeads", "documentId", "heads", "batch", "put", "sublevel", "keyEncoding", "valueEncoding", "headsEncoding", "getHeads", "documentIds", "getMany", "LifecycleState", "Resource", "LevelDBStorageAdapter", "Resource", "constructor", "_params", "load", "keyArray", "_lifecycleState", "LifecycleState", "OPEN", "undefined", "startMs", "Date", "now", "chunk", "db", "get", "encodingOptions", "monitor", "recordBytesLoaded", "byteLength", "recordLoadDuration", "err", "isLevelDbNotFoundError", "save", "binary", "batch", "callbacks", "beforeSave", "path", "put", "Buffer", "from", "write", "recordBytesStored", "afterSave", "recordStoreDuration", "remove", "del", "loadRange", "keyPrefix", "result", "key", "value", "iterator", "gte", "lte", "push", "data", "removeRange", "keyEncoder", "encode", "map", "k", "replaceAll", "join", "decode", "toString", "split", "format", "keyEncoding", "valueEncoding", "code", "AutomergeHost", "Resource", "constructor", "db", "indexMetadataStore", "dataMonitor", "_collectionSynchronizer", "CollectionSynchronizer", "queryCollectionState", "_queryCollectionState", "bind", "sendCollectionState", "_sendCollectionState", "shouldSyncCollection", "_shouldSyncCollection", "_db", "_storage", "LevelDBStorageAdapter", "sublevel", "callbacks", "beforeSave", "params", "_beforeSave", "afterSave", "key", "_afterSave", "monitor", "_echoNetworkAdapter", "EchoNetworkAdapter", "getContainingSpaceForDocument", "_getContainingSpaceForDocument", "isDocumentInRemoteCollection", "_isDocumentInRemoteCollection", "onCollectionStateQueried", "_onCollectionStateQueried", "onCollectionStateReceived", "_onCollectionStateReceived", "_headsStore", "HeadsStore", "_indexMetadataStore", "_open", "_peerId", "PublicKey", "random", "toHex", "open", "_repo", "Repo", "peerId", "sharePolicy", "_sharePolicy", "storage", "network", "Event", "wrap", "on", "_ctx", "e", "_onPeerConnected", "_onPeerDisconnected", "remoteStateUpdated", "collectionId", "_onRemoteCollectionStateUpdated", "whenConnected", "_close", "close", "dispose", "repo", "loadedDocsCount", "Object", "keys", "handles", "length", "addReplicator", "replicator", "removeReplicator", "loadDoc", "ctx", "documentId", "opts", "handle", "find", "isReady", "timeout", "cancelWithContext", "whenReady", "asyncTimeout", "createDoc", "initialValue", "preserveHistory", "isAutomerge", "TypeError", "import", "save", "create", "waitUntilHeadsReplicated", "heads", "entries", "documentIds", "map", "entry", "documentHeads", "getHeads", "headsToWait", "filter", "index", "targetHeads", "currentHeads", "headsEquals", "Promise", "all", "Context", "default", "waitForHeads", "flush", "reIndexHeads", "log", "info", "inState", "warn", "doc", "docSync", "invariant", "batch", "setHeads", "write", "startsWith", "peerMetadata", "peerMetadataByPeerId", "isEchoPeerMetadata", "shouldAdvertise", "path", "spaceKey", "getSpaceKeyFromDoc", "undefined", "objectIds", "objects", "encodedIds", "objectId", "objectPointerCodec", "encode", "idToLastHash", "Map", "id", "markDirty", "notifyMarkedDirty", "document", "_onHeadsChanged", "_automergePeers", "peers", "getRegisteredCollectionIds", "remoteCollections", "getRemoteCollectionStates", "remotePeerDocs", "get", "documents", "spaceKeyHex", "from", "result", "storeRequestIds", "storeResultIndices", "push", "storedHeads", "i", "getLocalCollectionState", "refreshCollection", "getCollectionSyncState", "localState", "remoteState", "state", "diff", "diffCollectionState", "differentDocuments", "different", "updateLocalCollectionState", "fromEntries", "setLocalCollectionState", "onRemoteStateReceived", "decodeCollectionState", "encodeCollectionState", "onConnectionOpen", "onConnectionClosed", "count", "newState", "structuredClone", "trace", "depth", "span", "showInBrowserTimeline", "resource", "rawSpaceKey", "access", "experimental_spaceKey", "String", "unavailableHeads", "Set", "waitForCondition", "changeHash", "values", "changeIsPresentInDoc", "delete", "size", "getBackend", "getChangeByHash", "invariant", "PublicKey", "log", "ComplexSet", "defaultMap", "A", "cbor", "Resource", "invariant", "log", "AutomergeReplicator", "DEFAULT_FACTORY", "params", "MeshReplicatorConnection", "constructor", "_params", "remoteDeviceKey", "_remotePeerId", "_isEnabled", "readableStreamController", "readable", "ReadableStream", "start", "controller", "_ctx", "onDispose", "close", "writable", "WritableStream", "write", "message", "logSendSync", "replicatorExtension", "sendSyncMessage", "payload", "encode", "err", "error", "_disconnectIfEnabled", "createAutomergeReplicator", "replicatorFactory", "peerId", "ownPeerId", "onStartReplication", "info", "remotePeerId", "id", "thisPeerId", "toHex", "onRemoteConnected", "onSyncMessage", "decode", "enqueue", "onClose", "onRemoteDisconnected", "shouldAdvertise", "shouldSyncCollection", "enable", "disable", "decodedSyncMessage", "type", "data", "decodeSyncMessage", "undefined", "sync", "headsLength", "heads", "length", "requesting", "need", "sendingChanges", "changes", "from", "senderId", "to", "targetId", "invariant", "SpaceId", "deriveCollectionIdFromSpaceId", "spaceId", "getSpaceIdFromCollectionId", "collectionId", "replace", "isValid", "MeshEchoReplicator", "_connections", "Set", "_connectionsPerPeer", "Map", "_authorizedDevices", "_context", "connect", "context", "disconnect", "connection", "values", "onConnectionClosed", "close", "clear", "createExtension", "extensionFactory", "invariant", "MeshReplicatorConnection", "ownPeerId", "peerId", "replicatorFactory", "onRemoteConnected", "log", "has", "onConnectionAuthScopeChanged", "set", "onConnectionOpen", "enable", "onRemoteDisconnected", "delete", "disable", "shouldAdvertise", "params", "documentId", "spaceKey", "getContainingSpaceForDocument", "remoteDocumentExists", "isDocumentInRemoteCollection", "spaceId", "createIdFromSpaceKey", "authorizedDevices", "get", "remoteDeviceKey", "isAuthorized", "localPeer", "remotePeer", "deviceKey", "err", "catch", "shouldSyncCollection", "collectionId", "getSpaceIdFromCollectionId", "add", "replicatorExtension", "authorizeDevice", "defaultMap", "ComplexSet", "PublicKey", "hash", "equals", "trace", "CircularBuffer", "mapValues", "SlidingWindowSummary", "PER_SECOND_RATE_AVG_WINDOW_SIZE", "DEFAULT_AVG_WINDOW_SIZE", "EchoDataMonitor", "constructor", "_params", "timeSeriesLength", "_lastTick", "_activeCounters", "createLocalCounters", "_localTimeSeries", "createLocalTimeSeries", "_storageAverages", "createStorageAverages", "_replicationAverages", "createNetworkAverages", "_sizeByMessageType", "_lastReceivedMessages", "CircularBuffer", "_lastSentMessages", "_connectionsCount", "tick", "timeMs", "_advanceTimeWindow", "computeStats", "meta", "rateAverageOverSeconds", "storage", "reads", "payloadSize", "loadedChunkSize", "average", "opDuration", "loadDuration", "countPerSecond", "loadsPerSecond", "writes", "storedChunkSize", "storeDuration", "storesPerSecond", "replicator", "connections", "receivedMessages", "receivedMessageSize", "receivedPerSecond", "sentMessages", "sentMessageSize", "sendDuration", "sentPerSecond", "failedPerSecond", "sendsFailedPerSecond", "countByMessageType", "_computeMessageHistogram", "avgSizeByMessageType", "mapValues", "summary", "connectionsCount", "lastPerSecondStats", "_lastCompleteCounters", "timeSeries", "replication", "messagesByPeerId", "millisPassed", "oldMetrics", "Object", "freeze", "peerId", "keys", "byPeerId", "createMessageCounter", "_addToTimeSeries", "Math", "abs", "_reportPerSecondRate", "values", "key", "value", "entries", "push", "length", "shift", "metrics", "toReport", "loadedChunks", "storedChunks", "received", "sent", "metricName", "metric", "record", "trace", "distribution", "increment", "tags", "status", "failed", "recordPeerConnected", "recordPeerDisconnected", "recordBytesStored", "count", "storedBytes", "unit", "recordLoadDuration", "durationMs", "recordStoreDuration", "recordBytesLoaded", "loadedBytes", "recordMessageSent", "message", "duration", "metricsGroupName", "bytes", "getByteCount", "type", "isAutomergeProtocolMessage", "success", "messageSize", "messageCounts", "_getStatsForType", "targetId", "recordMessageReceived", "senderId", "recordMessageSendingFailed", "createSlidingWindow", "byType", "groupKey", "result", "receivedMessage", "counters", "resource", "isCollectionQueryMessage", "isCollectionStateMessage", "overrides", "SlidingWindowSummary", "dataPoints", "precision", "data", "byteLength", "documentId", "DataServiceImpl", "constructor", "params", "_subscriptions", "Map", "_automergeHost", "automergeHost", "_updateIndexes", "updateIndexes", "subscribe", "request", "Stream", "next", "ready", "synchronizer", "DocumentsSynchronizer", "repo", "sendUpdates", "updates", "open", "then", "set", "subscriptionId", "catch", "err", "log", "close", "updateSubscription", "get", "invariant", "addIds", "length", "addDocuments", "removeIds", "removeDocuments", "update", "flush", "getDocumentHeads", "documentIds", "heads", "entries", "getHeads", "map", "idx", "documentId", "waitUntilHeadsReplicated", "options", "reIndexHeads", "getSpaceSyncState", "SpaceId", "isValid", "spaceId", "collectionId", "deriveCollectionIdFromSpaceId", "state", "getCollectionSyncState", "peers", "peer", "peerId", "documentsToReconcile", "differentDocuments", "SpaceManager", "constructor", "feedStore", "networkManager", "metadataStore", "snapshotStore", "blobStore", "disableP2pReplication", "_spaces", "ComplexMap", "PublicKey", "hash", "_instanceId", "random", "toHex", "_feedStore", "_networkManager", "_metadataStore", "_snapshotStore", "_blobStore", "_disableP2pReplication", "spaces", "open", "close", "Promise", "all", "values", "map", "space", "constructSpace", "metadata", "swarmIdentity", "onAuthorizedConnection", "onAuthFailure", "onDelegatedInvitationStatusChange", "onMemberRolesChanged", "memberKey", "log", "trace", "begin", "id", "spaceKey", "genesisFeedKey", "genesisFeed", "openFeed", "failUndefined", "key", "spaceId", "createIdFromSpaceKey", "protocol", "SpaceProtocol", "topic", "onSessionAuth", "snapshotManager", "SnapshotManager", "blobSync", "Space", "feedProvider", "feedKey", "opts", "set", "end", "requestSpaceAdmissionCredential", "params", "traceKey", "onCredentialResolved", "Trigger", "session", "addExtension", "CredentialRetrieverExtension", "identityKey", "start", "credential", "wait", "timeout", "err", "error", "stop", "synchronized", "trackLeaks", "CRC32", "Event", "scheduleTaskInterval", "synchronized", "Context", "invariant", "PublicKey", "log", "DataCorruptionError", "STORAGE_VERSION", "schema", "Invitation", "SpaceState", "ComplexMap", "arrayToBuffer", "forEachAsync", "isNotNullOrUndefined", "EXPIRED_INVITATION_CLEANUP_INTERVAL", "emptyEchoMetadata", "version", "spaces", "created", "Date", "updated", "emptyLargeSpaceMetadata", "EchoMetadata", "getCodecForType", "LargeSpaceMetadata", "MetadataStore", "constructor", "directory", "_metadata", "_spaceLargeMetadata", "hash", "_metadataFile", "undefined", "update", "_invitationCleanupCtx", "_directory", "metadata", "_readFile", "file", "codec", "size", "fileLength", "stat", "dataSize", "fromBytesInt32", "read", "checksum", "name", "filename", "data", "calculatedChecksum", "buf", "decode", "close", "_writeFile", "encoded", "encode", "result", "Buffer", "alloc", "length", "writeInt32LE", "copy", "write", "dispose", "flush", "clear", "load", "closed", "getOrCreateFile", "forEach", "space", "state", "SPACE_ACTIVE", "err", "error", "identity", "haloSpace", "key", "map", "filter", "_loadSpaceLargeMetadata", "invitation", "invitations", "hasInvitationExpired", "isLegacyInvitationFormat", "removeInvitation", "invitationId", "_save", "emit", "toHex", "set", "_saveSpaceLargeMetadata", "_getLargeSpaceMetadata", "_getSpace", "spaceKey", "equals", "find", "entry", "get", "delete", "getIdentityRecord", "setIdentityRecord", "record", "getInvitations", "addInvitation", "i", "push", "addSpace", "setSpaceDataLatestTimeframe", "timeframe", "dataTimeframe", "setSpaceControlLatestTimeframe", "controlTimeframe", "setCache", "cache", "setWritableFeedKeys", "controlFeedKey", "dataFeedKey", "setSpaceState", "getSpaceControlPipelineSnapshot", "controlPipelineSnapshot", "setSpaceControlPipelineSnapshot", "snapshot", "readInt32LE", "Boolean", "lifetime", "getTime", "now", "type", "Type", "MULTIUSE"]
7
- }