@dxos/echo-db 2.33.5-dev.b298094f → 2.33.5-dev.b4e42956

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 (133) hide show
  1. package/dist/src/echo.d.ts.map +1 -1
  2. package/dist/src/echo.js +1 -1
  3. package/dist/src/echo.js.map +1 -1
  4. package/dist/src/echo.test.js +12 -4
  5. package/dist/src/echo.test.js.map +1 -1
  6. package/dist/src/halo/halo-factory.d.ts +4 -4
  7. package/dist/src/halo/halo-factory.d.ts.map +1 -1
  8. package/dist/src/halo/halo-factory.js +3 -2
  9. package/dist/src/halo/halo-factory.js.map +1 -1
  10. package/dist/src/halo/halo-party.d.ts +4 -3
  11. package/dist/src/halo/halo-party.d.ts.map +1 -1
  12. package/dist/src/halo/halo-party.js +8 -4
  13. package/dist/src/halo/halo-party.js.map +1 -1
  14. package/dist/src/halo/halo.d.ts +2 -2
  15. package/dist/src/halo/halo.d.ts.map +1 -1
  16. package/dist/src/halo/party-opener.d.ts.map +1 -1
  17. package/dist/src/halo/party-opener.js +3 -1
  18. package/dist/src/halo/party-opener.js.map +1 -1
  19. package/dist/src/invitations/greeting-initiator.d.ts +2 -2
  20. package/dist/src/invitations/greeting-initiator.d.ts.map +1 -1
  21. package/dist/src/invitations/greeting-initiator.js +2 -1
  22. package/dist/src/invitations/greeting-initiator.js.map +1 -1
  23. package/dist/src/packlets/database/data-mirror.test.js +2 -2
  24. package/dist/src/packlets/database/data-mirror.test.js.map +1 -1
  25. package/dist/src/packlets/database/database-backend.d.ts +4 -5
  26. package/dist/src/packlets/database/database-backend.d.ts.map +1 -1
  27. package/dist/src/packlets/database/database-backend.js +5 -6
  28. package/dist/src/packlets/database/database-backend.js.map +1 -1
  29. package/dist/src/packlets/database/item-demuxer.d.ts +2 -2
  30. package/dist/src/packlets/database/item-demuxer.d.ts.map +1 -1
  31. package/dist/src/packlets/database/item-demuxer.js +2 -3
  32. package/dist/src/packlets/database/item-demuxer.js.map +1 -1
  33. package/dist/src/packlets/database/item-demuxer.test.js +13 -9
  34. package/dist/src/packlets/database/item-demuxer.test.js.map +1 -1
  35. package/dist/src/packlets/database/testing.d.ts.map +1 -1
  36. package/dist/src/packlets/database/testing.js +3 -4
  37. package/dist/src/packlets/database/testing.js.map +1 -1
  38. package/dist/src/packlets/database/timeframe-clock.d.ts +1 -0
  39. package/dist/src/packlets/database/timeframe-clock.d.ts.map +1 -1
  40. package/dist/src/packlets/database/timeframe-clock.js +3 -0
  41. package/dist/src/packlets/database/timeframe-clock.js.map +1 -1
  42. package/dist/src/parties/data-party.d.ts +6 -5
  43. package/dist/src/parties/data-party.d.ts.map +1 -1
  44. package/dist/src/parties/data-party.js +26 -5
  45. package/dist/src/parties/data-party.js.map +1 -1
  46. package/dist/src/parties/data-party.test.js +24 -5
  47. package/dist/src/parties/data-party.test.js.map +1 -1
  48. package/dist/src/parties/party-factory.d.ts +5 -4
  49. package/dist/src/parties/party-factory.d.ts.map +1 -1
  50. package/dist/src/parties/party-factory.js +15 -11
  51. package/dist/src/parties/party-factory.js.map +1 -1
  52. package/dist/src/parties/party-manager.d.ts +3 -4
  53. package/dist/src/parties/party-manager.d.ts.map +1 -1
  54. package/dist/src/parties/party-manager.js +8 -7
  55. package/dist/src/parties/party-manager.js.map +1 -1
  56. package/dist/src/parties/party-manager.test.js +9 -9
  57. package/dist/src/parties/party-manager.test.js.map +1 -1
  58. package/dist/src/pipeline/{pipeline.d.ts → feed-muxer.d.ts} +8 -11
  59. package/dist/src/pipeline/feed-muxer.d.ts.map +1 -0
  60. package/dist/src/pipeline/{pipeline.js → feed-muxer.js} +34 -41
  61. package/dist/src/pipeline/feed-muxer.js.map +1 -0
  62. package/dist/src/pipeline/feed-muxer.test.d.ts +2 -0
  63. package/dist/src/pipeline/feed-muxer.test.d.ts.map +1 -0
  64. package/dist/src/pipeline/{pipeline.test.js → feed-muxer.test.js} +17 -15
  65. package/dist/src/pipeline/feed-muxer.test.js.map +1 -0
  66. package/dist/src/pipeline/index.d.ts +2 -2
  67. package/dist/src/pipeline/index.d.ts.map +1 -1
  68. package/dist/src/pipeline/index.js +2 -2
  69. package/dist/src/pipeline/index.js.map +1 -1
  70. package/dist/src/pipeline/message-selector.d.ts.map +1 -1
  71. package/dist/src/pipeline/message-selector.js +6 -5
  72. package/dist/src/pipeline/message-selector.js.map +1 -1
  73. package/dist/src/pipeline/metadata-store.d.ts +2 -1
  74. package/dist/src/pipeline/metadata-store.d.ts.map +1 -1
  75. package/dist/src/pipeline/metadata-store.js +7 -1
  76. package/dist/src/pipeline/metadata-store.js.map +1 -1
  77. package/dist/src/pipeline/party-feed-provider.d.ts +2 -3
  78. package/dist/src/pipeline/party-feed-provider.d.ts.map +1 -1
  79. package/dist/src/pipeline/party-feed-provider.js +2 -17
  80. package/dist/src/pipeline/party-feed-provider.js.map +1 -1
  81. package/dist/src/pipeline/{party-core.d.ts → party-pipeline.d.ts} +23 -9
  82. package/dist/src/pipeline/party-pipeline.d.ts.map +1 -0
  83. package/dist/src/pipeline/{party-core.js → party-pipeline.js} +26 -25
  84. package/dist/src/pipeline/party-pipeline.js.map +1 -0
  85. package/dist/src/pipeline/party-pipeline.test.d.ts +2 -0
  86. package/dist/src/pipeline/party-pipeline.test.d.ts.map +1 -0
  87. package/dist/src/pipeline/{party-core.test.js → party-pipeline.test.js} +50 -33
  88. package/dist/src/pipeline/party-pipeline.test.js.map +1 -0
  89. package/dist/src/snapshots/snapshot-generator.d.ts +2 -2
  90. package/dist/src/snapshots/snapshot-generator.d.ts.map +1 -1
  91. package/dist/src/snapshots/snapshot-generator.js.map +1 -1
  92. package/dist/src/snapshots/snapshot-store.js +1 -1
  93. package/dist/src/snapshots/snapshot-store.js.map +1 -1
  94. package/dist/tsconfig.tsbuildinfo +1 -1
  95. package/package.json +17 -17
  96. package/src/echo.test.ts +15 -4
  97. package/src/echo.ts +1 -0
  98. package/src/halo/halo-factory.ts +6 -6
  99. package/src/halo/halo-party.ts +10 -8
  100. package/src/halo/halo.ts +2 -2
  101. package/src/halo/party-opener.ts +3 -1
  102. package/src/invitations/greeting-initiator.ts +5 -4
  103. package/src/packlets/database/data-mirror.test.ts +2 -2
  104. package/src/packlets/database/database-backend.ts +7 -6
  105. package/src/packlets/database/item-demuxer.test.ts +20 -18
  106. package/src/packlets/database/item-demuxer.ts +5 -4
  107. package/src/packlets/database/testing.ts +3 -6
  108. package/src/packlets/database/timeframe-clock.ts +4 -0
  109. package/src/parties/data-party.test.ts +39 -8
  110. package/src/parties/data-party.ts +31 -9
  111. package/src/parties/party-factory.ts +19 -17
  112. package/src/parties/party-manager.test.ts +15 -9
  113. package/src/parties/party-manager.ts +9 -6
  114. package/src/pipeline/{pipeline.test.ts → feed-muxer.test.ts} +20 -16
  115. package/src/pipeline/{pipeline.ts → feed-muxer.ts} +39 -51
  116. package/src/pipeline/index.ts +2 -2
  117. package/src/pipeline/message-selector.ts +6 -5
  118. package/src/pipeline/metadata-store.ts +8 -2
  119. package/src/pipeline/party-feed-provider.ts +3 -16
  120. package/src/pipeline/{party-core.test.ts → party-pipeline.test.ts} +49 -27
  121. package/src/pipeline/{party-core.ts → party-pipeline.ts} +53 -24
  122. package/src/snapshots/snapshot-generator.ts +2 -2
  123. package/src/snapshots/snapshot-store.ts +1 -1
  124. package/dist/src/pipeline/party-core.d.ts.map +0 -1
  125. package/dist/src/pipeline/party-core.js.map +0 -1
  126. package/dist/src/pipeline/party-core.test.d.ts +0 -2
  127. package/dist/src/pipeline/party-core.test.d.ts.map +0 -1
  128. package/dist/src/pipeline/party-core.test.js.map +0 -1
  129. package/dist/src/pipeline/pipeline.d.ts.map +0 -1
  130. package/dist/src/pipeline/pipeline.js.map +0 -1
  131. package/dist/src/pipeline/pipeline.test.d.ts +0 -2
  132. package/dist/src/pipeline/pipeline.test.d.ts.map +0 -1
  133. package/dist/src/pipeline/pipeline.test.js.map +0 -1
