@dxos/echo-pipeline 0.4.10-main.d4e372f → 0.4.10-main.d51f2c2

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 (60) hide show
  1. package/dist/lib/browser/{chunk-RTEEJ723.mjs → chunk-SYE4EK33.mjs} +30 -35
  2. package/dist/lib/browser/chunk-SYE4EK33.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +279 -159
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +8 -2
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  8. package/dist/lib/node/{chunk-7VZVCCNF.cjs → chunk-WCTX6RNS.cjs} +35 -40
  9. package/dist/lib/node/chunk-WCTX6RNS.cjs.map +7 -0
  10. package/dist/lib/node/index.cjs +285 -168
  11. package/dist/lib/node/index.cjs.map +4 -4
  12. package/dist/lib/node/meta.json +1 -1
  13. package/dist/lib/node/testing/index.cjs +18 -13
  14. package/dist/lib/node/testing/index.cjs.map +4 -4
  15. package/dist/types/src/automerge/automerge-doc-loader.d.ts +2 -0
  16. package/dist/types/src/automerge/automerge-doc-loader.d.ts.map +1 -1
  17. package/dist/types/src/automerge/automerge-host.d.ts +20 -10
  18. package/dist/types/src/automerge/automerge-host.d.ts.map +1 -1
  19. package/dist/types/src/automerge/index.d.ts +1 -0
  20. package/dist/types/src/automerge/index.d.ts.map +1 -1
  21. package/dist/types/src/automerge/level.test.d.ts +2 -0
  22. package/dist/types/src/automerge/level.test.d.ts.map +1 -0
  23. package/dist/types/src/automerge/leveldb-storage-adapter.d.ts +27 -0
  24. package/dist/types/src/automerge/leveldb-storage-adapter.d.ts.map +1 -0
  25. package/dist/types/src/automerge/migrations.d.ts +7 -0
  26. package/dist/types/src/automerge/migrations.d.ts.map +1 -0
  27. package/dist/types/src/automerge/reference.d.ts +15 -0
  28. package/dist/types/src/automerge/reference.d.ts.map +1 -0
  29. package/dist/types/src/automerge/storage-adapter.test.d.ts +2 -0
  30. package/dist/types/src/automerge/storage-adapter.test.d.ts.map +1 -0
  31. package/dist/types/src/automerge/types.d.ts +7 -2
  32. package/dist/types/src/automerge/types.d.ts.map +1 -1
  33. package/dist/types/src/metadata/metadata-store.d.ts +2 -1
  34. package/dist/types/src/metadata/metadata-store.d.ts.map +1 -1
  35. package/dist/types/src/space/space.d.ts +4 -8
  36. package/dist/types/src/space/space.d.ts.map +1 -1
  37. package/dist/types/src/testing/index.d.ts +1 -0
  38. package/dist/types/src/testing/index.d.ts.map +1 -1
  39. package/dist/types/src/testing/level.d.ts +3 -0
  40. package/dist/types/src/testing/level.d.ts.map +1 -0
  41. package/dist/types/src/testing/test-agent-builder.d.ts +2 -2
  42. package/package.json +33 -30
  43. package/src/automerge/automerge-doc-loader.ts +6 -0
  44. package/src/automerge/automerge-host.test.ts +19 -5
  45. package/src/automerge/automerge-host.ts +52 -33
  46. package/src/automerge/index.ts +1 -0
  47. package/src/automerge/level.test.ts +43 -0
  48. package/src/automerge/leveldb-storage-adapter.ts +105 -0
  49. package/src/automerge/migrations.ts +41 -0
  50. package/src/automerge/reference.ts +31 -0
  51. package/src/automerge/storage-adapter.test.ts +90 -0
  52. package/src/automerge/types.ts +7 -5
  53. package/src/db-host/data-service.ts +1 -1
  54. package/src/metadata/metadata-store.ts +17 -8
  55. package/src/space/space.test.ts +7 -7
  56. package/src/space/space.ts +6 -21
  57. package/src/testing/index.ts +1 -0
  58. package/src/testing/level.ts +11 -0
  59. package/dist/lib/browser/chunk-RTEEJ723.mjs.map +0 -7
  60. package/dist/lib/node/chunk-7VZVCCNF.cjs.map +0 -7
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../../src/testing/change-metadata.ts", "../../../../src/testing/test-agent-builder.ts", "../../../../src/testing/test-feed-builder.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { log } from '@dxos/log';\nimport { schema } from '@dxos/protocols';\nimport type { Storage } from '@dxos/random-access-storage';\n\nimport { MetadataStore } from '../metadata';\n\nconst EchoMetadata = schema.getCodecForType('dxos.echo.metadata.EchoMetadata');\n\n/**\n * This function will change the storage version in the metadata.\n * This will break your storage and make it unusable.\n * Use this only for testing purposes.\n */\nexport const changeStorageVersionInMetadata = async (storage: Storage, version: number) => {\n log.info('Changing storage version in metadata. USE ONLY FOR TESTING.');\n const metadata = new MetadataStore(storage.createDirectory('metadata'));\n await metadata.load();\n const echoMetadata = metadata.metadata;\n echoMetadata.version = version;\n const file = metadata._directory.getOrCreateFile('EchoMetadata');\n await metadata._writeFile(file, EchoMetadata, echoMetadata);\n await metadata._directory.flush();\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Context } from '@dxos/context';\nimport { CredentialGenerator } from '@dxos/credentials';\nimport { type FeedStore } from '@dxos/feed-store';\nimport { type Keyring } from '@dxos/keyring';\nimport { PublicKey } from '@dxos/keys';\nimport { MemorySignalManager, MemorySignalManagerContext, WebsocketSignalManager } from '@dxos/messaging';\nimport { MemoryTransportFactory, NetworkManager, createSimplePeerTransportFactory } from '@dxos/network-manager';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type SpaceMetadata } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport { AdmittedFeed } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { StorageType, createStorage, type Storage } from '@dxos/random-access-storage';\nimport { Gossip, Presence } from '@dxos/teleport-extension-gossip';\nimport { BlobStore } from '@dxos/teleport-extension-object-sync';\nimport { ComplexMap } from '@dxos/util';\n\nimport { TestFeedBuilder } from './test-feed-builder';\nimport { SnapshotStore } from '../db-host';\nimport { MetadataStore } from '../metadata';\nimport { MOCK_AUTH_PROVIDER, MOCK_AUTH_VERIFIER, SpaceManager, SpaceProtocol, type Space } from '../space';\n\nexport type NetworkManagerProvider = () => NetworkManager;\n\nexport const MemoryNetworkManagerProvider =\n (signalContext: MemorySignalManagerContext): NetworkManagerProvider =>\n () =>\n new NetworkManager({\n signalManager: new MemorySignalManager(signalContext),\n transportFactory: MemoryTransportFactory,\n });\n\nexport const WebsocketNetworkManagerProvider =\n (signalUrl: string): NetworkManagerProvider =>\n () =>\n new NetworkManager({\n signalManager: new WebsocketSignalManager([{ server: signalUrl }]),\n transportFactory: createSimplePeerTransportFactory(),\n });\n\nexport type TestAgentBuilderOptions = {\n storage?: Storage;\n networkManagerProvider?: NetworkManagerProvider;\n};\n\n/**\n * Factory for test agents.\n */\nexport class TestAgentBuilder {\n private readonly _agents = new ComplexMap<PublicKey, TestAgent>(PublicKey.hash);\n private readonly _storage: Storage;\n private readonly _networkManagerProvider: NetworkManagerProvider;\n\n constructor({ storage, networkManagerProvider }: TestAgentBuilderOptions = {}) {\n this._storage = storage ?? createStorage({ type: StorageType.RAM });\n this._networkManagerProvider =\n networkManagerProvider ?? MemoryNetworkManagerProvider(new MemorySignalManagerContext());\n }\n\n async close() {\n return Promise.all(this.agents.map((agent) => agent.close()));\n }\n\n get agents() {\n return Array.from(this._agents.values());\n }\n\n getAgent(deviceKey: PublicKey) {\n return this._agents.get(deviceKey);\n }\n\n async createPeer(): Promise<TestAgent> {\n // prettier-ignore\n const feedBuilder = new TestFeedBuilder()\n .setStorage(this._storage, `agent-${this._agents.size}`);\n\n const identityKey = await feedBuilder.keyring.createKey();\n const deviceKey = await feedBuilder.keyring.createKey();\n\n const agent = new TestAgent(this._networkManagerProvider, feedBuilder, identityKey, deviceKey);\n this._agents.set(deviceKey, agent);\n return agent;\n }\n}\n\n/**\n * Test agent that enables the creation and replication of multiple spaces.\n */\nexport class TestAgent {\n private readonly _spaces = new ComplexMap<PublicKey, Space>(PublicKey.hash);\n\n public readonly storage: Storage;\n public readonly keyring: Keyring;\n public readonly feedStore: FeedStore<FeedMessage>;\n\n private _metadataStore?: MetadataStore;\n get metadataStore() {\n return (this._metadataStore ??= new MetadataStore(this.storage.createDirectory('metadata')));\n }\n\n private _snapshotStore?: SnapshotStore;\n get snapshotStore() {\n return (this._snapshotStore ??= new SnapshotStore(this.storage.createDirectory('snapshots')));\n }\n\n private _blobStore?: BlobStore;\n get blobStore() {\n return (this._blobStore ??= new BlobStore(this.storage.createDirectory('blobs')));\n }\n\n constructor(\n private readonly _networkManagerProvider: NetworkManagerProvider,\n private readonly _feedBuilder: TestFeedBuilder,\n public readonly identityKey: PublicKey,\n public readonly deviceKey: PublicKey,\n ) {\n this.storage = this._feedBuilder.storage;\n this.keyring = this._feedBuilder.keyring;\n this.feedStore = this._feedBuilder.createFeedStore();\n }\n\n async close() {\n return Promise.all([...this.spaces.map((space) => space.close())]);\n }\n\n get spaces() {\n return Array.from(this._spaces.values());\n }\n\n getSpace(spaceKey: PublicKey) {\n return this._spaces.get(spaceKey);\n }\n\n private _spaceManager?: SpaceManager;\n get spaceManager() {\n return (this._spaceManager ??= new SpaceManager({\n feedStore: this.feedStore,\n networkManager: this._networkManagerProvider(),\n metadataStore: this.metadataStore,\n snapshotStore: this.snapshotStore,\n blobStore: this.blobStore,\n }));\n }\n\n async createSpace(\n identityKey: PublicKey = this.identityKey,\n spaceKey?: PublicKey,\n genesisKey?: PublicKey,\n dataKey?: PublicKey,\n saveMetadata = false,\n ): Promise<Space> {\n if (!spaceKey) {\n saveMetadata = true;\n spaceKey = await this.keyring.createKey();\n }\n if (!genesisKey) {\n genesisKey = await this.keyring.createKey();\n }\n\n const controlFeed = await this.feedStore.openFeed(genesisKey, { writable: true });\n const dataFeed = await this.feedStore.openFeed(dataKey ?? (await this.keyring.createKey()), {\n writable: true,\n sparse: true,\n });\n\n const metadata: SpaceMetadata = {\n key: spaceKey,\n genesisFeedKey: genesisKey,\n controlFeedKey: controlFeed.key,\n dataFeedKey: dataFeed.key,\n };\n if (saveMetadata) {\n await this.metadataStore.addSpace(metadata);\n }\n\n await this.spaceManager.open();\n const space = await this.spaceManager.constructSpace({\n metadata,\n swarmIdentity: {\n peerKey: this.deviceKey,\n credentialProvider: MOCK_AUTH_PROVIDER,\n credentialAuthenticator: MOCK_AUTH_VERIFIER,\n },\n memberKey: identityKey,\n onAuthorizedConnection: (session) => {\n session.addExtension(\n 'dxos.mesh.teleport.gossip',\n this.createGossip().createExtension({ remotePeerId: session.remotePeerId }),\n );\n },\n });\n await space.setControlFeed(controlFeed);\n await space.setDataFeed(dataFeed);\n\n await space.open(new Context());\n\n this._spaces.set(spaceKey, space);\n return space;\n }\n\n createSpaceProtocol(topic: PublicKey, gossip?: Gossip) {\n return new SpaceProtocol({\n topic,\n swarmIdentity: {\n peerKey: this.deviceKey,\n credentialProvider: MOCK_AUTH_PROVIDER,\n credentialAuthenticator: MOCK_AUTH_VERIFIER,\n },\n networkManager: this._networkManagerProvider(),\n blobStore: this.blobStore,\n onSessionAuth: (session) => {\n session.addExtension(\n 'dxos.mesh.teleport.gossip',\n (gossip ?? this.createGossip()).createExtension({ remotePeerId: session.remotePeerId }),\n );\n },\n });\n }\n\n createGossip() {\n return new Gossip({\n localPeerId: this.deviceKey,\n });\n }\n\n createPresence(gossip?: Gossip) {\n return new Presence({\n announceInterval: 30,\n offlineTimeout: 200,\n identityKey: this.identityKey,\n gossip: gossip ?? this.createGossip(),\n });\n }\n\n async spaceGenesis(space: Space) {\n const generator = new CredentialGenerator(this.keyring, this.identityKey, this.deviceKey);\n const credentials = [\n ...(await generator.createSpaceGenesis(space.key, space.controlFeedKey!)),\n await generator.createFeedAdmission(space.key, space.dataFeedKey!, AdmittedFeed.Designation.DATA),\n await generator.createEpochCredential(space.key),\n ];\n\n for (const credential of credentials) {\n await space.controlPipeline.writer.write({\n credential: { credential },\n });\n }\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { TestBuilder } from '@dxos/feed-store/testing';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\n\nimport { valueEncoding } from '../common';\n\n/**\n * Builder with default encoder and generator.\n */\nexport class TestFeedBuilder extends TestBuilder<FeedMessage> {\n constructor() {\n super({\n valueEncoding,\n });\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["log", "schema", "EchoMetadata", "schema", "getCodecForType", "changeStorageVersionInMetadata", "storage", "version", "log", "info", "metadata", "MetadataStore", "createDirectory", "load", "echoMetadata", "file", "_directory", "getOrCreateFile", "_writeFile", "flush", "Context", "CredentialGenerator", "PublicKey", "MemorySignalManager", "MemorySignalManagerContext", "WebsocketSignalManager", "MemoryTransportFactory", "NetworkManager", "createSimplePeerTransportFactory", "AdmittedFeed", "StorageType", "createStorage", "Gossip", "Presence", "BlobStore", "ComplexMap", "TestBuilder", "TestFeedBuilder", "TestBuilder", "constructor", "valueEncoding", "MemoryNetworkManagerProvider", "signalContext", "NetworkManager", "signalManager", "MemorySignalManager", "transportFactory", "MemoryTransportFactory", "WebsocketNetworkManagerProvider", "signalUrl", "WebsocketSignalManager", "server", "createSimplePeerTransportFactory", "TestAgentBuilder", "constructor", "storage", "networkManagerProvider", "_agents", "ComplexMap", "PublicKey", "hash", "_storage", "createStorage", "type", "StorageType", "RAM", "_networkManagerProvider", "MemorySignalManagerContext", "close", "Promise", "all", "agents", "map", "agent", "Array", "from", "values", "getAgent", "deviceKey", "get", "createPeer", "feedBuilder", "TestFeedBuilder", "setStorage", "size", "identityKey", "keyring", "createKey", "TestAgent", "set", "metadataStore", "_metadataStore", "MetadataStore", "createDirectory", "snapshotStore", "_snapshotStore", "SnapshotStore", "blobStore", "_blobStore", "BlobStore", "_feedBuilder", "_spaces", "feedStore", "createFeedStore", "spaces", "space", "getSpace", "spaceKey", "spaceManager", "_spaceManager", "SpaceManager", "networkManager", "createSpace", "genesisKey", "dataKey", "saveMetadata", "controlFeed", "openFeed", "writable", "dataFeed", "sparse", "metadata", "key", "genesisFeedKey", "controlFeedKey", "dataFeedKey", "addSpace", "open", "constructSpace", "swarmIdentity", "peerKey", "credentialProvider", "MOCK_AUTH_PROVIDER", "credentialAuthenticator", "MOCK_AUTH_VERIFIER", "memberKey", "onAuthorizedConnection", "session", "addExtension", "createGossip", "createExtension", "remotePeerId", "setControlFeed", "setDataFeed", "Context", "createSpaceProtocol", "topic", "gossip", "SpaceProtocol", "onSessionAuth", "Gossip", "localPeerId", "createPresence", "Presence", "announceInterval", "offlineTimeout", "spaceGenesis", "generator", "CredentialGenerator", "credentials", "createSpaceGenesis", "createFeedAdmission", "AdmittedFeed", "Designation", "DATA", "createEpochCredential", "credential", "controlPipeline", "writer", "write"]
3
+ "sources": ["../../../../src/testing/change-metadata.ts", "../../../../src/testing/test-agent-builder.ts", "../../../../src/testing/test-feed-builder.ts", "../../../../src/testing/level.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { log } from '@dxos/log';\nimport { schema } from '@dxos/protocols';\nimport type { Storage } from '@dxos/random-access-storage';\n\nimport { MetadataStore } from '../metadata';\n\nconst EchoMetadata = schema.getCodecForType('dxos.echo.metadata.EchoMetadata');\n\n/**\n * This function will change the storage version in the metadata.\n * This will break your storage and make it unusable.\n * Use this only for testing purposes.\n */\nexport const changeStorageVersionInMetadata = async (storage: Storage, version: number) => {\n log.info('Changing storage version in metadata. USE ONLY FOR TESTING.');\n const metadata = new MetadataStore(storage.createDirectory('metadata'));\n await metadata.load();\n const echoMetadata = metadata.metadata;\n echoMetadata.version = version;\n const file = metadata._directory.getOrCreateFile('EchoMetadata');\n await metadata._writeFile(file, EchoMetadata, echoMetadata);\n await metadata._directory.flush();\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Context } from '@dxos/context';\nimport { CredentialGenerator } from '@dxos/credentials';\nimport { type FeedStore } from '@dxos/feed-store';\nimport { type Keyring } from '@dxos/keyring';\nimport { PublicKey } from '@dxos/keys';\nimport { MemorySignalManager, MemorySignalManagerContext, WebsocketSignalManager } from '@dxos/messaging';\nimport { MemoryTransportFactory, NetworkManager, createSimplePeerTransportFactory } from '@dxos/network-manager';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type SpaceMetadata } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport { AdmittedFeed } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { StorageType, createStorage, type Storage } from '@dxos/random-access-storage';\nimport { Gossip, Presence } from '@dxos/teleport-extension-gossip';\nimport { BlobStore } from '@dxos/teleport-extension-object-sync';\nimport { ComplexMap } from '@dxos/util';\n\nimport { TestFeedBuilder } from './test-feed-builder';\nimport { SnapshotStore } from '../db-host';\nimport { MetadataStore } from '../metadata';\nimport { MOCK_AUTH_PROVIDER, MOCK_AUTH_VERIFIER, SpaceManager, SpaceProtocol, type Space } from '../space';\n\nexport type NetworkManagerProvider = () => NetworkManager;\n\nexport const MemoryNetworkManagerProvider =\n (signalContext: MemorySignalManagerContext): NetworkManagerProvider =>\n () =>\n new NetworkManager({\n signalManager: new MemorySignalManager(signalContext),\n transportFactory: MemoryTransportFactory,\n });\n\nexport const WebsocketNetworkManagerProvider =\n (signalUrl: string): NetworkManagerProvider =>\n () =>\n new NetworkManager({\n signalManager: new WebsocketSignalManager([{ server: signalUrl }]),\n transportFactory: createSimplePeerTransportFactory(),\n });\n\nexport type TestAgentBuilderOptions = {\n storage?: Storage;\n networkManagerProvider?: NetworkManagerProvider;\n};\n\n/**\n * Factory for test agents.\n */\nexport class TestAgentBuilder {\n private readonly _agents = new ComplexMap<PublicKey, TestAgent>(PublicKey.hash);\n private readonly _storage: Storage;\n private readonly _networkManagerProvider: NetworkManagerProvider;\n\n constructor({ storage, networkManagerProvider }: TestAgentBuilderOptions = {}) {\n this._storage = storage ?? createStorage({ type: StorageType.RAM });\n this._networkManagerProvider =\n networkManagerProvider ?? MemoryNetworkManagerProvider(new MemorySignalManagerContext());\n }\n\n async close() {\n return Promise.all(this.agents.map((agent) => agent.close()));\n }\n\n get agents() {\n return Array.from(this._agents.values());\n }\n\n getAgent(deviceKey: PublicKey) {\n return this._agents.get(deviceKey);\n }\n\n async createPeer(): Promise<TestAgent> {\n // prettier-ignore\n const feedBuilder = new TestFeedBuilder()\n .setStorage(this._storage, `agent-${this._agents.size}`);\n\n const identityKey = await feedBuilder.keyring.createKey();\n const deviceKey = await feedBuilder.keyring.createKey();\n\n const agent = new TestAgent(this._networkManagerProvider, feedBuilder, identityKey, deviceKey);\n this._agents.set(deviceKey, agent);\n return agent;\n }\n}\n\n/**\n * Test agent that enables the creation and replication of multiple spaces.\n */\nexport class TestAgent {\n private readonly _spaces = new ComplexMap<PublicKey, Space>(PublicKey.hash);\n\n public readonly storage: Storage;\n public readonly keyring: Keyring;\n public readonly feedStore: FeedStore<FeedMessage>;\n\n private _metadataStore?: MetadataStore;\n get metadataStore() {\n return (this._metadataStore ??= new MetadataStore(this.storage.createDirectory('metadata')));\n }\n\n private _snapshotStore?: SnapshotStore;\n get snapshotStore() {\n return (this._snapshotStore ??= new SnapshotStore(this.storage.createDirectory('snapshots')));\n }\n\n private _blobStore?: BlobStore;\n get blobStore() {\n return (this._blobStore ??= new BlobStore(this.storage.createDirectory('blobs')));\n }\n\n constructor(\n private readonly _networkManagerProvider: NetworkManagerProvider,\n private readonly _feedBuilder: TestFeedBuilder,\n public readonly identityKey: PublicKey,\n public readonly deviceKey: PublicKey,\n ) {\n this.storage = this._feedBuilder.storage;\n this.keyring = this._feedBuilder.keyring;\n this.feedStore = this._feedBuilder.createFeedStore();\n }\n\n async close() {\n return Promise.all([...this.spaces.map((space) => space.close())]);\n }\n\n get spaces() {\n return Array.from(this._spaces.values());\n }\n\n getSpace(spaceKey: PublicKey) {\n return this._spaces.get(spaceKey);\n }\n\n private _spaceManager?: SpaceManager;\n get spaceManager() {\n return (this._spaceManager ??= new SpaceManager({\n feedStore: this.feedStore,\n networkManager: this._networkManagerProvider(),\n metadataStore: this.metadataStore,\n snapshotStore: this.snapshotStore,\n blobStore: this.blobStore,\n }));\n }\n\n async createSpace(\n identityKey: PublicKey = this.identityKey,\n spaceKey?: PublicKey,\n genesisKey?: PublicKey,\n dataKey?: PublicKey,\n saveMetadata = false,\n ): Promise<Space> {\n if (!spaceKey) {\n saveMetadata = true;\n spaceKey = await this.keyring.createKey();\n }\n if (!genesisKey) {\n genesisKey = await this.keyring.createKey();\n }\n\n const controlFeed = await this.feedStore.openFeed(genesisKey, { writable: true });\n const dataFeed = await this.feedStore.openFeed(dataKey ?? (await this.keyring.createKey()), {\n writable: true,\n sparse: true,\n });\n\n const metadata: SpaceMetadata = {\n key: spaceKey,\n genesisFeedKey: genesisKey,\n controlFeedKey: controlFeed.key,\n dataFeedKey: dataFeed.key,\n };\n if (saveMetadata) {\n await this.metadataStore.addSpace(metadata);\n }\n\n await this.spaceManager.open();\n const space = await this.spaceManager.constructSpace({\n metadata,\n swarmIdentity: {\n peerKey: this.deviceKey,\n credentialProvider: MOCK_AUTH_PROVIDER,\n credentialAuthenticator: MOCK_AUTH_VERIFIER,\n },\n memberKey: identityKey,\n onAuthorizedConnection: (session) => {\n session.addExtension(\n 'dxos.mesh.teleport.gossip',\n this.createGossip().createExtension({ remotePeerId: session.remotePeerId }),\n );\n },\n });\n await space.setControlFeed(controlFeed);\n await space.setDataFeed(dataFeed);\n\n await space.open(new Context());\n\n this._spaces.set(spaceKey, space);\n return space;\n }\n\n createSpaceProtocol(topic: PublicKey, gossip?: Gossip) {\n return new SpaceProtocol({\n topic,\n swarmIdentity: {\n peerKey: this.deviceKey,\n credentialProvider: MOCK_AUTH_PROVIDER,\n credentialAuthenticator: MOCK_AUTH_VERIFIER,\n },\n networkManager: this._networkManagerProvider(),\n blobStore: this.blobStore,\n onSessionAuth: (session) => {\n session.addExtension(\n 'dxos.mesh.teleport.gossip',\n (gossip ?? this.createGossip()).createExtension({ remotePeerId: session.remotePeerId }),\n );\n },\n });\n }\n\n createGossip() {\n return new Gossip({\n localPeerId: this.deviceKey,\n });\n }\n\n createPresence(gossip?: Gossip) {\n return new Presence({\n announceInterval: 30,\n offlineTimeout: 200,\n identityKey: this.identityKey,\n gossip: gossip ?? this.createGossip(),\n });\n }\n\n async spaceGenesis(space: Space) {\n const generator = new CredentialGenerator(this.keyring, this.identityKey, this.deviceKey);\n const credentials = [\n ...(await generator.createSpaceGenesis(space.key, space.controlFeedKey!)),\n await generator.createFeedAdmission(space.key, space.dataFeedKey!, AdmittedFeed.Designation.DATA),\n await generator.createEpochCredential(space.key),\n ];\n\n for (const credential of credentials) {\n await space.controlPipeline.writer.write({\n credential: { credential },\n });\n }\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { TestBuilder } from '@dxos/feed-store/testing';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\n\nimport { valueEncoding } from '../common';\n\n/**\n * Builder with default encoder and generator.\n */\nexport class TestFeedBuilder extends TestBuilder<FeedMessage> {\n constructor() {\n super({\n valueEncoding,\n });\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { Level } from 'level';\n\nimport { PublicKey } from '@dxos/keys';\n\nimport { type MyLevel } from '../automerge/types';\n\nexport const createTestLevel = (): MyLevel => new Level<string, string>(`/tmp/dxos-${PublicKey.random().toHex()}`);\n"],
5
+ "mappings": "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",
6
+ "names": ["log", "schema", "EchoMetadata", "schema", "getCodecForType", "changeStorageVersionInMetadata", "storage", "version", "log", "info", "metadata", "MetadataStore", "createDirectory", "load", "echoMetadata", "file", "_directory", "getOrCreateFile", "_writeFile", "flush", "Context", "CredentialGenerator", "PublicKey", "MemorySignalManager", "MemorySignalManagerContext", "WebsocketSignalManager", "MemoryTransportFactory", "NetworkManager", "createSimplePeerTransportFactory", "AdmittedFeed", "StorageType", "createStorage", "Gossip", "Presence", "BlobStore", "ComplexMap", "TestBuilder", "TestFeedBuilder", "TestBuilder", "constructor", "valueEncoding", "MemoryNetworkManagerProvider", "signalContext", "NetworkManager", "signalManager", "MemorySignalManager", "transportFactory", "MemoryTransportFactory", "WebsocketNetworkManagerProvider", "signalUrl", "WebsocketSignalManager", "server", "createSimplePeerTransportFactory", "TestAgentBuilder", "constructor", "storage", "networkManagerProvider", "_agents", "ComplexMap", "PublicKey", "hash", "_storage", "createStorage", "type", "StorageType", "RAM", "_networkManagerProvider", "MemorySignalManagerContext", "close", "Promise", "all", "agents", "map", "agent", "Array", "from", "values", "getAgent", "deviceKey", "get", "createPeer", "feedBuilder", "TestFeedBuilder", "setStorage", "size", "identityKey", "keyring", "createKey", "TestAgent", "set", "metadataStore", "_metadataStore", "MetadataStore", "createDirectory", "snapshotStore", "_snapshotStore", "SnapshotStore", "blobStore", "_blobStore", "BlobStore", "_feedBuilder", "_spaces", "feedStore", "createFeedStore", "spaces", "space", "getSpace", "spaceKey", "spaceManager", "_spaceManager", "SpaceManager", "networkManager", "createSpace", "genesisKey", "dataKey", "saveMetadata", "controlFeed", "openFeed", "writable", "dataFeed", "sparse", "metadata", "key", "genesisFeedKey", "controlFeedKey", "dataFeedKey", "addSpace", "open", "constructSpace", "swarmIdentity", "peerKey", "credentialProvider", "MOCK_AUTH_PROVIDER", "credentialAuthenticator", "MOCK_AUTH_VERIFIER", "memberKey", "onAuthorizedConnection", "session", "addExtension", "createGossip", "createExtension", "remotePeerId", "setControlFeed", "setDataFeed", "Context", "createSpaceProtocol", "topic", "gossip", "SpaceProtocol", "onSessionAuth", "Gossip", "localPeerId", "createPresence", "Presence", "announceInterval", "offlineTimeout", "spaceGenesis", "generator", "CredentialGenerator", "credentials", "createSpaceGenesis", "createFeedAdmission", "AdmittedFeed", "Designation", "DATA", "createEpochCredential", "credential", "controlPipeline", "writer", "write", "Level", "PublicKey", "createTestLevel", "Level", "PublicKey", "random", "toHex"]
7
7
  }
@@ -26,8 +26,8 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
26
26
  mod
27
27
  ));
