@dxos/echo-pipeline 0.8.4-main.bc674ce → 0.8.4-main.bcb3aa67d6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/{browser/chunk-WIQUYO7H.mjs → neutral/chunk-DN4YBAWV.mjs} +35 -41
- package/dist/lib/neutral/chunk-DN4YBAWV.mjs.map +7 -0
- package/dist/lib/{browser/chunk-FJPXA75J.mjs → neutral/chunk-IMPFMBJK.mjs} +7 -1
- package/dist/lib/neutral/chunk-IMPFMBJK.mjs.map +7 -0
- package/dist/lib/{browser → neutral}/filter/index.mjs +1 -1
- package/dist/lib/{browser → neutral}/index.mjs +1428 -1288
- package/dist/lib/neutral/index.mjs.map +7 -0
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/lib/{browser → neutral}/testing/index.mjs +4 -4
- package/dist/lib/{browser → neutral}/testing/index.mjs.map +3 -3
- package/dist/types/src/automerge/automerge-host.d.ts +9 -12
- package/dist/types/src/automerge/automerge-host.d.ts.map +1 -1
- package/dist/types/src/automerge/automerge-repo.test.d.ts.map +1 -1
- package/dist/types/src/automerge/echo-network-adapter.d.ts +7 -6
- package/dist/types/src/automerge/echo-network-adapter.d.ts.map +1 -1
- package/dist/types/src/automerge/echo-replicator.d.ts +11 -10
- package/dist/types/src/automerge/echo-replicator.d.ts.map +1 -1
- package/dist/types/src/automerge/heads-store.d.ts.map +1 -1
- package/dist/types/src/automerge/mesh-echo-replicator-connection.d.ts +2 -2
- package/dist/types/src/automerge/mesh-echo-replicator-connection.d.ts.map +1 -1
- package/dist/types/src/automerge/mesh-echo-replicator.d.ts +6 -5
- package/dist/types/src/automerge/mesh-echo-replicator.d.ts.map +1 -1
- package/dist/types/src/db-host/automerge-data-source.d.ts +2 -1
- package/dist/types/src/db-host/automerge-data-source.d.ts.map +1 -1
- package/dist/types/src/db-host/data-service.d.ts.map +1 -1
- package/dist/types/src/db-host/documents-synchronizer.d.ts +2 -2
- package/dist/types/src/db-host/documents-synchronizer.d.ts.map +1 -1
- package/dist/types/src/db-host/echo-host.d.ts +33 -35
- package/dist/types/src/db-host/echo-host.d.ts.map +1 -1
- package/dist/types/src/db-host/local-queue-service.d.ts +5 -2
- package/dist/types/src/db-host/local-queue-service.d.ts.map +1 -1
- package/dist/types/src/db-host/query-service.d.ts +8 -8
- package/dist/types/src/db-host/query-service.d.ts.map +1 -1
- package/dist/types/src/db-host/queue-data-source.d.ts +11 -1
- package/dist/types/src/db-host/queue-data-source.d.ts.map +1 -1
- package/dist/types/src/db-host/stub.d.ts +2 -1
- package/dist/types/src/db-host/stub.d.ts.map +1 -1
- package/dist/types/src/edge/echo-edge-replicator.d.ts +5 -4
- package/dist/types/src/edge/echo-edge-replicator.d.ts.map +1 -1
- package/dist/types/src/filter/filter-match.d.ts.map +1 -1
- package/dist/types/src/query/plan.d.ts +30 -13
- package/dist/types/src/query/plan.d.ts.map +1 -1
- package/dist/types/src/query/query-executor.d.ts +15 -15
- package/dist/types/src/query/query-executor.d.ts.map +1 -1
- package/dist/types/src/query/query-planner.d.ts +4 -1
- package/dist/types/src/query/query-planner.d.ts.map +1 -1
- package/dist/types/src/space/control-pipeline.d.ts +2 -1
- package/dist/types/src/space/control-pipeline.d.ts.map +1 -1
- package/dist/types/src/space/space-manager.d.ts +2 -1
- package/dist/types/src/space/space-manager.d.ts.map +1 -1
- package/dist/types/src/space/space-protocol.d.ts +3 -2
- package/dist/types/src/space/space-protocol.d.ts.map +1 -1
- package/dist/types/src/space/space.d.ts +2 -2
- package/dist/types/src/space/space.d.ts.map +1 -1
- package/dist/types/src/testing/test-replicator.d.ts +8 -8
- package/dist/types/src/testing/test-replicator.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +44 -49
- package/src/automerge/automerge-host.test.ts +8 -10
- package/src/automerge/automerge-host.ts +25 -42
- package/src/automerge/automerge-repo.test.ts +2 -1
- package/src/automerge/echo-network-adapter.test.ts +2 -1
- package/src/automerge/echo-network-adapter.ts +17 -17
- package/src/automerge/echo-replicator.ts +11 -10
- package/src/automerge/heads-store.ts +28 -1
- package/src/automerge/mesh-echo-replicator-connection.ts +2 -2
- package/src/automerge/mesh-echo-replicator.ts +13 -9
- package/src/db-host/automerge-data-source.test.ts +31 -25
- package/src/db-host/automerge-data-source.ts +48 -5
- package/src/db-host/data-service.ts +4 -3
- package/src/db-host/documents-synchronizer.test.ts +0 -4
- package/src/db-host/documents-synchronizer.ts +5 -3
- package/src/db-host/echo-host.ts +128 -141
- package/src/db-host/local-queue-service.ts +45 -46
- package/src/db-host/query-service.ts +21 -109
- package/src/db-host/queue-data-source.ts +50 -23
- package/src/db-host/queue-service.test.ts +15 -11
- package/src/db-host/space-state-manager.ts +1 -1
- package/src/db-host/stub.ts +5 -0
- package/src/edge/echo-edge-replicator.test.ts +9 -8
- package/src/edge/echo-edge-replicator.ts +27 -22
- package/src/filter/filter-match.test.ts +10 -0
- package/src/filter/filter-match.ts +13 -5
- package/src/metadata/metadata-store.ts +3 -3
- package/src/query/plan.ts +35 -17
- package/src/query/query-executor.ts +545 -378
- package/src/query/query-planner.test.ts +457 -163
- package/src/query/query-planner.ts +208 -55
- package/src/space/control-pipeline.test.ts +2 -1
- package/src/space/control-pipeline.ts +2 -3
- package/src/space/space-manager.ts +7 -3
- package/src/space/space-protocol.browser.test.ts +13 -12
- package/src/space/space-protocol.test.ts +13 -12
- package/src/space/space-protocol.ts +5 -4
- package/src/space/space.test.ts +2 -2
- package/src/space/space.ts +5 -5
- package/src/testing/test-replicator.ts +11 -11
- package/dist/lib/browser/chunk-FJPXA75J.mjs.map +0 -7
- package/dist/lib/browser/chunk-WIQUYO7H.mjs.map +0 -7
- package/dist/lib/browser/index.mjs.map +0 -7
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/node-esm/chunk-7PL6UK4B.mjs +0 -2154
- package/dist/lib/node-esm/chunk-7PL6UK4B.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-S5KGVQFZ.mjs +0 -235
- package/dist/lib/node-esm/chunk-S5KGVQFZ.mjs.map +0 -7
- package/dist/lib/node-esm/filter/index.mjs +0 -12
- package/dist/lib/node-esm/filter/index.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -6805
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/testing/index.mjs +0 -591
- package/dist/lib/node-esm/testing/index.mjs.map +0 -7
- package/dist/types/src/db-host/documents-iterator.d.ts +0 -7
- package/dist/types/src/db-host/documents-iterator.d.ts.map +0 -1
- package/src/db-host/documents-iterator.ts +0 -76
- /package/dist/lib/{browser → neutral}/filter/index.mjs.map +0 -0
|
@@ -1209,7 +1209,7 @@ var ControlPipeline = class {
|
|
|
1209
1209
|
await this._pipeline.addFeed(feed);
|
|
1210
1210
|
this._pipeline.setWriteFeed(feed);
|
|
1211
1211
|
}
|
|
1212
|
-
async start() {
|
|
1212
|
+
async start(ctx) {
|
|
1213
1213
|
const snapshot = this._metadata.getSpaceControlPipelineSnapshot(this._spaceKey);
|
|
1214
1214
|
log6("load snapshot", {
|
|
1215
1215
|
key: this._spaceKey,
|
|
@@ -1231,10 +1231,7 @@ var ControlPipeline = class {
|
|
|
1231
1231
|
C: (f, a) => f(...a)
|
|
1232
1232
|
});
|
|
1233
1233
|
setTimeout(async () => {
|
|
1234
|
-
void this._consumePipeline(
|
|
1235
|
-
F: __dxlog_file7,
|
|
1236
|
-
L: 133
|
|
1237
|
-
}));
|
|
1234
|
+
void this._consumePipeline(ctx);
|
|
1238
1235
|
});
|
|
1239
1236
|
await this._pipeline.start();
|
|
1240
1237
|
log6("started", void 0, {
|
|
@@ -1293,7 +1290,7 @@ var ControlPipeline = class {
|
|
|
1293
1290
|
} catch (err) {
|
|
1294
1291
|
log6.catch(err, void 0, {
|
|
1295
1292
|
F: __dxlog_file7,
|
|
1296
|
-
L:
|
|
1293
|
+
L: 178,
|
|
1297
1294
|
S: this,
|
|
1298
1295
|
C: (f, a) => f(...a)
|
|
1299
1296
|
});
|
|
@@ -1307,7 +1304,7 @@ var ControlPipeline = class {
|
|
|
1307
1304
|
seq: msg.seq
|
|
1308
1305
|
}, {
|
|
1309
1306
|
F: __dxlog_file7,
|
|
1310
|
-
L:
|
|
1307
|
+
L: 187,
|
|
1311
1308
|
S: this,
|
|
1312
1309
|
C: (f, a) => f(...a)
|
|
1313
1310
|
});
|
|
@@ -1322,7 +1319,7 @@ var ControlPipeline = class {
|
|
|
1322
1319
|
msg
|
|
1323
1320
|
}, {
|
|
1324
1321
|
F: __dxlog_file7,
|
|
1325
|
-
L:
|
|
1322
|
+
L: 196,
|
|
1326
1323
|
S: this,
|
|
1327
1324
|
C: (f, a) => f(...a)
|
|
1328
1325
|
});
|
|
@@ -1341,7 +1338,7 @@ var ControlPipeline = class {
|
|
|
1341
1338
|
async stop() {
|
|
1342
1339
|
log6("stopping...", void 0, {
|
|
1343
1340
|
F: __dxlog_file7,
|
|
1344
|
-
L:
|
|
1341
|
+
L: 216,
|
|
1345
1342
|
S: this,
|
|
1346
1343
|
C: (f, a) => f(...a)
|
|
1347
1344
|
});
|
|
@@ -1350,7 +1347,7 @@ var ControlPipeline = class {
|
|
|
1350
1347
|
await this._saveTargetTimeframe(this._pipeline.state.timeframe);
|
|
1351
1348
|
log6("stopped", void 0, {
|
|
1352
1349
|
F: __dxlog_file7,
|
|
1353
|
-
L:
|
|
1350
|
+
L: 220,
|
|
1354
1351
|
S: this,
|
|
1355
1352
|
C: (f, a) => f(...a)
|
|
1356
1353
|
});
|
|
@@ -1363,7 +1360,7 @@ var ControlPipeline = class {
|
|
|
1363
1360
|
} catch (err) {
|
|
1364
1361
|
log6(err, void 0, {
|
|
1365
1362
|
F: __dxlog_file7,
|
|
1366
|
-
L:
|
|
1363
|
+
L: 229,
|
|
1367
1364
|
S: this,
|
|
1368
1365
|
C: (f, a) => f(...a)
|
|
1369
1366
|
});
|
|
@@ -1381,9 +1378,6 @@ _ts_decorate4([
|
|
|
1381
1378
|
showInBrowserTimeline: true
|
|
1382
1379
|
})
|
|
1383
1380
|
], ControlPipeline.prototype, "start", null);
|
|
1384
|
-
_ts_decorate4([
|
|
1385
|
-
trace.span()
|
|
1386
|
-
], ControlPipeline.prototype, "_consumePipeline", null);
|
|
1387
1381
|
_ts_decorate4([
|
|
1388
1382
|
trace.span()
|
|
1389
1383
|
], ControlPipeline.prototype, "_processMessage", null);
|
|
@@ -1568,7 +1562,7 @@ var Space = class extends Resource {
|
|
|
1568
1562
|
S: this,
|
|
1569
1563
|
C: (f, a) => f(...a)
|
|
1570
1564
|
});
|
|
1571
|
-
await this._controlPipeline.start();
|
|
1565
|
+
await this._controlPipeline.start(ctx);
|
|
1572
1566
|
log7("opened", void 0, {
|
|
1573
1567
|
F: __dxlog_file8,
|
|
1574
1568
|
L: 182,
|
|
@@ -1576,7 +1570,7 @@ var Space = class extends Resource {
|
|
|
1576
1570
|
C: (f, a) => f(...a)
|
|
1577
1571
|
});
|
|
1578
1572
|
}
|
|
1579
|
-
async startProtocol() {
|
|
1573
|
+
async startProtocol(ctx) {
|
|
1580
1574
|
invariant6(this.isOpen, void 0, {
|
|
1581
1575
|
F: __dxlog_file8,
|
|
1582
1576
|
L: 187,
|
|
@@ -1586,10 +1580,10 @@ var Space = class extends Resource {
|
|
|
1586
1580
|
""
|
|
1587
1581
|
]
|
|
1588
1582
|
});
|
|
1589
|
-
await this.protocol.start();
|
|
1583
|
+
await this.protocol.start(ctx);
|
|
1590
1584
|
await this.protocol.addFeed(await this._feedProvider(this._genesisFeedKey));
|
|
1591
1585
|
}
|
|
1592
|
-
async _close() {
|
|
1586
|
+
async _close(ctx) {
|
|
1593
1587
|
log7("closing...", {
|
|
1594
1588
|
key: this._key
|
|
1595
1589
|
}, {
|
|
@@ -1598,7 +1592,7 @@ var Space = class extends Resource {
|
|
|
1598
1592
|
S: this,
|
|
1599
1593
|
C: (f, a) => f(...a)
|
|
1600
1594
|
});
|
|
1601
|
-
await this.protocol.stop();
|
|
1595
|
+
await this.protocol.stop(ctx);
|
|
1602
1596
|
await this._controlPipeline.stop();
|
|
1603
1597
|
log7("closed", void 0, {
|
|
1604
1598
|
F: __dxlog_file8,
|
|
@@ -1774,7 +1768,7 @@ var SpaceProtocol = class {
|
|
|
1774
1768
|
key: feed.key
|
|
1775
1769
|
}, {
|
|
1776
1770
|
F: __dxlog_file10,
|
|
1777
|
-
L:
|
|
1771
|
+
L: 132,
|
|
1778
1772
|
S: this,
|
|
1779
1773
|
C: (f, a) => f(...a)
|
|
1780
1774
|
});
|
|
@@ -1785,7 +1779,7 @@ var SpaceProtocol = class {
|
|
|
1785
1779
|
await this.feedAdded.callSerial(feed);
|
|
1786
1780
|
}
|
|
1787
1781
|
// TODO(burdon): Rename open? Common open/close interfaces for all services?
|
|
1788
|
-
async start() {
|
|
1782
|
+
async start(ctx) {
|
|
1789
1783
|
if (this._connection) {
|
|
1790
1784
|
return;
|
|
1791
1785
|
}
|
|
@@ -1793,12 +1787,12 @@ var SpaceProtocol = class {
|
|
|
1793
1787
|
await this.blobSync.open();
|
|
1794
1788
|
log8("starting...", void 0, {
|
|
1795
1789
|
F: __dxlog_file10,
|
|
1796
|
-
L:
|
|
1790
|
+
L: 153,
|
|
1797
1791
|
S: this,
|
|
1798
1792
|
C: (f, a) => f(...a)
|
|
1799
1793
|
});
|
|
1800
1794
|
const topic = await this._topic;
|
|
1801
|
-
this._connection = await this._networkManager.joinSwarm({
|
|
1795
|
+
this._connection = await this._networkManager.joinSwarm(ctx, {
|
|
1802
1796
|
protocolProvider: this._createProtocolProvider(credentials),
|
|
1803
1797
|
topic,
|
|
1804
1798
|
topology: this._topology,
|
|
@@ -1806,7 +1800,7 @@ var SpaceProtocol = class {
|
|
|
1806
1800
|
});
|
|
1807
1801
|
log8("started", void 0, {
|
|
1808
1802
|
F: __dxlog_file10,
|
|
1809
|
-
L:
|
|
1803
|
+
L: 162,
|
|
1810
1804
|
S: this,
|
|
1811
1805
|
C: (f, a) => f(...a)
|
|
1812
1806
|
});
|
|
@@ -1814,19 +1808,19 @@ var SpaceProtocol = class {
|
|
|
1814
1808
|
updateTopology() {
|
|
1815
1809
|
this._topology.forceUpdate();
|
|
1816
1810
|
}
|
|
1817
|
-
async stop() {
|
|
1811
|
+
async stop(ctx) {
|
|
1818
1812
|
await this.blobSync.close();
|
|
1819
1813
|
if (this._connection) {
|
|
1820
1814
|
log8("stopping...", void 0, {
|
|
1821
1815
|
F: __dxlog_file10,
|
|
1822
|
-
L:
|
|
1816
|
+
L: 173,
|
|
1823
1817
|
S: this,
|
|
1824
1818
|
C: (f, a) => f(...a)
|
|
1825
1819
|
});
|
|
1826
|
-
await this._connection.close();
|
|
1820
|
+
await this._connection.close(ctx);
|
|
1827
1821
|
log8("stopped", void 0, {
|
|
1828
1822
|
F: __dxlog_file10,
|
|
1829
|
-
L:
|
|
1823
|
+
L: 175,
|
|
1830
1824
|
S: this,
|
|
1831
1825
|
C: (f, a) => f(...a)
|
|
1832
1826
|
});
|
|
@@ -1909,7 +1903,7 @@ var SpaceProtocolSession = class {
|
|
|
1909
1903
|
onAuthSuccess: () => {
|
|
1910
1904
|
log8("Peer authenticated", void 0, {
|
|
1911
1905
|
F: __dxlog_file10,
|
|
1912
|
-
L:
|
|
1906
|
+
L: 286,
|
|
1913
1907
|
S: this,
|
|
1914
1908
|
C: (f, a) => f(...a)
|
|
1915
1909
|
});
|
|
@@ -1929,7 +1923,7 @@ var SpaceProtocolSession = class {
|
|
|
1929
1923
|
async close() {
|
|
1930
1924
|
log8("close", void 0, {
|
|
1931
1925
|
F: __dxlog_file10,
|
|
1932
|
-
L:
|
|
1926
|
+
L: 305,
|
|
1933
1927
|
S: this,
|
|
1934
1928
|
C: (f, a) => f(...a)
|
|
1935
1929
|
});
|
|
@@ -1993,7 +1987,7 @@ var SpaceManager = class {
|
|
|
1993
1987
|
id: this._instanceId
|
|
1994
1988
|
}), {
|
|
1995
1989
|
F: __dxlog_file11,
|
|
1996
|
-
L:
|
|
1990
|
+
L: 104,
|
|
1997
1991
|
S: this,
|
|
1998
1992
|
C: (f, a) => f(...a)
|
|
1999
1993
|
});
|
|
@@ -2001,7 +1995,7 @@ var SpaceManager = class {
|
|
|
2001
1995
|
spaceKey: metadata.genesisFeedKey
|
|
2002
1996
|
}, {
|
|
2003
1997
|
F: __dxlog_file11,
|
|
2004
|
-
L:
|
|
1998
|
+
L: 105,
|
|
2005
1999
|
S: this,
|
|
2006
2000
|
C: (f, a) => f(...a)
|
|
2007
2001
|
});
|
|
@@ -2033,19 +2027,19 @@ var SpaceManager = class {
|
|
|
2033
2027
|
id: this._instanceId
|
|
2034
2028
|
}), {
|
|
2035
2029
|
F: __dxlog_file11,
|
|
2036
|
-
L:
|
|
2030
|
+
L: 135,
|
|
2037
2031
|
S: this,
|
|
2038
2032
|
C: (f, a) => f(...a)
|
|
2039
2033
|
});
|
|
2040
2034
|
return space;
|
|
2041
2035
|
}
|
|
2042
|
-
async requestSpaceAdmissionCredential(params) {
|
|
2036
|
+
async requestSpaceAdmissionCredential(ctx, params) {
|
|
2043
2037
|
const traceKey = "dxos.echo.space-manager.request-space-admission";
|
|
2044
2038
|
log9.trace(traceKey, trace4.begin({
|
|
2045
2039
|
id: this._instanceId
|
|
2046
2040
|
}), {
|
|
2047
2041
|
F: __dxlog_file11,
|
|
2048
|
-
L:
|
|
2042
|
+
L: 144,
|
|
2049
2043
|
S: this,
|
|
2050
2044
|
C: (f, a) => f(...a)
|
|
2051
2045
|
});
|
|
@@ -2053,7 +2047,7 @@ var SpaceManager = class {
|
|
|
2053
2047
|
spaceKey: params.spaceKey
|
|
2054
2048
|
}, {
|
|
2055
2049
|
F: __dxlog_file11,
|
|
2056
|
-
L:
|
|
2050
|
+
L: 145,
|
|
2057
2051
|
S: this,
|
|
2058
2052
|
C: (f, a) => f(...a)
|
|
2059
2053
|
});
|
|
@@ -2073,7 +2067,7 @@ var SpaceManager = class {
|
|
|
2073
2067
|
disableP2pReplication: this._disableP2pReplication
|
|
2074
2068
|
});
|
|
2075
2069
|
try {
|
|
2076
|
-
await protocol.start();
|
|
2070
|
+
await protocol.start(ctx);
|
|
2077
2071
|
const credential = await onCredentialResolved.wait({
|
|
2078
2072
|
timeout: params.timeout
|
|
2079
2073
|
});
|
|
@@ -2081,7 +2075,7 @@ var SpaceManager = class {
|
|
|
2081
2075
|
id: this._instanceId
|
|
2082
2076
|
}), {
|
|
2083
2077
|
F: __dxlog_file11,
|
|
2084
|
-
L:
|
|
2078
|
+
L: 169,
|
|
2085
2079
|
S: this,
|
|
2086
2080
|
C: (f, a) => f(...a)
|
|
2087
2081
|
});
|
|
@@ -2092,13 +2086,13 @@ var SpaceManager = class {
|
|
|
2092
2086
|
error: err
|
|
2093
2087
|
}), {
|
|
2094
2088
|
F: __dxlog_file11,
|
|
2095
|
-
L:
|
|
2089
|
+
L: 172,
|
|
2096
2090
|
S: this,
|
|
2097
2091
|
C: (f, a) => f(...a)
|
|
2098
2092
|
});
|
|
2099
2093
|
throw err;
|
|
2100
2094
|
} finally {
|
|
2101
|
-
await protocol.stop();
|
|
2095
|
+
await protocol.stop(ctx);
|
|
2102
2096
|
}
|
|
2103
2097
|
}
|
|
2104
2098
|
findSpaceByRootDocumentId(documentId) {
|
|
@@ -2151,4 +2145,4 @@ export {
|
|
|
2151
2145
|
SpaceProtocolSession,
|
|
2152
2146
|
SpaceManager
|
|
2153
2147
|
};
|
|
2154
|
-
//# sourceMappingURL=chunk-
|
|
2148
|
+
//# sourceMappingURL=chunk-DN4YBAWV.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/common/codec.ts", "../../../src/common/feeds.ts", "../../../src/common/space-id.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/admission-discovery-extension.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/proto';\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 2024 DXOS.org\n//\n\nimport { subtleCrypto } from '@dxos/crypto';\nimport { PublicKey, SpaceId } from '@dxos/keys';\nimport { ComplexMap } from '@dxos/util';\n\nconst SPACE_IDS_CACHE = new ComplexMap<PublicKey, SpaceId>(PublicKey.hash);\n\n/**\n * Space keys are generated by creating a keypair, and then taking the first 20 bytes of the SHA-256 hash of the public key and encoding them to multibase RFC4648 base-32 format (prefixed with B, see Multibase Table).\n * Inspired by how ethereum addresses are derived.\n */\nexport const createIdFromSpaceKey = async (spaceKey: PublicKey): Promise<SpaceId> => {\n const cachedValue = SPACE_IDS_CACHE.get(spaceKey);\n if (cachedValue !== undefined) {\n return cachedValue;\n }\n\n const digest = await subtleCrypto.digest('SHA-256', spaceKey.asUint8Array() as Uint8Array<ArrayBuffer>);\n\n const bytes = new Uint8Array(digest).slice(0, SpaceId.byteLength);\n const spaceId = SpaceId.encode(bytes);\n SPACE_IDS_CACHE.set(spaceKey, spaceId);\n return spaceId;\n};\n", "//\n// Copyright 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 } from '@dxos/protocols';\nimport { schema } from '@dxos/protocols/proto';\nimport { Invitation, SpaceState } from '@dxos/protocols/proto/dxos/client/services';\nimport {\n type ControlPipelineSnapshot,\n type EchoMetadata,\n type EdgeReplicationSetting,\n type IdentityRecord,\n type LargeSpaceMetadata,\n type SpaceCache,\n type SpaceMetadata,\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, isNonNullable } 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({\n message: 'Metadata size is smaller than expected.',\n context: { fileLength, dataSize },\n });\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({ message: '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(): Promise<void> {\n await this._invitationCleanupCtx.dispose();\n await this.flush();\n await this._metadataFile?.close();\n this._metadataFile = undefined;\n this._metadata = emptyEchoMetadata();\n this._spaceLargeMetadata.clear();\n }\n\n /**\n * Loads metadata from persistent storage.\n */\n @synchronized\n async load(): Promise<void> {\n if (!this._metadataFile || this._metadataFile.closed) {\n this._metadataFile = this._directory.getOrCreateFile('EchoMetadata');\n }\n\n try {\n const metadata = await this._readFile(this._metadataFile, EchoMetadata);\n if (metadata) {\n this._metadata = metadata;\n }\n\n // post-processing\n this._metadata.spaces?.forEach((space) => {\n space.state ??= SpaceState.SPACE_ACTIVE;\n });\n } catch (err: any) {\n log.error('failed to load metadata', { err });\n this._metadata = emptyEchoMetadata();\n }\n\n await forEachAsync(\n [this._metadata.identity?.haloSpace.key, ...(this._metadata.spaces?.map((space) => space.key) ?? [])].filter(\n isNonNullable,\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(): Promise<void> {\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.equals(spaceKey));\n invariant(space, 'Space not found');\n return space;\n }\n\n hasSpace(spaceKey: PublicKey): boolean {\n if (this._metadata.identity?.haloSpace.key.equals(spaceKey)) {\n // Check if the space is the identity space.\n return true;\n }\n\n return !!this.spaces.find((space) => space.key.equals(spaceKey));\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): Promise<void> {\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): Promise<void> {\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): Promise<void> {\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): Promise<void> {\n invariant(\n !(this._metadata.spaces ?? []).find((space) => space.key.equals(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): Promise<void> {\n this._getSpace(spaceKey).dataTimeframe = timeframe;\n await this._save();\n }\n\n async setSpaceControlLatestTimeframe(spaceKey: PublicKey, timeframe: Timeframe): Promise<void> {\n this._getSpace(spaceKey).controlTimeframe = timeframe;\n await this._save();\n await this.flush();\n }\n\n async setCache(spaceKey: PublicKey, cache: SpaceCache): Promise<void> {\n this._getSpace(spaceKey).cache = cache;\n await this._save();\n }\n\n async setWritableFeedKeys(spaceKey: PublicKey, controlFeedKey: PublicKey, dataFeedKey: PublicKey): Promise<void> {\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): Promise<void> {\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): Promise<void> {\n this._getLargeSpaceMetadata(spaceKey).controlPipelineSnapshot = snapshot;\n await this._saveSpaceLargeMetadata(spaceKey);\n await this.flush();\n }\n\n getSpaceEdgeReplicationSetting(spaceKey: PublicKey): EdgeReplicationSetting | undefined {\n return this.hasSpace(spaceKey) ? this._getSpace(spaceKey).edgeReplication : undefined;\n }\n\n async setSpaceEdgeReplicationSetting(spaceKey: PublicKey, setting: EdgeReplicationSetting): Promise<void> {\n this._getSpace(spaceKey).edgeReplication = setting;\n await this._save();\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): void {\n this._timeframe = timeframe;\n this._pendingTimeframe = timeframe;\n this.update.emit(this._timeframe);\n }\n\n updatePendingTimeframe(key: PublicKey, seq: number): void {\n this._pendingTimeframe = Timeframe.merge(this._pendingTimeframe, new Timeframe([[key, seq]]));\n }\n\n updateTimeframe(): void {\n this._timeframe = this._pendingTimeframe;\n this.update.emit(this._timeframe);\n }\n\n hasGaps(timeframe: Timeframe): boolean {\n const gaps = Timeframe.dependencies(timeframe, this._timeframe);\n return !gaps.isEmpty();\n }\n\n @timed(5_000)\n async waitUntilReached(target: Timeframe): Promise<void> {\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, Trigger, sleepWithContext, synchronized } 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 { createMappedFeedWriter } from '../common';\n\nimport { createMessageSelector } from './message-selector';\nimport { TimeframeClock, mapFeedIndexesToTimeframe, startAfter } from './timeframe-clock';\n\nexport type WaitUntilReachedTargetProps = {\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?. Avoid accessing `_timeframeClock` before constructor initialization.\n public get timeframeUpdate() {\n return this._timeframeClock.update;\n }\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): Promise<void> {\n await this._timeframeClock.waitUntilReached(target);\n }\n\n setTargetTimeframe(target: Timeframe): void {\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 }: WaitUntilReachedTargetProps = {}): Promise<void> {\n log('waitUntilReachedTargetTimeframe', {\n timeout,\n current: this.timeframe,\n target: this.targetTimeframe,\n });\n\n this._reachedTargetPromise ??= Promise.race([\n this._timeframeClock.update.waitForCondition(() => {\n return Timeframe.dependencies(this.targetTimeframe, this.timeframe).isEmpty();\n }),\n ...(breakOnStall ? [this.stalled.discardParameter().waitForCount(1)] : []),\n ]);\n\n let done = false;\n\n if (timeout) {\n return Promise.race([\n rejectOnDispose(ctx),\n rejectOnDispose(this._ctx),\n this._reachedTargetPromise.then(() => {\n done = true;\n this._reachedTarget = true;\n }),\n sleepWithContext(this._ctx, timeout).then(() => {\n if (done) {\n return;\n }\n\n log.warn('waitUntilReachedTargetTimeframe timed out', {\n timeout,\n current: this.timeframe,\n target: this.targetTimeframe,\n dependencies: Timeframe.dependencies(this.targetTimeframe, this.timeframe),\n });\n }),\n ]);\n } else {\n return this._reachedTargetPromise;\n }\n }\n}\n\n// TODO(mykola): Extract to `@dxos/echo-protocol`\nexport interface PipelineAccessor {\n state: PipelineState;\n writer: FeedWriter<FeedMessage.Payload>;\n}\n\n/**\n * A multi-reader pipeline that operates on feeds.\n * Might have a single writable feed.\n * Has a timeframe clock to handle message ordering.\n *\n * NOTE:\n * - Feeds passed in must have value encoding consistent with the type expected by the iterator/writer.\n *\n * # Usage examples\n *\n * ## Create a new space.\n *\n * 1. Generate space key, genesis feed key.\n * 2. Create and open pipeline reading from {}.\n * 3. Create and add the writable genesis feed.\n * 4. Write the initial sequence of control and credential messages.\n *\n * ## Load an existing space from storage\n *\n * 1. Load space key, genesis feed key, get starting timeframe from saved snapshot.\n * 2. Create and open pipeline reading from the initial timeframe.\n * 3. Open and add the genesis feed.\n * 4. Once the writable feed is added, the pipeline becomes writable.\n *\n * ## Join an existing space created by another agent/device.\n *\n * 1. Get the space key, genesis feed key from another agent.\n * 2. (optionally) Download the snapshot from another agent.\n * 3. Create and open pipeline.\n * 4. Generate the writable feed key.\n * 5. Wait for the writable feed to be added.\n */\nexport class Pipeline implements PipelineAccessor {\n private readonly _timeframeClock = new TimeframeClock(new Timeframe());\n private readonly _feeds = new ComplexMap<PublicKey, FeedWrapper<FeedMessage>>(PublicKey.hash);\n\n // External state accessor.\n private readonly _state: PipelineState = new PipelineState(this._feeds, this._timeframeClock);\n\n // Waits for the message consumer to process the message and yield control back to the pipeline.\n private readonly _processingTrigger = new Trigger().wake();\n private readonly _pauseTrigger = new Trigger().wake();\n\n // Pending downloads.\n private readonly _downloads = new ComplexMap<FeedWrapper<FeedMessage>, any>((value) => PublicKey.hash(value.key));\n\n // Inbound feed stream.\n private _feedSetIterator?: FeedSetIterator<FeedMessage>;\n\n // Outbound feed writer.\n private _writer: FeedWriter<FeedMessage.Payload> | undefined;\n\n private _isStopping = false;\n private _isStarted = false;\n private _isBeingConsumed = false;\n private _isPaused = false;\n\n get state() {\n return this._state;\n }\n\n get writer(): FeedWriter<FeedMessage.Payload> {\n invariant(this._writer, 'Writer not set.');\n return this._writer;\n }\n\n hasFeed(feedKey: PublicKey): boolean {\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>): Promise<void> {\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>): void {\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(): Promise<void> {\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(): Promise<void> {\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): Promise<void> {\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(): Promise<void> {\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(): Promise<void> {\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>): void {\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('downloaded', { data }); // TODO(burdon): Never called.\n }\n });\n\n this._downloads.set(feed, handle);\n }\n\n private async _initIterator(): Promise<void> {\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 currentTimeframe: this._timeframeClock.timeframe,\n targetTimeframe: this._state.targetTimeframe,\n });\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/proto';\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 AuthExtensionProps = {\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 _authProps: AuthExtensionProps) {\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._authProps.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._authProps.verifier(challenge, credential);\n invariant(success, 'credential not verified');\n runInContext(this._ctx, () => this._authProps.onAuthSuccess());\n } catch (err) {\n log('auth failed', err);\n this.close();\n this._authProps.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, scheduleMicroTask, synchronized, trackLeaks } from '@dxos/async';\nimport { type Context, Resource } from '@dxos/context';\nimport { type DelegateInvitationCredential, type FeedInfo, type MemberInfo } from '@dxos/credentials';\nimport { type FeedOptions, type FeedWrapper } from '@dxos/feed-store';\nimport { invariant } from '@dxos/invariant';\nimport { type PublicKey, type SpaceId } from '@dxos/keys';\nimport { log, logInfo } from '@dxos/log';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { AdmittedFeed, type Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { type Timeframe } from '@dxos/timeframe';\nimport { trace } from '@dxos/tracing';\nimport { type AsyncCallback, Callback } from '@dxos/util';\n\nimport { type MetadataStore } from '../metadata';\nimport { type PipelineAccessor } from '../pipeline';\n\nimport { ControlPipeline } from './control-pipeline';\nimport { type SpaceProtocol } from './space-protocol';\n\n// TODO(burdon): Factor out?\ntype FeedProvider = (feedKey: PublicKey, opts?: FeedOptions) => Promise<FeedWrapper<FeedMessage>>;\n\nexport type SpaceProps = {\n id: SpaceId;\n spaceKey: PublicKey;\n protocol: SpaceProtocol;\n genesisFeed: FeedWrapper<FeedMessage>;\n feedProvider: FeedProvider;\n metadataStore: MetadataStore;\n memberKey: PublicKey;\n\n // TODO(dmaretskyi): Superseded by epochs.\n snapshotId?: string | undefined;\n\n onDelegatedInvitationStatusChange: (invitation: DelegateInvitationCredential, isActive: boolean) => Promise<void>;\n onMemberRolesChanged: (member: MemberInfo[]) => Promise<void>;\n};\n\nexport type CreatePipelineProps = {\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// TODO(dmaretskyi): Rename HaloGraph move to HALO.\n@trackLeaks('open', 'close')\n@trace.resource()\nexport class Space extends Resource {\n public readonly onCredentialProcessed = new Callback<AsyncCallback<Credential>>();\n public readonly stateUpdate = new Event();\n @trace.info()\n public readonly protocol: SpaceProtocol;\n\n private readonly _id: SpaceId;\n private readonly _key: PublicKey;\n private readonly _genesisFeedKey: PublicKey;\n private readonly _feedProvider: FeedProvider;\n @trace.info()\n private readonly _controlPipeline: ControlPipeline;\n\n private _controlFeed?: FeedWrapper<FeedMessage>;\n private _dataFeed?: FeedWrapper<FeedMessage>;\n\n constructor(params: SpaceProps) {\n super();\n invariant(params.spaceKey && params.feedProvider);\n this._id = params.id;\n this._key = params.spaceKey;\n this._genesisFeedKey = params.genesisFeed.key;\n this._feedProvider = params.feedProvider;\n\n this._controlPipeline = new ControlPipeline({\n spaceKey: params.spaceKey,\n genesisFeed: params.genesisFeed,\n feedProvider: params.feedProvider,\n metadataStore: params.metadataStore,\n });\n\n // TODO(dmaretskyi): Feed set abstraction.\n this._controlPipeline.onFeedAdmitted.set(async (info) => {\n // Enable sparse replication to not download mutations covered by prior epochs.\n const sparse = info.assertion.designation === AdmittedFeed.Designation.DATA;\n\n if (!info.key.equals(params.genesisFeed.key)) {\n scheduleMicroTask(this._ctx, async () => {\n await this.protocol.addFeed(await params.feedProvider(info.key, { sparse }));\n });\n }\n });\n\n this._controlPipeline.onCredentialProcessed.set(async (credential) => {\n await this.onCredentialProcessed.callIfSet(credential);\n log('onCredentialProcessed', { credential });\n this.stateUpdate.emit();\n });\n this._controlPipeline.onDelegatedInvitation.set(async (invitation) => {\n log('onDelegatedInvitation', { invitation });\n await params.onDelegatedInvitationStatusChange(invitation, true);\n });\n this._controlPipeline.onDelegatedInvitationRemoved.set(async (invitation) => {\n log('onDelegatedInvitationRemoved', { invitation });\n await params.onDelegatedInvitationStatusChange(invitation, false);\n });\n this._controlPipeline.onMemberRoleChanged.set(async (changedMembers) => {\n log('onMemberRoleChanged', () => ({ changedMembers: changedMembers.map((m) => [m.key, m.role]) }));\n await params.onMemberRolesChanged(changedMembers);\n });\n\n // Start replicating the genesis feed.\n this.protocol = params.protocol;\n }\n\n @logInfo\n @trace.info()\n get id() {\n return this._id;\n }\n\n @logInfo\n @trace.info()\n get key() {\n return this._key;\n }\n\n get 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 async setControlFeed(feed: FeedWrapper<FeedMessage>): Promise<this> {\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>): Promise<this> {\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): Promise<void> {\n log('opening...');\n\n // Order is important.\n await this._controlPipeline.start(ctx);\n\n log('opened');\n }\n\n @synchronized\n public async startProtocol(ctx: Context): Promise<void> {\n invariant(this.isOpen);\n await this.protocol.start(ctx);\n await this.protocol.addFeed(await this._feedProvider(this._genesisFeedKey));\n }\n\n @synchronized\n protected override async _close(ctx: Context): Promise<void> {\n log('closing...', { key: this._key });\n\n // Closes in reverse order to open.\n await this.protocol.stop(ctx);\n await this._controlPipeline.stop();\n\n log('closed');\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { DeferredTask, scheduleMicroTask, sleepWithContext, trackLeaks } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport {\n type DelegateInvitationCredential,\n type FeedInfo,\n type MemberInfo,\n type SpaceState,\n SpaceStateMachine,\n} from '@dxos/credentials';\nimport { type FeedWrapper } from '@dxos/feed-store';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type FeedMessageBlock } from '@dxos/protocols';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type ControlPipelineSnapshot } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport { AdmittedFeed, type Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { Timeframe } from '@dxos/timeframe';\nimport { TimeSeriesCounter, TimeUsageCounter, trace } from '@dxos/tracing';\nimport { type AsyncCallback, Callback, tracer } from '@dxos/util';\n\nimport { type MetadataStore } from '../metadata';\nimport { Pipeline, type PipelineAccessor } from '../pipeline';\n\nexport type ControlPipelineProps = {\n spaceKey: PublicKey;\n genesisFeed: FeedWrapper<FeedMessage>;\n feedProvider: (feedKey: PublicKey) => Promise<FeedWrapper<FeedMessage>>;\n metadataStore: MetadataStore;\n};\n\nconst TIMEFRAME_SAVE_DEBOUNCE_INTERVAL = 500;\n\nconst CONTROL_PIPELINE_SNAPSHOT_DELAY = 10_000;\n\nconst USE_SNAPSHOTS = true;\n\n/**\n * Processes HALO credentials, which include genesis and invitations.\n */\n@trace.resource()\n@trackLeaks('start', 'stop')\nexport class ControlPipeline {\n private readonly _ctx = new Context();\n private readonly _pipeline: Pipeline;\n private readonly _spaceStateMachine: SpaceStateMachine;\n\n private readonly _spaceKey: PublicKey;\n private readonly _metadata: MetadataStore;\n private _targetTimeframe?: Timeframe;\n private _lastTimeframeSaveTime: number = Date.now();\n\n public readonly onFeedAdmitted = new Callback<AsyncCallback<FeedInfo>>();\n public readonly onMemberRoleChanged: Callback<AsyncCallback<MemberInfo[]>>;\n public readonly onCredentialProcessed: Callback<AsyncCallback<Credential>>;\n public readonly onDelegatedInvitation: Callback<AsyncCallback<DelegateInvitationCredential>>;\n public readonly onDelegatedInvitationRemoved: Callback<AsyncCallback<DelegateInvitationCredential>>;\n\n @trace.metricsCounter()\n private _usage = new TimeUsageCounter();\n\n @trace.metricsCounter()\n private _mutations = new TimeSeriesCounter();\n\n private _snapshotTask = new DeferredTask(this._ctx, async () => {\n await sleepWithContext(this._ctx, CONTROL_PIPELINE_SNAPSHOT_DELAY);\n await this._saveSnapshot();\n });\n\n constructor({ spaceKey, genesisFeed, feedProvider, metadataStore }: ControlPipelineProps) {\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 scheduleMicroTask(this._ctx, async () => {\n try {\n const feed = await feedProvider(info.key);\n if (this._ctx.disposed) {\n return;\n }\n if (!this._pipeline.hasFeed(feed.key)) {\n await this._pipeline.addFeed(feed);\n }\n } catch (err: any) {\n log.catch(err);\n }\n });\n }\n\n await this.onFeedAdmitted.callIfSet(info);\n });\n\n this.onMemberRoleChanged = this._spaceStateMachine.onMemberRoleChanged;\n this.onCredentialProcessed = this._spaceStateMachine.onCredentialProcessed;\n this.onDelegatedInvitation = this._spaceStateMachine.onDelegatedInvitation;\n this.onDelegatedInvitationRemoved = this._spaceStateMachine.onDelegatedInvitationRemoved;\n }\n\n get spaceState(): SpaceState {\n return this._spaceStateMachine;\n }\n\n get pipeline(): PipelineAccessor {\n return this._pipeline;\n }\n\n async setWriteFeed(feed: FeedWrapper<FeedMessage>): Promise<void> {\n await this._pipeline.addFeed(feed);\n this._pipeline.setWriteFeed(feed);\n }\n\n @trace.span({ showInBrowserTimeline: true })\n async start(ctx: Context): Promise<void> {\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(ctx);\n });\n\n await this._pipeline.start();\n log('started');\n }\n\n private async _processSnapshot(snapshot: ControlPipelineSnapshot): Promise<void> {\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(): Promise<void> {\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: getSnapshotLoggerContext(snapshot) });\n await this._metadata.setSpaceControlPipelineSnapshot(this._spaceKey, snapshot);\n }\n\n private async _consumePipeline(ctx: Context): Promise<void> {\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): Promise<void> {\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): Promise<void> {\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(): Promise<void> {\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): Promise<void> {\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\nconst getSnapshotLoggerContext = (snapshot: ControlPipelineSnapshot) => {\n return snapshot.messages?.map((msg) => {\n const issuer = msg.credential.issuer;\n const subject = msg.credential.subject.id;\n const type = msg.credential.subject.assertion['@type'];\n return { issuer, subject, type };\n });\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Trigger, scheduleTask } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { ProtocolError } from '@dxos/protocols';\nimport { schema } from '@dxos/protocols/proto';\nimport { type Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport {\n type AdmissionDiscoveryService,\n type GetAdmissionCredentialRequest,\n type GetAdmissionCredentialResponse,\n} from '@dxos/protocols/proto/dxos/mesh/teleport';\nimport { type ExtensionContext, RpcExtension } from '@dxos/teleport';\n\nimport { type Space } from './space';\n\n/**\n * Guest's side for a connection to a concrete peer in p2p network during invitation.\n */\nexport class CredentialRetrieverExtension extends RpcExtension<\n { AdmissionDiscoveryService: AdmissionDiscoveryService },\n {}\n> {\n private _ctx = new Context();\n\n constructor(\n private readonly _request: GetAdmissionCredentialRequest,\n private readonly _onResult: Trigger<Credential>,\n ) {\n super({\n requested: {\n AdmissionDiscoveryService: schema.getService('dxos.mesh.teleport.AdmissionDiscoveryService'),\n },\n });\n }\n\n protected override async getHandlers(): Promise<{}> {\n return {};\n }\n\n override async onOpen(context: ExtensionContext): Promise<void> {\n await super.onOpen(context);\n scheduleTask(this._ctx, async () => {\n try {\n const result = await this.rpc.AdmissionDiscoveryService.getAdmissionCredential(this._request);\n this._onResult.wake(result.admissionCredential);\n } catch (err: any) {\n context.close(err);\n }\n });\n }\n\n override async onClose(): Promise<void> {\n await this._ctx.dispose();\n }\n\n override async onAbort(): Promise<void> {\n await this._ctx.dispose();\n }\n}\n\nexport class CredentialServerExtension extends RpcExtension<\n {},\n { AdmissionDiscoveryService: AdmissionDiscoveryService }\n> {\n constructor(private readonly _space: Space) {\n super({\n exposed: {\n AdmissionDiscoveryService: schema.getService('dxos.mesh.teleport.AdmissionDiscoveryService'),\n },\n });\n }\n\n protected override async getHandlers(): Promise<{ AdmissionDiscoveryService: AdmissionDiscoveryService }> {\n return {\n AdmissionDiscoveryService: {\n getAdmissionCredential: async (\n request: GetAdmissionCredentialRequest,\n ): Promise<GetAdmissionCredentialResponse> => {\n const memberInfo = this._space.spaceState.members.get(request.memberKey);\n if (!memberInfo?.credential) {\n throw new ProtocolError({ message: 'Space member not found.', context: { ...request } });\n }\n return { admissionCredential: memberInfo.credential };\n },\n },\n };\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { type Event } from '@dxos/async';\nimport { discoveryKey, subtleCrypto } from '@dxos/crypto';\nimport { type FeedWrapper } from '@dxos/feed-store';\nimport { PublicKey } from '@dxos/keys';\nimport { log, logInfo } from '@dxos/log';\nimport {\n MMSTTopology,\n type SwarmConnection,\n type SwarmNetworkManager,\n type WireProtocol,\n type WireProtocolProps,\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 { type AsyncCallback, CallbackCollection, ComplexMap } from '@dxos/util';\n\nimport { AuthExtension, type AuthProvider, type AuthVerifier } from './auth';\nimport { Context } from '@dxos/context';\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 identityKey: PublicKey;\n credentialProvider: AuthProvider;\n credentialAuthenticator: AuthVerifier;\n}\n\nexport type SpaceProtocolOptions = {\n topic: PublicKey; // TODO(burdon): Rename?\n swarmIdentity: SwarmIdentity;\n networkManager: SwarmNetworkManager;\n\n blobStore: BlobStore;\n\n onFeed?: (feed: FeedWrapper<FeedMessage>) => Promise<void>;\n\n /**\n * Called when new session is authenticated.\n * Additional extensions can be added here.\n */\n onSessionAuth?: (session: Teleport) => void;\n onAuthFailure?: (session: Teleport) => void;\n\n disableP2pReplication?: boolean;\n};\n\n/**\n * Manages Teleport protocol stream creation and joining swarms with replication and presence extensions.\n */\n@trace.resource()\nexport class SpaceProtocol {\n private readonly _networkManager: SwarmNetworkManager;\n private readonly _swarmIdentity: SwarmIdentity;\n private readonly _onSessionAuth?: (session: Teleport) => void;\n private readonly _onAuthFailure?: (session: Teleport) => void;\n\n public readonly blobSync: BlobSync;\n\n private readonly _disableP2pReplication: boolean;\n\n @logInfo\n @trace.info()\n private readonly _topic: Promise<PublicKey>;\n\n @trace.info()\n private readonly _spaceKey: PublicKey;\n\n private readonly _feeds = new Set<FeedWrapper<FeedMessage>>();\n private readonly _sessions = new ComplexMap<PublicKey, SpaceProtocolSession>(PublicKey.hash);\n // TODO(burdon): Move to config (with sensible defaults).\n private readonly _topology = new MMSTTopology({\n originateConnections: 4,\n maxPeers: 10,\n sampleSize: 20,\n });\n\n private _connection?: SwarmConnection;\n\n public readonly feedAdded = new CallbackCollection<AsyncCallback<FeedWrapper<FeedMessage>>>();\n\n get sessions(): ReadonlyMap<PublicKey, SpaceProtocolSession> {\n return this._sessions;\n }\n\n get feeds(): ReadonlySet<FeedWrapper<FeedMessage>> {\n return this._feeds;\n }\n\n @logInfo\n private get _ownPeerKey() {\n return this._swarmIdentity.peerKey;\n }\n\n constructor({\n topic,\n swarmIdentity,\n networkManager,\n onSessionAuth,\n onAuthFailure,\n blobStore,\n disableP2pReplication,\n }: SpaceProtocolOptions) {\n this._spaceKey = topic;\n this._networkManager = networkManager;\n this._swarmIdentity = swarmIdentity;\n this._onSessionAuth = onSessionAuth;\n this._onAuthFailure = onAuthFailure;\n this.blobSync = new BlobSync({ blobStore });\n\n // TODO(burdon): Async race condition? Move to start?\n this._topic = subtleCrypto\n .digest('SHA-256', topic.asBuffer() as ArrayBufferView<ArrayBuffer>)\n .then(discoveryKey)\n .then(PublicKey.from);\n\n this._disableP2pReplication = disableP2pReplication ?? false;\n }\n\n // TODO(burdon): Create abstraction for Space (e.g., add keys and have provider).\n async addFeed(feed: FeedWrapper<FeedMessage>): Promise<void> {\n log('addFeed', { key: feed.key });\n\n this._feeds.add(feed);\n for (const session of this._sessions.values()) {\n session.replicator.addFeed(feed);\n }\n\n await this.feedAdded.callSerial(feed);\n }\n\n // TODO(burdon): Rename open? Common open/close interfaces for all services?\n async start(ctx: Context): Promise<void> {\n if (this._connection) {\n return;\n }\n\n // TODO(burdon): Document why empty buffer.\n const credentials = await this._swarmIdentity.credentialProvider(Buffer.from(''));\n\n await this.blobSync.open();\n\n log('starting...');\n const topic = await this._topic;\n this._connection = await this._networkManager.joinSwarm(ctx, {\n protocolProvider: this._createProtocolProvider(credentials),\n topic,\n topology: this._topology,\n label: `swarm ${topic.truncate()} for space ${this._spaceKey.truncate()}`,\n });\n\n log('started');\n }\n\n public updateTopology(): void {\n this._topology.forceUpdate();\n }\n\n async stop(ctx: Context): Promise<void> {\n await this.blobSync.close();\n\n if (this._connection) {\n log('stopping...');\n await this._connection.close(ctx);\n log('stopped');\n }\n }\n\n private _createProtocolProvider(credentials: Uint8Array | undefined): WireProtocolProvider {\n return (wireProps) => {\n const session = new SpaceProtocolSession({\n wireProps,\n swarmIdentity: this._swarmIdentity,\n onSessionAuth: this._onSessionAuth,\n onAuthFailure: this._onAuthFailure,\n blobSync: this.blobSync,\n disableP2pReplication: this._disableP2pReplication,\n });\n this._sessions.set(wireProps.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 SpaceProtocolSessionProps = {\n wireProps: WireProtocolProps;\n swarmIdentity: SwarmIdentity;\n\n blobSync: BlobSync;\n\n /**\n * Called when new session is authenticated.\n * Additional extensions can be added here.\n */\n onSessionAuth?: (session: Teleport) => void;\n\n onAuthFailure?: (session: Teleport) => void;\n\n disableP2pReplication?: boolean;\n};\n\nexport enum AuthStatus {\n INITIAL = 'INITIAL',\n SUCCESS = 'SUCCESS',\n FAILURE = 'FAILURE',\n}\n\n// TODO(dmaretskyi): Move to a separate file.\n/**\n * Represents a single connection to a remote peer\n */\nexport class SpaceProtocolSession implements WireProtocol {\n @logInfo\n private readonly _wireProps: WireProtocolProps;\n\n private readonly _disableP2pReplication: boolean;\n\n private readonly _onSessionAuth?: (session: Teleport) => void;\n private readonly _onAuthFailure?: (session: Teleport) => void;\n private readonly _swarmIdentity: SwarmIdentity;\n private readonly _blobSync: BlobSync;\n\n private readonly _teleport: Teleport;\n\n // TODO(dmaretskyi): Start with upload=false when switching it on the fly works.\n public readonly replicator = new ReplicatorExtension().setOptions({ upload: true });\n\n private _authStatus = AuthStatus.INITIAL;\n\n @logInfo\n get authStatus() {\n return this._authStatus;\n }\n\n get stats(): Event<MuxerStats> {\n return this._teleport.stats;\n }\n\n // TODO(dmaretskyi): Allow to pass in extra extensions.\n constructor({\n wireProps,\n swarmIdentity,\n onSessionAuth,\n onAuthFailure,\n blobSync,\n disableP2pReplication,\n }: SpaceProtocolSessionProps) {\n this._wireProps = wireProps;\n this._swarmIdentity = swarmIdentity;\n this._onSessionAuth = onSessionAuth;\n this._onAuthFailure = onAuthFailure;\n this._blobSync = blobSync;\n\n this._teleport = new Teleport(wireProps);\n\n this._disableP2pReplication = disableP2pReplication ?? false;\n }\n\n get stream() {\n return this._teleport.stream;\n }\n\n async open(sessionId?: PublicKey): Promise<void> {\n await this._teleport.open(sessionId);\n this._teleport.addExtension(\n 'dxos.mesh.teleport.auth',\n new AuthExtension({\n provider: this._swarmIdentity.credentialProvider,\n verifier: this._swarmIdentity.credentialAuthenticator,\n onAuthSuccess: () => {\n log('Peer authenticated');\n this._authStatus = AuthStatus.SUCCESS;\n this._onSessionAuth?.(this._teleport);\n // TODO(dmaretskyi): Configure replicator to upload.\n },\n onAuthFailure: () => {\n this._authStatus = AuthStatus.FAILURE;\n this._onAuthFailure?.(this._teleport);\n },\n }),\n );\n\n if (!this._disableP2pReplication) {\n this._teleport.addExtension('dxos.mesh.teleport.replicator', this.replicator);\n }\n this._teleport.addExtension('dxos.mesh.teleport.blobsync', this._blobSync.createExtension());\n }\n\n async close(): Promise<void> {\n log('close');\n await this._teleport.close();\n }\n\n async abort(): Promise<void> {\n await this._teleport.abort();\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { type AutomergeUrl, parseAutomergeUrl } from '@automerge/automerge-repo';\n\nimport { Trigger, synchronized, trackLeaks } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { type DelegateInvitationCredential, type MemberInfo, getCredentialAssertion } from '@dxos/credentials';\nimport { failUndefined } from '@dxos/debug';\nimport { type FeedStore } from '@dxos/feed-store';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { type SwarmNetworkManager } from '@dxos/network-manager';\nimport { trace } from '@dxos/protocols';\nimport type { FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';\nimport { type SpaceMetadata } from '@dxos/protocols/proto/dxos/echo/metadata';\nimport type { Credential } from '@dxos/protocols/proto/dxos/halo/credentials';\nimport { type Teleport } from '@dxos/teleport';\nimport { type BlobStore } from '@dxos/teleport-extension-object-sync';\nimport { ComplexMap } from '@dxos/util';\n\nimport { createIdFromSpaceKey } from '../common/space-id';\nimport { type MetadataStore } from '../metadata';\n\nimport { CredentialRetrieverExtension } from './admission-discovery-extension';\nimport { Space } from './space';\nimport { SpaceProtocol, type SwarmIdentity } from './space-protocol';\n\nexport type SpaceManagerProps = {\n feedStore: FeedStore<FeedMessage>;\n networkManager: SwarmNetworkManager;\n metadataStore: MetadataStore;\n\n blobStore: BlobStore;\n\n disableP2pReplication?: boolean;\n};\n\nexport type ConstructSpaceProps = {\n metadata: SpaceMetadata;\n swarmIdentity: SwarmIdentity;\n memberKey: PublicKey;\n /**\n * Called when connection auth passed successful.\n */\n onAuthorizedConnection: (session: Teleport) => void;\n onAuthFailure?: (session: Teleport) => void;\n onDelegatedInvitationStatusChange: (invitation: DelegateInvitationCredential, isActive: boolean) => Promise<void>;\n onMemberRolesChanged: (member: MemberInfo[]) => Promise<void>;\n};\n\nexport type RequestSpaceAdmissionCredentialProps = {\n spaceKey: PublicKey;\n identityKey: PublicKey;\n swarmIdentity: SwarmIdentity;\n timeout: number;\n};\n\n/**\n * Manages a collection of ECHO (Data) Spaces.\n */\n@trackLeaks('open', 'close')\nexport class SpaceManager {\n private readonly _spaces = new ComplexMap<PublicKey, Space>(PublicKey.hash);\n private readonly _feedStore: FeedStore<FeedMessage>;\n private readonly _networkManager: SwarmNetworkManager;\n private readonly _metadataStore: MetadataStore;\n private readonly _blobStore: BlobStore;\n private readonly _instanceId = PublicKey.random().toHex();\n private readonly _disableP2pReplication: boolean;\n\n constructor({ feedStore, networkManager, metadataStore, blobStore, disableP2pReplication }: SpaceManagerProps) {\n // TODO(burdon): Assert.\n this._feedStore = feedStore;\n this._networkManager = networkManager;\n this._metadataStore = metadataStore;\n this._blobStore = blobStore;\n this._disableP2pReplication = disableP2pReplication ?? false;\n }\n\n // TODO(burdon): Remove.\n get spaces() {\n return this._spaces;\n }\n\n @synchronized\n async open(): Promise<void> {}\n\n @synchronized\n async close(): Promise<void> {\n await Promise.all([...this._spaces.values()].map((space) => space.close()));\n }\n\n async constructSpace({\n metadata,\n swarmIdentity,\n onAuthorizedConnection,\n onAuthFailure,\n onDelegatedInvitationStatusChange,\n onMemberRolesChanged,\n memberKey,\n }: ConstructSpaceProps): Promise<Space> {\n log.trace('dxos.echo.space-manager.construct-space', trace.begin({ id: this._instanceId }));\n log('constructing space...', { spaceKey: metadata.genesisFeedKey });\n\n // The genesis feed will be the same as the control feed if the space was created by the local agent.\n const genesisFeed = await this._feedStore.openFeed(metadata.genesisFeedKey ?? failUndefined());\n\n const spaceKey = metadata.key;\n const spaceId = await createIdFromSpaceKey(spaceKey);\n const protocol = new SpaceProtocol({\n topic: spaceKey,\n swarmIdentity,\n networkManager: this._networkManager,\n onSessionAuth: onAuthorizedConnection,\n onAuthFailure,\n blobStore: this._blobStore,\n disableP2pReplication: this._disableP2pReplication,\n });\n\n const space = new Space({\n id: spaceId,\n spaceKey,\n protocol,\n genesisFeed,\n feedProvider: (feedKey, opts) => this._feedStore.openFeed(feedKey, opts),\n metadataStore: this._metadataStore,\n memberKey,\n onDelegatedInvitationStatusChange,\n onMemberRolesChanged,\n });\n this._spaces.set(space.key, space);\n\n log.trace('dxos.echo.space-manager.construct-space', trace.end({ id: this._instanceId }));\n return space;\n }\n\n public async requestSpaceAdmissionCredential(\n ctx: Context,\n params: RequestSpaceAdmissionCredentialProps,\n ): Promise<Credential> {\n const traceKey = 'dxos.echo.space-manager.request-space-admission';\n log.trace(traceKey, trace.begin({ id: this._instanceId }));\n log('requesting space admission credential...', { spaceKey: params.spaceKey });\n\n const onCredentialResolved = new Trigger<Credential>();\n const protocol = new SpaceProtocol({\n topic: params.spaceKey,\n swarmIdentity: params.swarmIdentity,\n networkManager: this._networkManager,\n onSessionAuth: (session: Teleport) => {\n session.addExtension(\n 'dxos.mesh.teleport.admission-discovery',\n new CredentialRetrieverExtension(\n { spaceKey: params.spaceKey, memberKey: params.identityKey },\n onCredentialResolved,\n ),\n );\n },\n onAuthFailure: (session: Teleport) => session.close(),\n blobStore: this._blobStore,\n disableP2pReplication: this._disableP2pReplication,\n });\n\n try {\n await protocol.start(ctx);\n const credential = await onCredentialResolved.wait({ timeout: params.timeout });\n log.trace(traceKey, trace.end({ id: this._instanceId }));\n return credential;\n } catch (err: any) {\n log.trace(traceKey, trace.error({ id: this._instanceId, error: err }));\n throw err;\n } finally {\n await protocol.stop(ctx);\n }\n }\n\n public findSpaceByRootDocumentId(documentId: string): Space | undefined {\n return [...this._spaces.values()].find((space) => {\n return space.spaceState.credentials.some((credential) => {\n const assertion = getCredentialAssertion(credential);\n if (assertion['@type'] !== 'dxos.halo.credentials.Epoch') {\n return false;\n }\n if (!assertion?.automergeRoot) {\n return false;\n }\n return parseAutomergeUrl(assertion.automergeRoot as AutomergeUrl).documentId === documentId;\n });\n });\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["createCodecEncoding", "schema", "codec", "schema", "getCodecForType", "valueEncoding", "createCodecEncoding", "invariant", "createMappedFeedWriter", "mapper", "writer", "write", "data", "options", "subtleCrypto", "PublicKey", "SpaceId", "ComplexMap", "SPACE_IDS_CACHE", "ComplexMap", "PublicKey", "hash", "createIdFromSpaceKey", "spaceKey", "cachedValue", "get", "undefined", "digest", "subtleCrypto", "asUint8Array", "bytes", "Uint8Array", "slice", "SpaceId", "byteLength", "spaceId", "encode", "set", "CRC32", "Event", "scheduleTaskInterval", "synchronized", "Context", "invariant", "PublicKey", "log", "DataCorruptionError", "STORAGE_VERSION", "schema", "Invitation", "SpaceState", "ComplexMap", "arrayToBuffer", "forEachAsync", "isNonNullable", "EXPIRED_INVITATION_CLEANUP_INTERVAL", "emptyEchoMetadata", "version", "spaces", "created", "Date", "updated", "emptyLargeSpaceMetadata", "EchoMetadata", "getCodecForType", "LargeSpaceMetadata", "MetadataStore", "_metadata", "_spaceLargeMetadata", "hash", "_metadataFile", "undefined", "update", "_invitationCleanupCtx", "_directory", "directory", "metadata", "_readFile", "file", "codec", "size", "fileLength", "stat", "dataSize", "fromBytesInt32", "read", "checksum", "name", "filename", "message", "context", "data", "calculatedChecksum", "buf", "decode", "close", "_writeFile", "encoded", "encode", "result", "Buffer", "alloc", "length", "writeInt32LE", "copy", "write", "dispose", "flush", "clear", "load", "closed", "getOrCreateFile", "forEach", "space", "state", "SPACE_ACTIVE", "err", "error", "identity", "haloSpace", "key", "map", "filter", "_loadSpaceLargeMetadata", "invitation", "invitations", "hasInvitationExpired", "isLegacyInvitationFormat", "removeInvitation", "invitationId", "_save", "emit", "toHex", "set", "_saveSpaceLargeMetadata", "_getLargeSpaceMetadata", "_getSpace", "spaceKey", "equals", "find", "hasSpace", "entry", "get", "delete", "getIdentityRecord", "setIdentityRecord", "record", "getInvitations", "addInvitation", "i", "push", "addSpace", "setSpaceDataLatestTimeframe", "timeframe", "dataTimeframe", "setSpaceControlLatestTimeframe", "controlTimeframe", "setCache", "cache", "setWritableFeedKeys", "controlFeedKey", "dataFeedKey", "setSpaceState", "getSpaceControlPipelineSnapshot", "controlPipelineSnapshot", "setSpaceControlPipelineSnapshot", "snapshot", "getSpaceEdgeReplicationSetting", "edgeReplication", "setSpaceEdgeReplicationSetting", "setting", "readInt32LE", "Boolean", "lifetime", "getTime", "now", "type", "Type", "MULTIUSE", "Event", "timed", "log", "Timeframe", "mapTimeframeToFeedIndexes", "timeframe", "frames", "map", "feedKey", "index", "mapFeedIndexesToTimeframe", "indexes", "startAfter", "TimeframeClock", "update", "_pendingTimeframe", "_timeframe", "pendingTimeframe", "setTimeframe", "emit", "updatePendingTimeframe", "key", "seq", "merge", "updateTimeframe", "hasGaps", "gaps", "dependencies", "isEmpty", "waitUntilReached", "target", "current", "waitForCondition", "deps", "Event", "Trigger", "sleepWithContext", "synchronized", "Context", "rejectOnDispose", "failUndefined", "FeedSetIterator", "invariant", "PublicKey", "log", "Timeframe", "ComplexMap", "invariant", "log", "createMessageSelector", "timeframeClock", "messages", "i", "length", "data", "timeframe", "hasGaps", "PipelineState", "_ctx", "Context", "timeframeUpdate", "_timeframeClock", "update", "stalled", "Event", "_startTimeframe", "Timeframe", "_targetTimeframe", "_reachedTargetPromise", "_reachedTarget", "_feeds", "endTimeframe", "mapFeedIndexesToTimeframe", "Array", "from", "values", "filter", "feed", "length", "map", "feedKey", "key", "index", "startTimeframe", "timeframe", "pendingTimeframe", "targetTimeframe", "reachedTarget", "feeds", "waitUntilTimeframe", "target", "waitUntilReached", "setTargetTimeframe", "waitUntilReachedTargetTimeframe", "ctx", "timeout", "breakOnStall", "log", "current", "Promise", "race", "waitForCondition", "dependencies", "isEmpty", "discardParameter", "waitForCount", "done", "rejectOnDispose", "then", "sleepWithContext", "warn", "Pipeline", "TimeframeClock", "ComplexMap", "PublicKey", "hash", "_state", "_processingTrigger", "Trigger", "wake", "_pauseTrigger", "_downloads", "value", "_feedSetIterator", "_writer", "_isStopping", "_isStarted", "_isBeingConsumed", "_isPaused", "state", "writer", "invariant", "hasFeed", "has", "getFeeds", "addFeed", "set", "_setFeedDownloadState", "setWriteFeed", "properties", "writable", "createMappedFeedWriter", "payload", "createFeedWriter", "start", "_initIterator", "open", "stop", "handle", "entries", "undownload", "clear", "close", "wait", "dispose", "undefined", "setCursor", "setTimeframe", "pause", "reset", "unpause", "consume", "lastFeedSetIterator", "iterable", "Symbol", "asyncIterator", "next", "block", "failUndefined", "updatePendingTimeframe", "seq", "updateTimeframe", "get", "truncate", "download", "linear", "err", "data", "FeedSetIterator", "createMessageSelector", "startAfter", "stallTimeout", "on", "iterator", "options", "size", "currentTimeframe", "emit", "runInContext", "scheduleTask", "Context", "randomBytes", "invariant", "log", "schema", "RpcExtension", "AuthExtension", "_ctx", "onError", "err", "catch", "_authProps", "requested", "AuthService", "getService", "exposed", "timeout", "getHandlers", "authenticate", "challenge", "credential", "provider", "Error", "error", "onOpen", "context", "rpc", "length", "success", "verifier", "onAuthSuccess", "close", "onAuthFailure", "onClose", "dispose", "onAbort", "Event", "scheduleMicroTask", "synchronized", "trackLeaks", "Resource", "invariant", "log", "logInfo", "AdmittedFeed", "trace", "Callback", "DeferredTask", "scheduleMicroTask", "sleepWithContext", "trackLeaks", "Context", "SpaceStateMachine", "PublicKey", "log", "AdmittedFeed", "Timeframe", "TimeSeriesCounter", "TimeUsageCounter", "trace", "Callback", "tracer", "TIMEFRAME_SAVE_DEBOUNCE_INTERVAL", "CONTROL_PIPELINE_SNAPSHOT_DELAY", "USE_SNAPSHOTS", "ControlPipeline", "_ctx", "Context", "_pipeline", "_spaceStateMachine", "_spaceKey", "_metadata", "_targetTimeframe", "_lastTimeframeSaveTime", "Date", "now", "onFeedAdmitted", "Callback", "onMemberRoleChanged", "onCredentialProcessed", "onDelegatedInvitation", "onDelegatedInvitationRemoved", "_usage", "TimeUsageCounter", "_mutations", "TimeSeriesCounter", "_snapshotTask", "DeferredTask", "sleepWithContext", "_saveSnapshot", "spaceKey", "genesisFeed", "feedProvider", "metadataStore", "Pipeline", "addFeed", "SpaceStateMachine", "set", "info", "log", "key", "assertion", "designation", "AdmittedFeed", "Designation", "CONTROL", "equals", "scheduleMicroTask", "feed", "disposed", "hasFeed", "err", "catch", "callIfSet", "spaceState", "pipeline", "setWriteFeed", "start", "ctx", "snapshot", "getSpaceControlPipelineSnapshot", "present", "tf", "timeframe", "_processSnapshot", "setTimeout", "_consumePipeline", "setCursor", "message", "messages", "result", "process", "credential", "sourceFeed", "feedKey", "skipVerification", "warn", "pause", "state", "credentialEntries", "map", "entry", "unpause", "getSnapshotLoggerContext", "setSpaceControlPipelineSnapshot", "msg", "consume", "span", "beginRecording", "inc", "_processMessage", "end", "seq", "data", "payload", "timer", "tracer", "mark", "PublicKey", "from", "_noteTargetStateIfNeeded", "pendingTimeframe", "schedule", "_saveTargetTimeframe", "stop", "dispose", "newTimeframe", "Timeframe", "merge", "setSpaceControlLatestTimeframe", "metricsCounter", "showInBrowserTimeline", "resource", "issuer", "subject", "id", "type", "Space", "Resource", "onCredentialProcessed", "Callback", "stateUpdate", "Event", "protocol", "_id", "_key", "_genesisFeedKey", "_feedProvider", "_controlPipeline", "_controlFeed", "_dataFeed", "params", "invariant", "spaceKey", "feedProvider", "id", "genesisFeed", "key", "ControlPipeline", "metadataStore", "onFeedAdmitted", "set", "info", "sparse", "assertion", "designation", "AdmittedFeed", "Designation", "DATA", "equals", "scheduleMicroTask", "_ctx", "addFeed", "credential", "callIfSet", "log", "emit", "onDelegatedInvitation", "invitation", "onDelegatedInvitationStatusChange", "onDelegatedInvitationRemoved", "onMemberRoleChanged", "changedMembers", "map", "m", "role", "onMemberRolesChanged", "genesisFeedKey", "controlFeedKey", "dataFeedKey", "spaceState", "controlPipeline", "pipeline", "setControlFeed", "feed", "setWriteFeed", "setDataFeed", "getControlFeeds", "Array", "from", "feeds", "values", "_open", "ctx", "start", "startProtocol", "isOpen", "_close", "stop", "span", "resource", "scheduleTask", "Context", "ProtocolError", "schema", "RpcExtension", "CredentialRetrieverExtension", "_ctx", "_request", "_onResult", "requested", "AdmissionDiscoveryService", "getService", "getHandlers", "onOpen", "context", "result", "rpc", "getAdmissionCredential", "wake", "admissionCredential", "err", "close", "onClose", "dispose", "onAbort", "CredentialServerExtension", "_space", "exposed", "request", "memberInfo", "spaceState", "members", "get", "memberKey", "credential", "message", "discoveryKey", "subtleCrypto", "PublicKey", "log", "logInfo", "MMSTTopology", "Teleport", "BlobSync", "ReplicatorExtension", "trace", "CallbackCollection", "ComplexMap", "MOCK_AUTH_PROVIDER", "nonce", "Buffer", "from", "MOCK_AUTH_VERIFIER", "credential", "SpaceProtocol", "_networkManager", "_swarmIdentity", "_onSessionAuth", "_onAuthFailure", "blobSync", "_disableP2pReplication", "_topic", "_spaceKey", "_feeds", "Set", "_sessions", "ComplexMap", "PublicKey", "hash", "_topology", "MMSTTopology", "originateConnections", "maxPeers", "sampleSize", "_connection", "feedAdded", "CallbackCollection", "sessions", "feeds", "_ownPeerKey", "peerKey", "topic", "swarmIdentity", "networkManager", "onSessionAuth", "onAuthFailure", "blobStore", "disableP2pReplication", "BlobSync", "subtleCrypto", "digest", "asBuffer", "then", "discoveryKey", "addFeed", "feed", "log", "key", "add", "session", "values", "replicator", "callSerial", "start", "ctx", "credentials", "credentialProvider", "open", "joinSwarm", "protocolProvider", "_createProtocolProvider", "topology", "label", "truncate", "updateTopology", "forceUpdate", "stop", "close", "wireProps", "SpaceProtocolSession", "set", "remotePeerId", "info", "resource", "AuthStatus", "_wireProps", "_blobSync", "_teleport", "ReplicatorExtension", "setOptions", "upload", "_authStatus", "authStatus", "stats", "Teleport", "stream", "sessionId", "addExtension", "AuthExtension", "provider", "verifier", "credentialAuthenticator", "onAuthSuccess", "createExtension", "abort", "parseAutomergeUrl", "Trigger", "synchronized", "trackLeaks", "getCredentialAssertion", "failUndefined", "PublicKey", "log", "trace", "ComplexMap", "SpaceManager", "_spaces", "ComplexMap", "PublicKey", "hash", "_feedStore", "_networkManager", "_metadataStore", "_blobStore", "_instanceId", "random", "toHex", "_disableP2pReplication", "feedStore", "networkManager", "metadataStore", "blobStore", "disableP2pReplication", "spaces", "open", "close", "Promise", "all", "values", "map", "space", "constructSpace", "metadata", "swarmIdentity", "onAuthorizedConnection", "onAuthFailure", "onDelegatedInvitationStatusChange", "onMemberRolesChanged", "memberKey", "log", "trace", "begin", "id", "spaceKey", "genesisFeedKey", "genesisFeed", "openFeed", "failUndefined", "key", "spaceId", "createIdFromSpaceKey", "protocol", "SpaceProtocol", "topic", "onSessionAuth", "Space", "feedProvider", "feedKey", "opts", "set", "end", "requestSpaceAdmissionCredential", "ctx", "params", "traceKey", "onCredentialResolved", "Trigger", "session", "addExtension", "CredentialRetrieverExtension", "identityKey", "start", "credential", "wait", "timeout", "err", "error", "stop", "findSpaceByRootDocumentId", "documentId", "find", "spaceState", "credentials", "some", "assertion", "getCredentialAssertion", "automergeRoot", "parseAutomergeUrl"]
|
|
7
|
+
}
|
|
@@ -44,6 +44,9 @@ var filterMatchObject = (filter, obj) => {
|
|
|
44
44
|
case "text-search": {
|
|
45
45
|
return false;
|
|
46
46
|
}
|
|
47
|
+
case "timestamp": {
|
|
48
|
+
throw new Error("Timestamp filters must be handled at the index level, not in-memory matching.");
|
|
49
|
+
}
|
|
47
50
|
case "not": {
|
|
48
51
|
return !filterMatchObject(filter.filter, obj);
|
|
49
52
|
}
|
|
@@ -101,6 +104,9 @@ var filterMatchObjectJSON = (filter, obj) => {
|
|
|
101
104
|
case "text-search": {
|
|
102
105
|
return false;
|
|
103
106
|
}
|
|
107
|
+
case "timestamp": {
|
|
108
|
+
throw new Error("Timestamp filters must be handled at the index level, not in-memory matching.");
|
|
109
|
+
}
|
|
104
110
|
case "not": {
|
|
105
111
|
return !filterMatchObjectJSON(filter.filter, obj);
|
|
106
112
|
}
|
|
@@ -232,4 +238,4 @@ export {
|
|
|
232
238
|
filterMatchObjectJSON,
|
|
233
239
|
filterMatchValue
|
|
234
240
|
};
|
|
235
|
-
//# sourceMappingURL=chunk-
|
|
241
|
+
//# sourceMappingURL=chunk-IMPFMBJK.mjs.map
|