@@ -6,20 +6,20 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
6
6
  return (mod && mod.__esModule) ? mod : { "default": mod };
7
7
  };
8
8
  Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.Pipeline = void 0;
9
+ exports.FeedMuxer = void 0;
10
10
  const assert_1 = __importDefault(require("assert"));
11
11
  const debug_1 = __importDefault(require("debug"));
12
12
  const async_1 = require("@dxos/async");
13
13
  const crypto_1 = require("@dxos/crypto");
14
14
  const debug_2 = require("@dxos/debug");
15
15
  const echo_protocol_1 = require("@dxos/echo-protocol");
16
- const feed_store_1 = require("@dxos/feed-store");
17
16
  const util_1 = require("@dxos/util");
18
17
  const log = (0, debug_1.default)('dxos:echo-db:pipeline');
19
18
  /**
20
19
  * Manages the inbound and outbound message streams for an individual party.
20
+ * Reads messages from individual feeds and splits them into ECHO and HALO streams.
21
21
  */
22
- class Pipeline {
22
+ class FeedMuxer {
23
23
  /**
24
24
  * @param _partyProcessor Processes HALO messages to update party state.
25
25
  * @param _feedStorIterator Inbound messages from the feed store.
@@ -34,16 +34,29 @@ class Pipeline {
34
34
  this._feedWriter = _feedWriter;
35
35
  this._options = _options;
36
36
  this._errors = new async_1.Event();
37
+ this._isOpen = false;
38
+ if (this._feedWriter) {
39
+ const loggingWriter = (0, echo_protocol_1.mapFeedWriter)(async (msg) => {
40
+ var _a, _b;
41
+ (_b = (_a = this._options).writeLogger) === null || _b === void 0 ? void 0 : _b.call(_a, msg);
42
+ return msg;
43
+ }, this._feedWriter);
44
+ this._outboundEchoStream = (0, echo_protocol_1.mapFeedWriter)(async (message) => ({
45
+ timeframe: this._timeframeClock.timeframe,
46
+ echo: message
47
+ }), loggingWriter);
48
+ this._outboundHaloStream = (0, echo_protocol_1.mapFeedWriter)(async (message) => ({
49
+ timeframe: this._timeframeClock.timeframe,
50
+ halo: message
51
+ }), loggingWriter);
52
+ }
37
53
  }
38
54
  get isOpen() {
39
- return this._inboundEchoStream !== undefined;
55
+ return this._isOpen;
40
56
  }
41
57
  get readOnly() {
42
58
  return this._outboundEchoStream === undefined;
43
59
  }
44
- get inboundEchoStream() {
45
- return this._inboundEchoStream;
46
- }
47
60
  get outboundEchoStream() {
48
61
  return this._outboundEchoStream;
49
62
  }
@@ -53,6 +66,9 @@ class Pipeline {
53
66
  get errors() {
54
67
  return this._errors;
55
68
  }
69
+ setEchoProcessor(processor) {
70
+ this._echoProcessor = processor;
71
+ }
56
72
  /**
57
73
  * Create inbound and outbound pipielines.
58
74
  * https://nodejs.org/api/stream.html#stream_stream_pipeline_source_transforms_destination_callback
@@ -64,8 +80,7 @@ class Pipeline {
64
80
  * Feed
65
81
  */
66
82
  async open() {
67
- const { readLogger, writeLogger } = this._options;
68
- this._inboundEchoStream = (0, feed_store_1.createReadable)();
83
+ const { readLogger } = this._options;
69
84
  // This will exit cleanly once FeedStoreIterator is closed.
70
85
  setImmediate(async () => {
71
86
  var _a;
@@ -86,19 +101,18 @@ class Pipeline {
86
101
  // ECHO
87
102
  //
88
103
  if (message.echo) {
89
- this._timeframeClock.updateTimeframe(crypto_1.PublicKey.from(block.key), block.seq);
90
104
  const memberKey = this._partyProcessor.getFeedOwningMember(crypto_1.PublicKey.from(block.key));
91
105
  (0, assert_1.default)(memberKey, `Ownership of feed ${(0, crypto_1.keyToString)(block.key)} could not be determined.`);
92
106
  // Validate messge.
93
107
  const { itemId } = message.echo;
94
108
  if (itemId) {
95
- (0, assert_1.default)(this._inboundEchoStream);
96
- this._inboundEchoStream.push((0, debug_2.checkType)({
109
+ (0, assert_1.default)(this._echoProcessor);
110
+ await this._echoProcessor((0, debug_2.checkType)({
97
111
  meta: {
98
112
  seq: block.seq,
99
113
  feedKey: block.key,
100
114
  memberKey,
101
- timeframe: (_a = message.echo.timeframe) !== null && _a !== void 0 ? _a : new echo_protocol_1.Timeframe()
115
+ timeframe: (_a = message.timeframe) !== null && _a !== void 0 ? _a : new echo_protocol_1.Timeframe()
102
116
  },
103
117
  data: message.echo
104
118
  }));
@@ -108,6 +122,7 @@ class Pipeline {
108
122
  // TODO(burdon): Can we throw and have the pipeline log (without breaking the stream)?
109
123
  log(`Skipping invalid message: ${JSON.stringify(message, util_1.jsonReplacer)}`);
110
124
  }
125
+ this._timeframeClock.updateTimeframe(crypto_1.PublicKey.from(block.key), block.seq);
111
126
  }
112
127
  catch (err) {
113
128
  console.error('Error in message processing.');
@@ -115,28 +130,7 @@ class Pipeline {
115
130
  }
116
131
  }
117
132
  });
118
- //
119
- // Processes outbound messages (piped to the feed).
120
- // Sets the current timeframe.
121
- //
122
- if (this._feedWriter) {
123
- const loggingWriter = (0, echo_protocol_1.mapFeedWriter)(async (msg) => {
124
- writeLogger === null || writeLogger === void 0 ? void 0 : writeLogger(msg);
125
- return msg;
126
- }, this._feedWriter);
127
- this._outboundEchoStream = (0, echo_protocol_1.mapFeedWriter)(async (message) => ({
128
- echo: {
129
- ...message,
130
- timeframe: this._timeframeClock.timeframe
131
- }
132
- }), loggingWriter);
133
- this._outboundHaloStream =
134
- (0, echo_protocol_1.mapFeedWriter)(async (message) => ({ halo: message }), loggingWriter);
135
- }
136
- return [
137
- this._inboundEchoStream,
138
- this._outboundEchoStream
139
- ];
133
+ return this._outboundEchoStream;
140
134
  }
141
135
  /**
142
136
  * Close all streams.
@@ -144,12 +138,11 @@ class Pipeline {
144
138
  // TODO(burdon): Create test that all streams are closed cleanly.
145
139
  async close() {
146
140
  await this._feedStorIterator.close();
147
- if (this._inboundEchoStream) {
148
- this._inboundEchoStream.destroy();
149
- this._inboundEchoStream = undefined;
150
- }
151
141
  this._outboundEchoStream = undefined;
142
+ this._outboundHaloStream = undefined;
143
+ this._echoProcessor = undefined;
144
+ this._isOpen = false;
152
145
  }
153
146
  }
154
- exports.Pipeline = Pipeline;
155
- //# sourceMappingURL=pipeline.js.map
147
+ exports.FeedMuxer = FeedMuxer;
148
+ //# sourceMappingURL=feed-muxer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feed-muxer.js","sourceRoot":"","sources":["../../../src/pipeline/feed-muxer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=feed-muxer.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feed-muxer.test.d.ts","sourceRoot":"","sources":["../../../src/pipeline/feed-muxer.test.ts"],"names":[],"mappings":""}
@@ -18,11 +18,11 @@ const model_factory_1 = require("@dxos/model-factory");
18
18
  const random_access_multi_storage_1 = require("@dxos/random-access-multi-storage");
19
19
  const util_1 = require("@dxos/util");
20
20
  const database_1 = require("../packlets/database");
21
+ const feed_muxer_1 = require("./feed-muxer");
21
22
  const party_processor_1 = require("./party-processor");
22
- const pipeline_1 = require("./pipeline");
23
23
  const log = (0, debug_1.default)('dxos:echo:pipeline:test');
24
24
  // TODO(burdon): Test read-only.
25
- describe('pipeline', () => {
25
+ describe('FeedMuxer', () => {
26
26
  (0, mocha_1.it)('streams', async () => {
27
27
  const storage = (0, random_access_multi_storage_1.createStorage)('', random_access_multi_storage_1.StorageType.RAM);
28
28
  const feedStore = new feed_store_1.FeedStore(storage.directory('feed'), { valueEncoding: echo_protocol_1.codec });
@@ -54,19 +54,19 @@ describe('pipeline', () => {
54
54
  seq: 0
55
55
  }
56
56
  });
57
- const pipeline = new pipeline_1.Pipeline(partyProcessor, feedReadStream, new database_1.TimeframeClock());
58
- const [readStream] = await pipeline.open();
59
- (0, expect_1.default)(readStream).toBeTruthy();
60
57
  //
61
58
  // Pipeline consumer.
62
59
  // TODO(burdon): Check order (re-use feed-store-iterator test logic).
63
60
  //
64
61
  const numMessages = 5;
65
62
  const [counter, updateCounter] = (0, async_1.latch)(numMessages);
66
- readStream.pipe((0, feed_store_1.createWritable)(async (message) => {
63
+ const echoProcessor = async (message) => {
67
64
  log('Processed:', JSON.stringify(message, util_1.jsonReplacer, 2));
68
65
  updateCounter();
69
- }));
66
+ };
67
+ const pipeline = new feed_muxer_1.FeedMuxer(partyProcessor, feedReadStream, new database_1.TimeframeClock());
68
+ pipeline.setEchoProcessor(echoProcessor);
69
+ await pipeline.open();
70
70
  //
71
71
  // Write directly to feed store.
72
72
  // TODO(burdon): Write to multiple feeds.
@@ -95,10 +95,13 @@ describe('pipeline', () => {
95
95
  type: credentials_1.KeyType.FEED
96
96
  });
97
97
  const partyProcessor = new party_processor_1.PartyProcessor(partyKey.publicKey);
98
- const pipeline = new pipeline_1.Pipeline(partyProcessor, feedReadStream, new database_1.TimeframeClock(), (0, echo_protocol_1.createFeedWriter)(feed));
98
+ const echoMessages = [];
99
+ const echoProcessor = async (msg) => {
100
+ echoMessages.push(msg);
101
+ };
102
+ const pipeline = new feed_muxer_1.FeedMuxer(partyProcessor, feedReadStream, new database_1.TimeframeClock(), (0, echo_protocol_1.createFeedWriter)(feed));
103
+ pipeline.setEchoProcessor(echoProcessor);
99
104
  await pipeline.open();
100
- const writable = new feed_store_1.WritableArray();
101
- pipeline.inboundEchoStream.pipe(writable);
102
105
  await pipeline.outboundHaloStream.write((0, credentials_1.createPartyGenesisMessage)(keyring, partyKey, feedKey.publicKey, identityKey));
103
106
  await (0, async_1.waitForCondition)(() => !partyProcessor.genesisRequired);
104
107
  await pipeline.outboundEchoStream.write({
@@ -107,15 +110,14 @@ describe('pipeline', () => {
107
110
  itemType: 'foo'
108
111
  }
109
112
  });
110
- await (0, async_1.waitForCondition)(() => writable.objects.length === 1);
113
+ await (0, async_1.waitForCondition)(() => echoMessages.length === 1);
111
114
  (0, expect_1.default)(partyProcessor.genesisRequired).toEqual(false);
112
- (0, expect_1.default)(writable.objects[0].data).toEqual({
115
+ (0, expect_1.default)(echoMessages[0].data).toEqual({
113
116
  itemId: '123',
114
117
  genesis: {
115
118
  itemType: 'foo'
116
- },
117
- timeframe: expect_1.default.any(echo_protocol_1.Timeframe)
119
+ }
118
120
  });
119
121
  });
120
122
  });
121
- //# sourceMappingURL=pipeline.test.js.map
123
+ //# sourceMappingURL=feed-muxer.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feed-muxer.test.js","sourceRoot":"","sources":["../../../src/pipeline/feed-muxer.test.ts"],"names":[],"mappings":"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"}
@@ -2,7 +2,7 @@ export * from './message-selector';
2
2
  export * from './party-feed-provider';
3
3
  export * from './party-processor';
4
4
  export * from '../protocol/party-protocol-factory';
5
- export * from './pipeline';
6
- export * from './party-core';
5
+ export * from './feed-muxer';
6
+ export * from './party-pipeline';
7
7
  export * from './metadata-store';
8
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/pipeline/index.ts"],"names":[],"mappings":"AAIA,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oCAAoC,CAAC;AACnD,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/pipeline/index.ts"],"names":[],"mappings":"AAIA,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oCAAoC,CAAC;AACnD,cAAc,cAAc,CAAC;AAC7B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC"}
@@ -17,7 +17,7 @@ __exportStar(require("./message-selector"), exports);
17
17
  __exportStar(require("./party-feed-provider"), exports);
18
18
  __exportStar(require("./party-processor"), exports);
19
19
  __exportStar(require("../protocol/party-protocol-factory"), exports);
20
- __exportStar(require("./pipeline"), exports);
21
- __exportStar(require("./party-core"), exports);
20
+ __exportStar(require("./feed-muxer"), exports);
21
+ __exportStar(require("./party-pipeline"), exports);
22
22
  __exportStar(require("./metadata-store"), exports);
23
23
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/pipeline/index.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;;;;;;;AAEF,qDAAmC;AACnC,wDAAsC;AACtC,oDAAkC;AAClC,qEAAmD;AACnD,6CAA2B;AAC3B,+CAA6B;AAC7B,mDAAiC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/pipeline/index.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;;;;;;;AAEF,qDAAmC;AACnC,wDAAsC;AACtC,oDAAkC;AAClC,qEAAmD;AACnD,+CAA6B;AAC7B,mDAAiC;AACjC,mDAAiC"}
@@ -1 +1 @@
1
- {"version":3,"file":"message-selector.d.ts","sourceRoot":"","sources":["../../../src/pipeline/message-selector.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAIvD;;;;;;;;GAQG;AACH,eAAO,MAAM,qBAAqB,mBAAoB,kBAAkB,kBAAkB,cAAc,KAAG,eAuC1G,CAAC"}
1
+ {"version":3,"file":"message-selector.d.ts","sourceRoot":"","sources":["../../../src/pipeline/message-selector.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAIvD;;;;;;;;GAQG;AACH,eAAO,MAAM,qBAAqB,mBAAoB,kBAAkB,kBAAkB,cAAc,KAAG,eAwC1G,CAAC"}
@@ -24,24 +24,25 @@ const log = (0, debug_1.default)('dxos:echo-db:message-selector');
24
24
  const createMessageSelector = (partyProcessor, timeframeClock) => candidates => {
25
25
  // Check ECHO message candidates first since they are less expensive than HALO cancidates.
26
26
  for (let i = 0; i < candidates.length; i++) {
27
- const { data: { echo } } = candidates[i];
27
+ const { data: { timeframe, echo } } = candidates[i];
28
28
  const feedKey = crypto_1.PublicKey.from(candidates[i].key);
29
29
  if (!echo) {
30
30
  continue;
31
31
  }
32
- (0, assert_1.default)(echo.timeframe);
33
- if (partyProcessor.isFeedAdmitted(feedKey) && !timeframeClock.hasGaps(echo.timeframe)) {
32
+ (0, assert_1.default)(timeframe);
33
+ if (partyProcessor.isFeedAdmitted(feedKey) && !timeframeClock.hasGaps(timeframe)) {
34
34
  return i;
35
35
  }
36
36
  }
37
37
  // Check HALO message candidates.
38
38
  for (let i = 0; i < candidates.length; i++) {
39
- const { data: { halo } } = candidates[i];
39
+ const { data: { timeframe, halo } } = candidates[i];
40
40
  const feedKey = crypto_1.PublicKey.from(candidates[i].key);
41
41
  if (!halo) {
42
42
  continue;
43
43
  }
44
- if (partyProcessor.isFeedAdmitted(feedKey)) {
44
+ (0, assert_1.default)(timeframe);
45
+ if (partyProcessor.isFeedAdmitted(feedKey) && !timeframeClock.hasGaps(timeframe)) {
45
46
  return i;
46
47
  }
47
48
  if (partyProcessor.genesisRequired) {
@@ -1 +1 @@
1
- {"version":3,"file":"message-selector.js","sourceRoot":"","sources":["../../../src/pipeline/message-selector.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,oDAA4B;AAC5B,kDAA0B;AAE1B,mDAAmF;AACnF,yCAAyC;AAMzC,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,+BAA+B,CAAC,CAAC;AAEnD;;;;;;;;GAQG;AACI,MAAM,qBAAqB,GAAG,CAAC,cAAkC,EAAE,cAA8B,EAAmB,EAAE,CAAC,UAAU,CAAC,EAAE;IACzI,0FAA0F;IAC1F,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,MAAM,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,OAAO,GAAG,kBAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAClD,IAAI,CAAC,IAAI,EAAE;YACT,SAAS;SACV;QAED,IAAA,gBAAM,EAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,IAAI,cAAc,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;YACrF,OAAO,CAAC,CAAC;SACV;KACF;IAED,iCAAiC;IACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,MAAM,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,OAAO,GAAG,kBAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAClD,IAAI,CAAC,IAAI,EAAE;YACT,SAAS;SACV;QAED,IAAI,cAAc,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE;YAC1C,OAAO,CAAC,CAAC;SACV;QAED,IAAI,cAAc,CAAC,eAAe,EAAE;YAClC,IAAI,EAAE,+EAA+E;gBACnF,8DAA8D;gBAC9D,IAAI,IAAA,2CAA6B,EAAC,IAAI,CAAC,KAAK,6BAAe,CAAC,IAAI,CAAC,aAAa,EAAE;oBAC9E,OAAO,CAAC,CAAC;iBACV;aACF;YAAC,WAAM,GAAG;SACZ;KACF;IAED,kCAAkC;IAClC,GAAG,CAAC,aAAa,CAAC,CAAC;AACrB,CAAC,CAAC;AAvCW,QAAA,qBAAqB,yBAuChC"}
1
+ {"version":3,"file":"message-selector.js","sourceRoot":"","sources":["../../../src/pipeline/message-selector.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,oDAA4B;AAC5B,kDAA0B;AAE1B,mDAAmF;AACnF,yCAAyC;AAMzC,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,+BAA+B,CAAC,CAAC;AAEnD;;;;;;;;GAQG;AACI,MAAM,qBAAqB,GAAG,CAAC,cAAkC,EAAE,cAA8B,EAAmB,EAAE,CAAC,UAAU,CAAC,EAAE;IACzI,0FAA0F;IAC1F,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,MAAM,EAAE,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACpD,MAAM,OAAO,GAAG,kBAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAClD,IAAI,CAAC,IAAI,EAAE;YACT,SAAS;SACV;QAED,IAAA,gBAAM,EAAC,SAAS,CAAC,CAAC;QAClB,IAAI,cAAc,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAChF,OAAO,CAAC,CAAC;SACV;KACF;IAED,iCAAiC;IACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,MAAM,EAAE,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QACpD,MAAM,OAAO,GAAG,kBAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAClD,IAAI,CAAC,IAAI,EAAE;YACT,SAAS;SACV;QAED,IAAA,gBAAM,EAAC,SAAS,CAAC,CAAC;QAClB,IAAI,cAAc,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAChF,OAAO,CAAC,CAAC;SACV;QAED,IAAI,cAAc,CAAC,eAAe,EAAE;YAClC,IAAI,EAAE,+EAA+E;gBACnF,8DAA8D;gBAC9D,IAAI,IAAA,2CAA6B,EAAC,IAAI,CAAC,KAAK,6BAAe,CAAC,IAAI,CAAC,aAAa,EAAE;oBAC9E,OAAO,CAAC,CAAC;iBACV;aACF;YAAC,WAAM,GAAG;SACZ;KACF;IAED,kCAAkC;IAClC,GAAG,CAAC,aAAa,CAAC,CAAC;AACrB,CAAC,CAAC;AAxCW,QAAA,qBAAqB,yBAwChC"}
@@ -1,5 +1,5 @@
1
1
  import { PublicKey } from '@dxos/crypto';
2
- import { PartyMetadata } from '@dxos/echo-protocol';
2
+ import { PartyMetadata, Timeframe } from '@dxos/echo-protocol';
3
3
  import { Directory } from '@dxos/random-access-multi-storage';
4
4
  /**
5
5
  * Version for the schema of the stored data as defined in dxos.echo.metadata.EchoMetadata.
@@ -49,5 +49,6 @@ export declare class MetadataStore {
49
49
  * Checks if a party with given key has a feed with given key.
50
50
  */
51
51
  hasFeed(partyKey: PublicKey, feedKey: PublicKey): boolean;
52
+ setTimeframe(partyKey: PublicKey, timeframe: Timeframe): Promise<void>;
52
53
  }
53
54
  //# sourceMappingURL=metadata-store.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"metadata-store.d.ts","sourceRoot":"","sources":["../../../src/pipeline/metadata-store.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAgB,aAAa,EAAU,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAE9D;;;;GAIG;AACH,eAAO,MAAM,eAAe,IAAI,CAAC;AAIjC,qBAAa,aAAa;IAStB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAR7B,OAAO,CAAC,SAAS,CAKf;gBAGiB,UAAU,EAAE,SAAS;IAGxC,IAAI,OAAO,IAAK,MAAM,CAErB;IAED;;;OAGG;IACH,IAAI,OAAO,IAAK,aAAa,EAAE,CAE9B;IAED;;OAEG;IACG,IAAI,IAAK,OAAO,CAAC,IAAI,CAAC;YAqBd,KAAK;IAkBnB;;OAEG;IACG,KAAK,IAAK,OAAO,CAAC,IAAI,CAAC;IAK7B;;OAEG;IACG,QAAQ,CAAE,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAYnD;;;OAGG;IACG,YAAY,CAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAiB3E;;;;OAIG;IACG,WAAW,CAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAO1E;;OAEG;IACH,QAAQ,CAAE,QAAQ,EAAE,SAAS,GAAG,aAAa,GAAG,SAAS;IAIzD;;OAEG;IACH,OAAO,CAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,OAAO;CAO3D"}
1
+ {"version":3,"file":"metadata-store.d.ts","sourceRoot":"","sources":["../../../src/pipeline/metadata-store.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAgB,aAAa,EAAU,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACrF,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAE9D;;;;GAIG;AACH,eAAO,MAAM,eAAe,IAAI,CAAC;AAIjC,qBAAa,aAAa;IAStB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAR7B,OAAO,CAAC,SAAS,CAKf;gBAGiB,UAAU,EAAE,SAAS;IAGxC,IAAI,OAAO,IAAK,MAAM,CAErB;IAED;;;OAGG;IACH,IAAI,OAAO,IAAK,aAAa,EAAE,CAE9B;IAED;;OAEG;IACG,IAAI,IAAK,OAAO,CAAC,IAAI,CAAC;YAqBd,KAAK;IAkBnB;;OAEG;IACG,KAAK,IAAK,OAAO,CAAC,IAAI,CAAC;IAK7B;;OAEG;IACG,QAAQ,CAAE,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAYnD;;;OAGG;IACG,YAAY,CAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAiB3E;;;;OAIG;IACG,WAAW,CAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAO1E;;OAEG;IACH,QAAQ,CAAE,QAAQ,EAAE,SAAS,GAAG,aAAa,GAAG,SAAS;IAIzD;;OAEG;IACH,OAAO,CAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,GAAG,OAAO;IAQpD,YAAY,CAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;CAK9D"}
@@ -87,7 +87,7 @@ class MetadataStore {
87
87
  */
88
88
  async clear() {
89
89
  log('Clearing all echo metadata...');
90
- await this._directory.destroy();
90
+ await this._directory.delete();
91
91
  }
92
92
  /**
93
93
  * Adds new party to store and saves it in persistent storage.
@@ -155,6 +155,12 @@ class MetadataStore {
155
155
  }
156
156
  return !!((_a = party.feedKeys) === null || _a === void 0 ? void 0 : _a.find(fk => feedKey.equals(fk)));
157
157
  }
158
+ async setTimeframe(partyKey, timeframe) {
159
+ var _a;
160
+ const party = (_a = this.getParty(partyKey)) !== null && _a !== void 0 ? _a : (0, debug_2.failUndefined)();
161
+ party.latestTimeframe = timeframe;
162
+ await this._save();
163
+ }
158
164
  }
159
165
  exports.MetadataStore = MetadataStore;
160
166
  //# sourceMappingURL=metadata-store.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"metadata-store.js","sourceRoot":"","sources":["../../../src/pipeline/metadata-store.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"metadata-store.js","sourceRoot":"","sources":["../../../src/pipeline/metadata-store.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,oDAA4B;AAC5B,kDAA0B;AAG1B,uCAA4C;AAC5C,uDAAqF;AAGrF;;;;GAIG;AACU,QAAA,eAAe,GAAG,CAAC,CAAC;AAEjC,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,qBAAqB,CAAC,CAAC;AAEzC,MAAa,aAAa;IAQxB,YACmB,UAAqB;QAArB,eAAU,GAAV,UAAU,CAAW;QARhC,cAAS,GAAiB;YAChC,OAAO,EAAE,uBAAe;YACxB,OAAO,EAAE,EAAE;YACX,OAAO,EAAE,IAAI,IAAI,EAAE;YACnB,OAAO,EAAE,IAAI,IAAI,EAAE;SACpB,CAAC;IAIC,CAAC;IAEJ,IAAI,OAAO;;QACT,OAAO,MAAA,IAAI,CAAC,SAAS,CAAC,OAAO,mCAAI,CAAC,CAAC;IACrC,CAAC;IAED;;;OAGG;IACH,IAAI,OAAO;;QACT,OAAO,MAAA,IAAI,CAAC,SAAS,CAAC,OAAO,mCAAI,EAAE,CAAC;IACtC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,IAAI;QACR,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC;QAC1D,IAAI;YACF,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;YACnC,IAAI,IAAI,KAAK,CAAC,EAAE;gBACd,OAAO;aACR;YAED,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;YACtC,IAAI,CAAC,SAAS,GAAG,sBAAM,CAAC,eAAe,CAAC,iCAAiC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SACzF;QAAC,OAAO,GAAQ,EAAE;YACjB,IAAI,GAAG,CAAC,IAAI,KAAK,QAAQ,EAAE;gBACzB,OAAO;aACR;iBAAM;gBACL,MAAM,GAAG,CAAC;aACX;SACF;gBAAS;YACR,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;SACpB;IACH,CAAC;IAEO,KAAK,CAAC,KAAK;;QACjB,MAAM,IAAI,GAAiB;YACzB,GAAG,IAAI,CAAC,SAAS;YACjB,OAAO,EAAE,uBAAe;YACxB,OAAO,EAAE,MAAA,IAAI,CAAC,SAAS,CAAC,OAAO,mCAAI,IAAI,IAAI,EAAE;YAC7C,OAAO,EAAE,IAAI,IAAI,EAAE;SACpB,CAAC;QAEF,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC;QAE1D,IAAI;YACF,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,sBAAM,CAAC,eAAe,CAAC,iCAAiC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;YACpG,MAAM,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;SAC9B;gBAAS;YACR,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;SACpB;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAK;QACT,GAAG,CAAC,+BAA+B,CAAC,CAAC;QACrC,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;IACjC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,QAAQ,CAAE,QAAmB;QACjC,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YAC3B,OAAO;SACR;QACD,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE;YAC3B,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAC;SAC9C;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAC;SAChD;QACD,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,YAAY,CAAE,QAAmB,EAAE,OAAkB;QACzD,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,EAAE;YACnC,OAAO;SACR;QACD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YAC5B,MAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;SAC/B;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAA,gBAAM,EAAC,KAAK,CAAC,CAAC;QACd,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC9B;aAAM;YACL,KAAK,CAAC,QAAQ,GAAG,CAAC,OAAO,CAAC,CAAC;SAC5B;QACD,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,WAAW,CAAE,QAAmB,EAAE,OAAkB;;QACxD,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QAC3C,MAAM,KAAK,GAAG,MAAA,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,mCAAI,IAAA,qBAAa,GAAE,CAAC;QACzD,KAAK,CAAC,WAAW,GAAG,OAAO,CAAC;QAC5B,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,QAAQ,CAAE,QAAmB;;QAC3B,OAAO,MAAA,IAAI,CAAC,SAAS,CAAC,OAAO,0CAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,IAAI,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IACxF,CAAC;IAED;;OAEG;IACH,OAAO,CAAE,QAAmB,EAAE,OAAkB;;QAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAI,CAAC,KAAK,EAAE;YACV,OAAO,KAAK,CAAC;SACd;QACD,OAAO,CAAC,CAAC,CAAA,MAAA,KAAK,CAAC,QAAQ,0CAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAA,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,YAAY,CAAE,QAAmB,EAAE,SAAoB;;QAC3D,MAAM,KAAK,GAAG,MAAA,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,mCAAI,IAAA,qBAAa,GAAE,CAAC;QACzD,KAAK,CAAC,eAAe,GAAG,SAAS,CAAC;QAClC,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF;AAjJD,sCAiJC"}
@@ -1,7 +1,7 @@
1
1
  import { Event } from '@dxos/async';
2
2
  import { Keyring } from '@dxos/credentials';
3
3
  import { PublicKey } from '@dxos/crypto';
4
- import { FeedStoreIterator, MessageSelector, Timeframe } from '@dxos/echo-protocol';
4
+ import { FeedSelector, FeedStoreIterator, MessageSelector, Timeframe } from '@dxos/echo-protocol';
5
5
  import { FeedDescriptor, FeedStore } from '@dxos/feed-store';
6
6
  import { MetadataStore } from './metadata-store';
7
7
  export declare class PartyFeedProvider {
@@ -13,11 +13,10 @@ export declare class PartyFeedProvider {
13
13
  readonly feedOpened: Event<FeedDescriptor>;
14
14
  constructor(_metadataStore: MetadataStore, _keyring: Keyring, _feedStore: FeedStore, _partyKey: PublicKey);
15
15
  getFeeds(): FeedDescriptor[];
16
- openKnownFeeds(): Promise<void>;
17
16
  createOrOpenWritableFeed(): Promise<FeedDescriptor>;
18
17
  createOrOpenReadOnlyFeed(feedKey: PublicKey): Promise<FeedDescriptor>;
19
18
  private _trackFeed;
20
19
  private _createReadWriteFeed;
21
- createIterator(messageSelector: MessageSelector, initialTimeframe?: Timeframe): Promise<FeedStoreIterator>;
20
+ createIterator(messageSelector: MessageSelector, feedSelector: FeedSelector, initialTimeframe?: Timeframe): Promise<FeedStoreIterator>;
22
21
  }
23
22
  //# sourceMappingURL=party-feed-provider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"party-feed-provider.d.ts","sourceRoot":"","sources":["../../../src/pipeline/party-feed-provider.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,KAAK,EAAgB,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,OAAO,EAAW,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACpF,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAG7D,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAMjD,qBAAa,iBAAiB;IAK1B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAP5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4D;IACnF,QAAQ,CAAC,UAAU,wBAA+B;gBAG/B,cAAc,EAAE,aAAa,EAC7B,QAAQ,EAAE,OAAO,EACjB,UAAU,EAAE,SAAS,EACrB,SAAS,EAAE,SAAS;IAGvC,QAAQ,IAAK,cAAc,EAAE;IAKvB,cAAc;IAad,wBAAwB;IAqBxB,wBAAwB,CAAE,OAAO,EAAE,SAAS,GAAG,OAAO,CAAC,cAAc,CAAC;IAc5E,OAAO,CAAC,UAAU;YAWJ,oBAAoB;IAU5B,cAAc,CAAE,eAAe,EAAE,eAAe,EAAE,gBAAgB,CAAC,EAAE,SAAS;CAkBrF"}
1
+ {"version":3,"file":"party-feed-provider.d.ts","sourceRoot":"","sources":["../../../src/pipeline/party-feed-provider.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,KAAK,EAAgB,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,OAAO,EAAW,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAClG,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAG7D,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAMjD,qBAAa,iBAAiB;IAK1B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAP5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4D;IACnF,QAAQ,CAAC,UAAU,wBAA+B;gBAG/B,cAAc,EAAE,aAAa,EAC7B,QAAQ,EAAE,OAAO,EACjB,UAAU,EAAE,SAAS,EACrB,SAAS,EAAE,SAAS;IAGvC,QAAQ,IAAK,cAAc,EAAE;IAKvB,wBAAwB;IAqBxB,wBAAwB,CAAE,OAAO,EAAE,SAAS,GAAG,OAAO,CAAC,cAAc,CAAC;IAc5E,OAAO,CAAC,UAAU;YAWJ,oBAAoB;IAU5B,cAAc,CAAE,eAAe,EAAE,eAAe,EAAE,YAAY,EAAE,YAAY,EAAE,gBAAgB,CAAC,EAAE,SAAS;CAkBjH"}
@@ -34,18 +34,6 @@ class PartyFeedProvider {
34
34
  getFeeds() {
35
35
  return Array.from(this._feeds.values());
36
36
  }
37
- async openKnownFeeds() {
38
- var _a, _b;
39
- for (const feedKey of (_b = (_a = this._metadataStore.getParty(this._partyKey)) === null || _a === void 0 ? void 0 : _a.feedKeys) !== null && _b !== void 0 ? _b : []) {
40
- if (!this._feeds.has(feedKey)) {
41
- const fullKey = this._keyring.getFullKey(feedKey);
42
- const feed = (fullKey === null || fullKey === void 0 ? void 0 : fullKey.secretKey)
43
- ? await this._feedStore.openReadWriteFeed(fullKey.publicKey, fullKey.secretKey)
44
- : await this._feedStore.openReadOnlyFeed(feedKey);
45
- this._trackFeed(feed);
46
- }
47
- }
48
- }
49
37
  async createOrOpenWritableFeed() {
50
38
  const partyMetadata = this._metadataStore.getParty(this._partyKey);
51
39
  if (!(partyMetadata === null || partyMetadata === void 0 ? void 0 : partyMetadata.dataFeedKey)) {
@@ -92,8 +80,8 @@ class PartyFeedProvider {
92
80
  this._trackFeed(feed);
93
81
  return feed;
94
82
  }
95
- async createIterator(messageSelector, initialTimeframe) {
96
- const iterator = new echo_protocol_1.FeedStoreIterator(() => true, messageSelector, initialTimeframe !== null && initialTimeframe !== void 0 ? initialTimeframe : new echo_protocol_1.Timeframe());
83
+ async createIterator(messageSelector, feedSelector, initialTimeframe) {
84
+ const iterator = new echo_protocol_1.FeedStoreIterator(feedSelector, messageSelector, initialTimeframe !== null && initialTimeframe !== void 0 ? initialTimeframe : new echo_protocol_1.Timeframe());
97
85
  for (const feed of this._feeds.values()) {
98
86
  iterator.addFeedDescriptor(feed);
99
87
  }
@@ -109,9 +97,6 @@ class PartyFeedProvider {
109
97
  return iterator;
110
98
  }
111
99
  }
112
- __decorate([
113
- async_1.synchronized
114
- ], PartyFeedProvider.prototype, "openKnownFeeds", null);
115
100
  __decorate([
116
101
  async_1.synchronized
117
102
  ], PartyFeedProvider.prototype, "createOrOpenWritableFeed", null);
@@ -1 +1 @@
1
- {"version":3,"file":"party-feed-provider.js","sourceRoot":"","sources":["../../../src/pipeline/party-feed-provider.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"party-feed-provider.js","sourceRoot":"","sources":["../../../src/pipeline/party-feed-provider.ts"],"names":[],"mappings":"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"}
@@ -1,17 +1,32 @@
1
- import { KeyHint, Message as HaloMessage } from '@dxos/credentials';
1
+ import { Message as HaloMessage } from '@dxos/credentials';
2
2
  import { PublicKey } from '@dxos/crypto';
3
3
  import { FeedWriter, PartyKey, PartySnapshot, Timeframe } from '@dxos/echo-protocol';
4
4
  import { ModelFactory } from '@dxos/model-factory';
5
+ import { PartyProcessor, PartyFeedProvider, FeedMuxer } from '.';
5
6
  import { Database } from '../packlets/database';
6
- import { PartyProcessor, PartyFeedProvider, Pipeline } from '../pipeline';
7
7
  import { SnapshotStore } from '../snapshots';
8
- export interface PartyOptions {
8
+ export interface PipelineOptions {
9
9
  readLogger?: (msg: any) => void;
10
10
  writeLogger?: (msg: any) => void;
11
11
  readOnly?: boolean;
12
12
  snapshots?: boolean;
13
13
  snapshotInterval?: number;
14
14
  }
15
+ export interface OpenOptions {
16
+ /**
17
+ * Keys of initial feeds needed to bootstrap the party.
18
+ */
19
+ feedHints?: PublicKey[];
20
+ /**
21
+ * Timeframe to start processing feed messages from.
22
+ */
23
+ initialTimeframe?: Timeframe;
24
+ /**
25
+ * Timeframe which must be reached until further processing.
26
+ * PartyCore.open will block until this timeframe is reached.
27
+ */
28
+ targetTimeframe?: Timeframe;
29
+ }
15
30
  /**
16
31
  * Encapsulates core components needed by a party:
17
32
  * - ECHO database with item-manager & item-demuxer.
@@ -20,13 +35,12 @@ export interface PartyOptions {
20
35
  *
21
36
  * The core class also handles the combined ECHO and HALO state snapshots.
22
37
  */
23
- export declare class PartyCore {
38
+ export declare class PartyPipeline {
24
39
  private readonly _partyKey;
25
40
  private readonly _feedProvider;
26
41
  private readonly _modelFactory;
27
42
  private readonly _snapshotStore;
28
43
  private readonly _memberKey;
29
- private readonly _initialTimeframe?;
30
44
  private readonly _options;
31
45
  /**
32
46
  * Snapshot to be restored from when party.open() is called.
@@ -37,12 +51,12 @@ export declare class PartyCore {
37
51
  private _pipeline?;
38
52
  private _partyProcessor?;
39
53
  private _timeframeClock?;
40
- constructor(_partyKey: PartyKey, _feedProvider: PartyFeedProvider, _modelFactory: ModelFactory, _snapshotStore: SnapshotStore, _memberKey: PublicKey, _initialTimeframe?: Timeframe | undefined, _options?: PartyOptions);
54
+ constructor(_partyKey: PartyKey, _feedProvider: PartyFeedProvider, _modelFactory: ModelFactory, _snapshotStore: SnapshotStore, _memberKey: PublicKey, _options?: PipelineOptions);
41
55
  get key(): PartyKey;
42
56
  get isOpen(): boolean;
43
57
  get database(): Database;
44
58
  get processor(): PartyProcessor;
45
- get pipeline(): Pipeline;
59
+ get pipeline(): FeedMuxer;
46
60
  get timeframe(): Timeframe;
47
61
  get timeframeUpdate(): import("@dxos/async").Event<Timeframe>;
48
62
  getWriteFeed(): Promise<import("@dxos/feed-store").FeedDescriptor>;
@@ -50,7 +64,7 @@ export declare class PartyCore {
50
64
  /**
51
65
  * Opens the pipeline and connects the streams.
52
66
  */
53
- open(keyHints?: KeyHint[]): Promise<this>;
67
+ open(options?: OpenOptions): Promise<this>;
54
68
  /**
55
69
  * Closes the pipeline and streams.
56
70
  */
@@ -61,4 +75,4 @@ export declare class PartyCore {
61
75
  createSnapshot(): PartySnapshot;
62
76
  restoreFromSnapshot(snapshot: PartySnapshot): Promise<void>;
63
77
  }
64
- //# sourceMappingURL=party-core.d.ts.map
78
+ //# sourceMappingURL=party-pipeline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"party-pipeline.d.ts","sourceRoot":"","sources":["../../../src/pipeline/party-pipeline.ts"],"names":[],"mappings":"AAOA,OAAO,EAAW,OAAO,IAAI,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAoD,UAAU,EAAE,QAAQ,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACvI,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAGnD,OAAO,EAAyB,cAAc,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,GAAG,CAAC;AACxF,OAAO,EAAE,QAAQ,EAAuC,MAAM,sBAAsB,CAAC;AACrF,OAAO,EAA4B,aAAa,EAAE,MAAM,cAAc,CAAC;AAIvE,MAAM,WAAW,eAAe;IAC9B,UAAU,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,IAAI,CAAC;IAChC,WAAW,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,IAAI,CAAC;IACjC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAGnB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,WAAW;IAC1B;;OAEG;IACH,SAAS,CAAC,EAAE,SAAS,EAAE,CAAA;IACvB;;OAEG;IACH,gBAAgB,CAAC,EAAE,SAAS,CAAA;IAC5B;;;OAGG;IACH,eAAe,CAAC,EAAE,SAAS,CAAA;CAC5B;AAED;;;;;;;GAOG;AACH,qBAAa,aAAa;IActB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IAlB3B;;OAEG;IACH,OAAO,CAAC,iBAAiB,CAA+B;IAExD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA2B;IAE1D,OAAO,CAAC,SAAS,CAAC,CAAW;IAC7B,OAAO,CAAC,SAAS,CAAC,CAAY;IAC9B,OAAO,CAAC,eAAe,CAAC,CAAiB;IACzC,OAAO,CAAC,eAAe,CAAC,CAAiB;gBAGtB,SAAS,EAAE,QAAQ,EACnB,aAAa,EAAE,iBAAiB,EAChC,aAAa,EAAE,YAAY,EAC3B,cAAc,EAAE,aAAa,EAC7B,UAAU,EAAE,SAAS,EACrB,QAAQ,GAAE,eAAoB;IAGjD,IAAI,GAAG,IAAK,QAAQ,CAEnB;IAED,IAAI,MAAM,IAAK,OAAO,CAErB;IAED,IAAI,QAAQ,IAAK,QAAQ,CAGxB;IAED,IAAI,SAAS,mBAGZ;IAED,IAAI,QAAQ,cAGX;IAED,IAAI,SAAS,cAGZ;IAED,IAAI,eAAe,2CAGlB;IAEK,YAAY;IAMlB,IAAI,iBAAiB,IAAK,UAAU,CAAC,WAAW,CAAC,CAGhD;IAED;;OAEG;IAGG,IAAI,CAAE,OAAO,GAAE,WAAgB;IAkFrC;;OAEG;IAEG,KAAK;IAmBX;;OAEG;IACH,cAAc,IAAK,aAAa;IAY1B,mBAAmB,CAAE,QAAQ,EAAE,aAAa;CAWnD"}