28
28
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
- var chunk_7VZVCCNF_exports = {};
30
- __export(chunk_7VZVCCNF_exports, {
29
+ var chunk_WCTX6RNS_exports = {};
30
+ __export(chunk_WCTX6RNS_exports, {
31
31
  AuthExtension: () => AuthExtension,
32
32
  AuthStatus: () => AuthStatus,
33
33
  DataServiceImpl: () => DataServiceImpl,
@@ -44,12 +44,13 @@ __export(chunk_7VZVCCNF_exports, {
44
44
  TimeframeClock: () => TimeframeClock,
45
45
  codec: () => codec,
46
46
  createMappedFeedWriter: () => createMappedFeedWriter,
47
+ hasInvitationExpired: () => hasInvitationExpired,
47
48
  mapFeedIndexesToTimeframe: () => mapFeedIndexesToTimeframe,
48
49
  mapTimeframeToFeedIndexes: () => mapTimeframeToFeedIndexes,
49
50
  startAfter: () => startAfter,
50
51
  valueEncoding: () => valueEncoding
51
52
  });
52
- module.exports = __toCommonJS(chunk_7VZVCCNF_exports);
53
+ module.exports = __toCommonJS(chunk_WCTX6RNS_exports);
53
54
  var import_hypercore = require("@dxos/hypercore");
54
55
  var import_protocols = require("@dxos/protocols");
55
56
  var import_invariant = require("@dxos/invariant");
@@ -91,13 +92,14 @@ var import_log5 = require("@dxos/log");
91
92
  var import_protocols5 = require("@dxos/protocols");
92
93
  var import_teleport = require("@dxos/teleport");
93
94
  var import_async5 = require("@dxos/async");
95
+ var import_context5 = require("@dxos/context");
94
96
  var import_invariant6 = require("@dxos/invariant");
95
97
  var import_log6 = require("@dxos/log");
96
98
  var import_credentials = require("@dxos/protocols/proto/dxos/halo/credentials");
97
99
  var import_tracing = require("@dxos/tracing");
98
100
  var import_util3 = require("@dxos/util");
99
101
  var import_async6 = require("@dxos/async");
100
- var import_context5 = require("@dxos/context");
102
+ var import_context6 = require("@dxos/context");
101
103
  var import_credentials2 = require("@dxos/credentials");
102
104
  var import_keys4 = require("@dxos/keys");
103
105
  var import_log7 = require("@dxos/log");
@@ -228,6 +230,7 @@ var DataServiceImpl = class {
228
230
  throw new Error("Deprecated.");
229
231
  }
230
232
  async flush(request) {
233
+ await this._automergeHost.flush(request);
231
234
  }
232
235
  // Automerge specific.
233
236
  async getHostInfo(request) {
@@ -390,8 +393,8 @@ var MetadataStore = class {
390
393
  }
391
394
  });
392
395
  (0, import_async.scheduleTaskInterval)(this._invitationCleanupCtx, async () => {
393
- for (const invitation of this.getInvitations()) {
394
- if (invitation.created && invitation.lifetime && invitation.lifetime !== 0 && invitation.created.getTime() + invitation.lifetime * 1e3 < Date.now()) {
396
+ for (const invitation of this._metadata.invitations ?? []) {
397
+ if (hasInvitationExpired(invitation) || isLegacyInvitationFormat(invitation)) {
395
398
  await this.removeInvitation(invitation.invitationId);
396
399
  }
397
400
  }
@@ -420,7 +423,7 @@ var MetadataStore = class {
420
423
  err
421
424
  }, {
422
425
  F: __dxlog_file2,
423
- L: 215,
426
+ L: 210,
424
427
  S: this,
425
428
  C: (f, a) => f(...a)
426
429
  });
@@ -441,7 +444,7 @@ var MetadataStore = class {
441
444
  const space = this.spaces.find((space2) => space2.key === spaceKey);
442
445
  (0, import_invariant2.invariant)(space, "Space not found", {
443
446
  F: __dxlog_file2,
444
- L: 237,
447
+ L: 232,
445
448
  S: this,
446
449
  A: [
447
450
  "space",
@@ -465,7 +468,7 @@ var MetadataStore = class {
465
468
  async clear() {
466
469
  (0, import_log.log)("clearing all metadata", void 0, {
467
470
  F: __dxlog_file2,
468
- L: 256,
471
+ L: 251,
469
472
  S: this,
470
473
  C: (f, a) => f(...a)
471
474
  });
@@ -478,7 +481,7 @@ var MetadataStore = class {
478
481
  async setIdentityRecord(record) {
479
482
  (0, import_invariant2.invariant)(!this._metadata.identity, "Cannot overwrite existing identity in metadata", {
480
483
  F: __dxlog_file2,
481
- L: 266,
484
+ L: 261,
482
485
  S: this,
483
486
  A: [
484
487
  "!this._metadata.identity",
@@ -508,7 +511,7 @@ var MetadataStore = class {
508
511
  async addSpace(record) {
509
512
  (0, import_invariant2.invariant)(!(this._metadata.spaces ?? []).find((space) => space.key === record.key), "Cannot overwrite existing space in metadata", {
510
513
  F: __dxlog_file2,
511
- L: 294,
514
+ L: 289,
512
515
  S: this,
513
516
  A: [
514
517
  "!(this._metadata.spaces ?? []).find((space) => space.key === record.key)",
@@ -563,6 +566,12 @@ _ts_decorate([
563
566
  import_async.synchronized
564
567
  ], MetadataStore.prototype, "_saveSpaceLargeMetadata", null);
565
568
  var fromBytesInt32 = (buf) => buf.readInt32LE(0);
569
+ var hasInvitationExpired = (invitation) => {
570
+ return Boolean(invitation.created && invitation.lifetime && invitation.lifetime !== 0 && invitation.created.getTime() + invitation.lifetime * 1e3 < Date.now());
571
+ };
572
+ var isLegacyInvitationFormat = (invitation) => {
573
+ return invitation.type === import_services.Invitation.Type.MULTIUSE;
574
+ };
566
575
  function _ts_decorate2(decorators, target, key, desc) {
567
576
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
568
577
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
@@ -1204,7 +1213,7 @@ var CONTROL_PIPELINE_SNAPSHOT_DELAY = 1e4;
1204
1213
  var USE_SNAPSHOTS = true;
1205
1214
  var ControlPipeline = class {
1206
1215
  constructor({ spaceKey, genesisFeed, feedProvider, metadataStore }) {
1207
- this._ctx = new import_context5.Context();
1216
+ this._ctx = new import_context6.Context();
1208
1217
  this._lastTimeframeSaveTime = Date.now();
1209
1218
  this.onFeedAdmitted = new import_util4.Callback();
1210
1219
  this._usage = new import_tracing2.TimeUsageCounter();
@@ -1281,7 +1290,7 @@ var ControlPipeline = class {
1281
1290
  C: (f, a) => f(...a)
1282
1291
  });
1283
1292
  setTimeout(async () => {
1284
- void this._consumePipeline(new import_context5.Context());
1293
+ void this._consumePipeline(new import_context6.Context());
1285
1294
  });
1286
1295
  await this._pipeline.start();
1287
1296
  (0, import_log7.log)("started", void 0, {
@@ -1449,12 +1458,12 @@ function _ts_decorate5(decorators, target, key, desc) {
1449
1458
  return c > 3 && r && Object.defineProperty(target, key, r), r;
1450
1459
  }
1451
1460
  var __dxlog_file8 = "/home/runner/work/dxos/dxos/packages/core/echo/echo-pipeline/src/space/space.ts";
1452
- var Space = class {
1461
+ var Space = class extends import_context5.Resource {
1453
1462
  constructor(params) {
1463
+ super();
1454
1464
  this._addFeedMutex = new import_async5.Mutex();
1455
1465
  this.onCredentialProcessed = new import_util3.Callback();
1456
1466
  this.stateUpdate = new import_async5.Event();
1457
- this._isOpen = false;
1458
1467
  (0, import_invariant6.invariant)(params.spaceKey && params.feedProvider, void 0, {
1459
1468
  F: __dxlog_file8,
1460
1469
  L: 72,
@@ -1503,7 +1512,7 @@ var Space = class {
1503
1512
  return this._key;
1504
1513
  }
1505
1514
  get isOpen() {
1506
- return this._isOpen;
1515
+ return this._lifecycleState === import_context5.LifecycleState.OPEN;
1507
1516
  }
1508
1517
  get genesisFeedKey() {
1509
1518
  return this._genesisFeedKey;
@@ -1559,50 +1568,36 @@ var Space = class {
1559
1568
  getControlFeeds() {
1560
1569
  return Array.from(this._controlPipeline.spaceState.feeds.values());
1561
1570
  }
1562
- /**
1563
- * Use for diagnostics.
1564
- */
1565
- // getDataFeeds(): FeedInfo[] {
1566
- // return this._dataPipeline?.getFeeds();
1567
- // }
1568
- async open(ctx) {
1571
+ async _open(ctx) {
1569
1572
  (0, import_log6.log)("opening...", void 0, {
1570
1573
  F: __dxlog_file8,
1571
- L: 174,
1574
+ L: 167,
1572
1575
  S: this,
1573
1576
  C: (f, a) => f(...a)
1574
1577
  });
1575
- if (this._isOpen) {
1576
- return;
1577
- }
1578
1578
  await this._controlPipeline.start();
1579
1579
  await this.protocol.start();
1580
- this._isOpen = true;
1581
1580
  (0, import_log6.log)("opened", void 0, {
1582
1581
  F: __dxlog_file8,
1583
- L: 184,
1582
+ L: 173,
1584
1583
  S: this,
1585
1584
  C: (f, a) => f(...a)
1586
1585
  });
1587
1586
  }
1588
- async close() {
1587
+ async _close() {
1589
1588
  (0, import_log6.log)("closing...", {
1590
1589
  key: this._key
1591
1590
  }, {
1592
1591
  F: __dxlog_file8,
1593
- L: 189,
1592
+ L: 178,
1594
1593
  S: this,
1595
1594
  C: (f, a) => f(...a)
1596
1595
  });
1597
- if (!this._isOpen) {
1598
- return;
1599
- }
1600
1596
  await this.protocol.stop();
1601
1597
  await this._controlPipeline.stop();
1602
- this._isOpen = false;
1603
1598
  (0, import_log6.log)("closed", void 0, {
1604
1599
  F: __dxlog_file8,
1605
- L: 199,
1600
+ L: 184,
1606
1601
  S: this,
1607
1602
  C: (f, a) => f(...a)
1608
1603
  });
@@ -1619,12 +1614,11 @@ _ts_decorate5([
1619
1614
  import_tracing.trace.info()
1620
1615
  ], Space.prototype, "key", null);
1621
1616
  _ts_decorate5([
1622
- import_async5.synchronized,
1623
1617
  import_tracing.trace.span()
1624
- ], Space.prototype, "open", null);
1618
+ ], Space.prototype, "_open", null);
1625
1619
  _ts_decorate5([
1626
1620
  import_async5.synchronized
1627
- ], Space.prototype, "close", null);
1621
+ ], Space.prototype, "_close", null);
1628
1622
  Space = _ts_decorate5([
1629
1623
  (0, import_async5.trackLeaks)("open", "close"),
1630
1624
  import_tracing.trace.resource()
@@ -1940,9 +1934,10 @@ SpaceManager = _ts_decorate7([
1940
1934
  TimeframeClock,
1941
1935
  codec,
1942
1936
  createMappedFeedWriter,
1937
+ hasInvitationExpired,
1943
1938
  mapFeedIndexesToTimeframe,
1944
1939
  mapTimeframeToFeedIndexes,
1945
1940
  startAfter,
1946
1941
  valueEncoding
1947
1942
  });
1948
- //# sourceMappingURL=chunk-7VZVCCNF.cjs.map
1943
+ //# sourceMappingURL=chunk-WCTX6RNS.cjs.map
@@ -0,0 +1,7 @@
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/data-service.ts", "../../../src/metadata/metadata-store.ts", "../../../src/pipeline/timeframe-clock.ts", "../../../src/pipeline/pipeline.ts", "../../../src/pipeline/message-selector.ts", "../../../src/space/auth.ts", "../../../src/space/space.ts", "../../../src/space/control-pipeline.ts", "../../../src/space/space-protocol.ts", "../../../src/space/space-manager.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 { 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 { 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 2021 DXOS.org\n//\n\nimport { type Stream } from '@dxos/codec-protobuf';\nimport {\n type DataService,\n type EchoEvent,\n type FlushRequest,\n type HostInfo,\n type MutationReceipt,\n type SubscribeRequest,\n type SyncRepoRequest,\n type SyncRepoResponse,\n type WriteRequest,\n} from '@dxos/protocols/proto/dxos/echo/service';\n\nimport { type AutomergeHost } from '../automerge';\n\n/**\n * Data sync between client and services.\n */\n// TODO(burdon): Move to client-services.\nexport class DataServiceImpl implements DataService {\n constructor(private readonly _automergeHost: AutomergeHost) {}\n\n subscribe(request: SubscribeRequest): Stream<EchoEvent> {\n throw new Error('Deprecated.');\n }\n\n write(request: WriteRequest): Promise<MutationReceipt> {\n throw new Error('Deprecated.');\n }\n\n async flush(request: FlushRequest): Promise<void> {\n await this._automergeHost.flush(request);\n }\n\n // Automerge specific.\n\n async getHostInfo(request: void): Promise<HostInfo> {\n return this._automergeHost.getHostInfo();\n }\n\n syncRepo(request: SyncRepoRequest): Stream<SyncRepoResponse> {\n return this._automergeHost.syncRepo(request);\n }\n\n sendSyncMessage(request: SyncRepoRequest): Promise<void> {\n return this._automergeHost.sendSyncMessage(request);\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 EchoMetadata,\n type SpaceMetadata,\n type IdentityRecord,\n type SpaceCache,\n 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.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", "//\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\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 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 2022 DXOS.org\n//\n\nimport { Event, Mutex, synchronized, trackLeaks } from '@dxos/async';\nimport { Resource, type Context, LifecycleState } from '@dxos/context';\nimport { type FeedInfo } from '@dxos/credentials';\nimport { type FeedOptions, type FeedWrapper } from '@dxos/feed-store';\nimport { invariant } from '@dxos/invariant';\nimport { type PublicKey } 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 { Callback, type AsyncCallback } 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 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\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 private readonly _addFeedMutex = new Mutex();\n\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 _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._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 queueMicrotask(async () => {\n 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\n // Start replicating the genesis feed.\n this.protocol = params.protocol;\n this.protocol.addFeed(params.genesisFeed);\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\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", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { DeferredTask, sleepWithContext, trackLeaks } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { SpaceStateMachine, type SpaceState, type MemberInfo, type FeedInfo } 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 onMemberAdmitted: Callback<AsyncCallback<MemberInfo>>;\n public readonly onCredentialProcessed: Callback<AsyncCallback<Credential>>;\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.onMemberAdmitted = this._spaceStateMachine.onMemberAdmitted;\n this.onCredentialProcessed = this._spaceStateMachine.onCredentialProcessed;\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 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 NetworkManager,\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 { ComplexMap } 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: NetworkManager;\n\n blobStore: BlobStore;\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\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: NetworkManager;\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 @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\n private _connection?: SwarmConnection;\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({ topic, swarmIdentity, networkManager, onSessionAuth, onAuthFailure, blobStore }: 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\n // TODO(burdon): Create abstraction for Space (e.g., add keys and have provider).\n 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\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 // TODO(burdon): Move to config (with sensible defaults).\n const topologyConfig = {\n originateConnections: 4,\n maxPeers: 10,\n sampleSize: 20,\n };\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: new MMSTTopology(topologyConfig),\n label: `swarm ${topic.truncate()} for space ${this._spaceKey.truncate()}`,\n });\n\n log('started');\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 });\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\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 _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({ wireParams, swarmIdentity, onSessionAuth, onAuthFailure, blobSync }: 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\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 this._teleport.addExtension('dxos.mesh.teleport.replicator', this.replicator);\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 } from '@dxos/async';\nimport { failUndefined } from '@dxos/debug';\nimport { type FeedStore } from '@dxos/feed-store';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type NetworkManager } 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 Teleport } from '@dxos/teleport';\nimport { type BlobStore } from '@dxos/teleport-extension-object-sync';\nimport { ComplexMap } from '@dxos/util';\n\nimport { Space } 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: NetworkManager;\n metadataStore: MetadataStore;\n\n /**\n * @deprecated Replaced by BlobStore.\n */\n snapshotStore: SnapshotStore;\n\n blobStore: BlobStore;\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};\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: NetworkManager;\n private readonly _metadataStore: MetadataStore;\n private readonly _snapshotStore: SnapshotStore;\n private readonly _blobStore: BlobStore;\n private readonly _instanceId = PublicKey.random().toHex();\n\n constructor({ feedStore, networkManager, metadataStore, snapshotStore, blobStore }: 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 }\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 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 protocol = new SpaceProtocol({\n topic: spaceKey,\n swarmIdentity,\n networkManager: this._networkManager,\n onSessionAuth: onAuthorizedConnection,\n onAuthFailure,\n blobStore: this._blobStore,\n });\n const snapshotManager = new SnapshotManager(this._snapshotStore, this._blobStore, protocol.blobSync);\n\n const space = new Space({\n spaceKey,\n protocol,\n genesisFeed,\n feedProvider: (feedKey, opts) => this._feedStore.openFeed(feedKey, opts),\n metadataStore: this._metadataStore,\n snapshotManager,\n memberKey,\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"],
5
+ "mappings": "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",
6
+ "names": ["import_protocols", "import_context", "import_invariant", "import_keys", "import_async", "import_log", "import_debug", "import_timeframe", "import_util", "import_crypto", "import_credentials", "import_tracing", "import_teleport", "codec", "schema", "getCodecForType", "valueEncoding", "createCodecEncoding", "createMappedFeedWriter", "mapper", "writer", "invariant", "write", "data", "options", "SpaceSnapshot", "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", "SnapshotStore", "_directory", "saveSnapshot", "encoded", "key", "subtleCrypto", "digest", "keyString", "Buffer", "toString", "file", "getOrCreateFile", "close", "size", "stat", "undefined", "buffer", "read", "listSnapshots", "entries", "list", "Promise", "all", "map", "DataServiceImpl", "_automergeHost", "subscribe", "request", "Error", "flush", "getHostInfo", "syncRepo", "sendSyncMessage", "EXPIRED_INVITATION_CLEANUP_INTERVAL", "emptyEchoMetadata", "version", "STORAGE_VERSION", "spaces", "created", "Date", "updated", "emptyLargeSpaceMetadata", "EchoMetadata", "LargeSpaceMetadata", "MetadataStore", "directory", "_metadata", "_spaceLargeMetadata", "ComplexMap", "hash", "_metadataFile", "update", "Event", "_invitationCleanupCtx", "Context", "metadata", "_readFile", "fileLength", "dataSize", "fromBytesInt32", "checksum", "log", "name", "filename", "DataCorruptionError", "calculatedChecksum", "CRC32", "buf", "_writeFile", "arrayToBuffer", "result", "alloc", "length", "writeInt32LE", "copy", "dispose", "clear", "closed", "forEach", "space", "SpaceState", "ACTIVE", "err", "error", "forEachAsync", "identity", "haloSpace", "filter", "isNotNullOrUndefined", "_loadSpaceLargeMetadata", "scheduleTaskInterval", "invitation", "invitations", "hasInvitationExpired", "isLegacyInvitationFormat", "removeInvitation", "invitationId", "_save", "emit", "_saveSpaceLargeMetadata", "_getLargeSpaceMetadata", "_getSpace", "spaceKey", "equals", "find", "entry", "delete", "getIdentityRecord", "setIdentityRecord", "record", "getInvitations", "addInvitation", "i", "push", "addSpace", "setSpaceDataLatestTimeframe", "timeframe", "dataTimeframe", "setSpaceControlLatestTimeframe", "controlTimeframe", "setCache", "cache", "setWritableFeedKeys", "controlFeedKey", "dataFeedKey", "setSpaceState", "getSpaceControlPipelineSnapshot", "controlPipelineSnapshot", "setSpaceControlPipelineSnapshot", "synchronized", "readInt32LE", "Boolean", "lifetime", "getTime", "now", "type", "Invitation", "Type", "MULTIUSE", "mapTimeframeToFeedIndexes", "frames", "feedKey", "index", "mapFeedIndexesToTimeframe", "indexes", "Timeframe", "startAfter", "TimeframeClock", "_timeframe", "_pendingTimeframe", "pendingTimeframe", "setTimeframe", "updatePendingTimeframe", "seq", "merge", "updateTimeframe", "hasGaps", "gaps", "dependencies", "isEmpty", "waitUntilReached", "target", "current", "waitForCondition", "deps", "timed", "createMessageSelector", "timeframeClock", "messages", "PipelineState", "_feeds", "_timeframeClock", "_ctx", "timeframeUpdate", "stalled", "_startTimeframe", "_reachedTarget", "endTimeframe", "Array", "values", "feed", "startTimeframe", "targetTimeframe", "_targetTimeframe", "reachedTarget", "feeds", "waitUntilTimeframe", "setTargetTimeframe", "waitUntilReachedTargetTimeframe", "timeout", "breakOnStall", "_reachedTargetPromise", "race", "discardParameter", "waitForCount", "done", "rejectOnDispose", "then", "sleepWithContext", "warn", "Pipeline", "Trigger", "wake", "_pauseTrigger", "value", "_isStopping", "_isStarted", "_isBeingConsumed", "_isPaused", "_state", "_writer", "hasFeed", "has", "getFeeds", "_feedSetIterator", "addFeed", "_setFeedDownloadState", "setWriteFeed", "properties", "writable", "payload", "createFeedWriter", "start", "_initIterator", "open", "stop", "handle", "_downloads", "undownload", "_processingTrigger", "wait", "setCursor", "pause", "reset", "unpause", "consume", "lastFeedSetIterator", "iterable", "Symbol", "asyncIterator", "next", "block", "failUndefined", "truncate", "linear", "info", "FeedSetIterator", "stallTimeout", "on", "iterator", "AuthExtension", "RpcExtension", "_authParams", "requested", "AuthService", "getService", "exposed", "onError", "catch", "getHandlers", "authenticate", "challenge", "credential", "provider", "onOpen", "context", "scheduleTask", "randomBytes", "rpc", "success", "verifier", "runInContext", "onAuthSuccess", "onAuthFailure", "onClose", "onAbort", "TIMEFRAME_SAVE_DEBOUNCE_INTERVAL", "CONTROL_PIPELINE_SNAPSHOT_DELAY", "USE_SNAPSHOTS", "ControlPipeline", "genesisFeed", "feedProvider", "metadataStore", "_lastTimeframeSaveTime", "onFeedAdmitted", "Callback", "_usage", "TimeUsageCounter", "_mutations", "TimeSeriesCounter", "_snapshotTask", "DeferredTask", "_saveSnapshot", "_spaceKey", "_pipeline", "_spaceStateMachine", "SpaceStateMachine", "assertion", "designation", "AdmittedFeed", "Designation", "CONTROL", "queueMicrotask", "callIfSet", "onMemberAdmitted", "onCredentialProcessed", "spaceState", "pipeline", "present", "tf", "_processSnapshot", "setTimeout", "_consumePipeline", "message", "process", "sourceFeed", "skipVerification", "credentialEntries", "msg", "span", "beginRecording", "inc", "_processMessage", "end", "timer", "tracer", "mark", "_noteTargetStateIfNeeded", "schedule", "_saveTargetTimeframe", "newTimeframe", "trace", "metricsCounter", "showInBrowserTimeline", "resource", "trackLeaks", "Space", "Resource", "params", "_addFeedMutex", "Mutex", "stateUpdate", "_key", "_genesisFeedKey", "_feedProvider", "_snapshotManager", "snapshotManager", "_controlPipeline", "sparse", "DATA", "protocol", "isOpen", "_lifecycleState", "LifecycleState", "OPEN", "genesisFeedKey", "_controlFeed", "_dataFeed", "controlPipeline", "setControlFeed", "setDataFeed", "getControlFeeds", "_open", "_close", "logInfo", "MOCK_AUTH_PROVIDER", "nonce", "MOCK_AUTH_VERIFIER", "SpaceProtocol", "topic", "swarmIdentity", "networkManager", "onSessionAuth", "blobStore", "Set", "_sessions", "_networkManager", "_swarmIdentity", "_onSessionAuth", "_onAuthFailure", "blobSync", "BlobSync", "_topic", "asBuffer", "discoveryKey", "sessions", "_ownPeerKey", "peerKey", "add", "session", "replicator", "_connection", "credentials", "credentialProvider", "topologyConfig", "originateConnections", "maxPeers", "sampleSize", "joinSwarm", "protocolProvider", "_createProtocolProvider", "peerId", "topology", "MMSTTopology", "label", "wireParams", "SpaceProtocolSession", "remotePeerId", "AuthStatus", "ReplicatorExtension", "setOptions", "upload", "_authStatus", "_wireParams", "_teleport", "Teleport", "authStatus", "stats", "stream", "sessionId", "addExtension", "credentialAuthenticator", "createExtension", "abort", "SpaceManager", "feedStore", "snapshotStore", "_spaces", "_instanceId", "random", "_feedStore", "_metadataStore", "constructSpace", "onAuthorizedConnection", "memberKey", "begin", "openFeed", "opts"]
7
+ }