@dxos/client-services 0.3.11-main.ec7a2b3 → 0.3.11-main.ee2b64c
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-XM2TLK6X.mjs → chunk-3DRZQ4U6.mjs} +244 -117
- package/dist/lib/browser/chunk-3DRZQ4U6.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +1 -1
- package/dist/lib/browser/index.mjs.map +1 -1
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/packlets/testing/index.mjs +4 -11
- package/dist/lib/browser/packlets/testing/index.mjs.map +3 -3
- package/dist/lib/node/{chunk-YNYJIGPD.cjs → chunk-JUJNN3NE.cjs} +383 -256
- package/dist/lib/node/chunk-JUJNN3NE.cjs.map +7 -0
- package/dist/lib/node/index.cjs +37 -37
- package/dist/lib/node/index.cjs.map +1 -1
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/packlets/testing/index.cjs +11 -18
- package/dist/lib/node/packlets/testing/index.cjs.map +3 -3
- package/dist/types/src/packlets/identity/identity-service.d.ts +3 -3
- package/dist/types/src/packlets/identity/identity-service.d.ts.map +1 -1
- package/dist/types/src/packlets/invitations/device-invitation-protocol.d.ts +2 -0
- package/dist/types/src/packlets/invitations/device-invitation-protocol.d.ts.map +1 -1
- package/dist/types/src/packlets/invitations/invitation-protocol.d.ts +28 -3
- package/dist/types/src/packlets/invitations/invitation-protocol.d.ts.map +1 -1
- package/dist/types/src/packlets/invitations/invitations-handler.d.ts.map +1 -1
- package/dist/types/src/packlets/invitations/space-invitation-protocol.d.ts +2 -0
- package/dist/types/src/packlets/invitations/space-invitation-protocol.d.ts.map +1 -1
- package/dist/types/src/packlets/network/network-service.d.ts.map +1 -1
- package/dist/types/src/packlets/services/diagnostics.d.ts +32 -16
- package/dist/types/src/packlets/services/diagnostics.d.ts.map +1 -1
- package/dist/types/src/packlets/services/platform.d.ts +1 -14
- package/dist/types/src/packlets/services/platform.d.ts.map +1 -1
- package/dist/types/src/packlets/services/service-host.d.ts.map +1 -1
- package/dist/types/src/packlets/spaces/automerge-space-state.d.ts +2 -0
- package/dist/types/src/packlets/spaces/automerge-space-state.d.ts.map +1 -1
- package/dist/types/src/packlets/spaces/data-space-manager.d.ts.map +1 -1
- package/dist/types/src/packlets/spaces/data-space.d.ts +2 -0
- package/dist/types/src/packlets/spaces/data-space.d.ts.map +1 -1
- package/dist/types/src/packlets/system/system-service.d.ts +3 -2
- package/dist/types/src/packlets/system/system-service.d.ts.map +1 -1
- package/dist/types/src/packlets/testing/invitation-utils.d.ts.map +1 -1
- package/dist/types/src/version.d.ts +1 -1
- package/package.json +35 -35
- package/src/packlets/identity/identity-manager.ts +1 -1
- package/src/packlets/identity/identity-service.test.ts +1 -1
- package/src/packlets/identity/identity-service.ts +6 -3
- package/src/packlets/invitations/device-invitation-protocol.test.ts +14 -0
- package/src/packlets/invitations/device-invitation-protocol.ts +14 -0
- package/src/packlets/invitations/invitation-protocol.ts +44 -6
- package/src/packlets/invitations/invitations-handler.ts +19 -17
- package/src/packlets/invitations/space-invitation-protocol.test.ts +28 -0
- package/src/packlets/invitations/space-invitation-protocol.ts +11 -0
- package/src/packlets/network/network-service.ts +5 -1
- package/src/packlets/services/diagnostics.ts +52 -16
- package/src/packlets/services/platform.ts +7 -19
- package/src/packlets/services/service-host.ts +27 -12
- package/src/packlets/spaces/automerge-space-state.ts +4 -0
- package/src/packlets/spaces/data-space-manager.ts +5 -1
- package/src/packlets/spaces/data-space.ts +37 -4
- package/src/packlets/spaces/spaces-service.ts +3 -3
- package/src/packlets/system/system-service.ts +7 -1
- package/src/packlets/testing/invitation-utils.ts +2 -10
- package/src/version.ts +1 -1
- package/dist/lib/browser/chunk-XM2TLK6X.mjs.map +0 -7
- package/dist/lib/node/chunk-YNYJIGPD.cjs.map +0 -7
|
@@ -9,6 +9,8 @@ export class AutomergeSpaceState implements CredentialProcessor {
|
|
|
9
9
|
public rootUrl: string | undefined = undefined;
|
|
10
10
|
public lastEpoch: SpecificCredential<Epoch> | undefined = undefined;
|
|
11
11
|
|
|
12
|
+
constructor(private readonly _onNewRoot: (rootUrl: string) => void) {}
|
|
13
|
+
|
|
12
14
|
async processCredential(credential: Credential) {
|
|
13
15
|
if (!checkCredentialType(credential, 'dxos.halo.credentials.Epoch')) {
|
|
14
16
|
return;
|
|
@@ -17,6 +19,8 @@ export class AutomergeSpaceState implements CredentialProcessor {
|
|
|
17
19
|
this.lastEpoch = credential;
|
|
18
20
|
if (credential.subject.assertion.automergeRoot) {
|
|
19
21
|
this.rootUrl = credential.subject.assertion.automergeRoot;
|
|
22
|
+
|
|
23
|
+
this._onNewRoot(this.rootUrl);
|
|
20
24
|
}
|
|
21
25
|
}
|
|
22
26
|
}
|
|
@@ -143,6 +143,9 @@ export class DataSpaceManager {
|
|
|
143
143
|
const space = await this._constructSpace(metadata);
|
|
144
144
|
|
|
145
145
|
const automergeRoot = this._automergeHost.repo.create();
|
|
146
|
+
automergeRoot.change((doc: any) => {
|
|
147
|
+
doc.experimental_spaceKey = spaceKey.toHex();
|
|
148
|
+
});
|
|
146
149
|
|
|
147
150
|
const credentials = await spaceGenesis(this._keyring, this._signingContext, space.inner, automergeRoot.url);
|
|
148
151
|
await this._metadataStore.addSpace(metadata);
|
|
@@ -222,12 +225,13 @@ export class DataSpaceManager {
|
|
|
222
225
|
credentialProvider: createAuthProvider(this._signingContext.credentialSigner),
|
|
223
226
|
credentialAuthenticator: deferFunction(() => dataSpace.authVerifier.verifier),
|
|
224
227
|
},
|
|
225
|
-
|
|
228
|
+
onAuthorizedConnection: (session) => {
|
|
226
229
|
session.addExtension(
|
|
227
230
|
'dxos.mesh.teleport.gossip',
|
|
228
231
|
gossip.createExtension({ remotePeerId: session.remotePeerId }),
|
|
229
232
|
);
|
|
230
233
|
session.addExtension('dxos.mesh.teleport.notarization', dataSpace.notarizationPlugin.createExtension());
|
|
234
|
+
this._automergeHost.authorizeDevice(space.key, session.remotePeerId);
|
|
231
235
|
session.addExtension('dxos.mesh.teleport.automerge', this._automergeHost.createExtension());
|
|
232
236
|
},
|
|
233
237
|
onAuthFailure: () => {
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
// Copyright 2022 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { Event, scheduleTask, sleep, synchronized, trackLeaks } from '@dxos/async';
|
|
5
|
+
import { Event, asyncTimeout, scheduleTask, sleep, synchronized, trackLeaks } from '@dxos/async';
|
|
6
6
|
import { AUTH_TIMEOUT } from '@dxos/client-protocol';
|
|
7
|
-
import { cancelWithContext, Context } from '@dxos/context';
|
|
7
|
+
import { cancelWithContext, Context, ContextDisposedError } from '@dxos/context';
|
|
8
8
|
import { timed } from '@dxos/debug';
|
|
9
9
|
import {
|
|
10
10
|
type MetadataStore,
|
|
@@ -15,6 +15,7 @@ import {
|
|
|
15
15
|
type AutomergeHost,
|
|
16
16
|
} from '@dxos/echo-pipeline';
|
|
17
17
|
import { type FeedStore } from '@dxos/feed-store';
|
|
18
|
+
import { failedInvariant } from '@dxos/invariant';
|
|
18
19
|
import { type Keyring } from '@dxos/keyring';
|
|
19
20
|
import { PublicKey } from '@dxos/keys';
|
|
20
21
|
import { log } from '@dxos/log';
|
|
@@ -77,9 +78,12 @@ export type DataSpaceParams = {
|
|
|
77
78
|
const ENABLE_FEED_PURGE = false;
|
|
78
79
|
|
|
79
80
|
@trackLeaks('open', 'close')
|
|
81
|
+
@trace.resource()
|
|
80
82
|
export class DataSpace {
|
|
81
83
|
private _ctx = new Context();
|
|
84
|
+
@trace.info()
|
|
82
85
|
private readonly _inner: Space;
|
|
86
|
+
|
|
83
87
|
private readonly _gossip: Gossip;
|
|
84
88
|
private readonly _presence: Presence;
|
|
85
89
|
private readonly _keyring: Keyring;
|
|
@@ -92,7 +96,7 @@ export class DataSpace {
|
|
|
92
96
|
private readonly _automergeHost: AutomergeHost;
|
|
93
97
|
|
|
94
98
|
// TODO(dmaretskyi): Move into Space?
|
|
95
|
-
private readonly _automergeSpaceState = new AutomergeSpaceState();
|
|
99
|
+
private readonly _automergeSpaceState = new AutomergeSpaceState((rootUrl) => this._onNewAutomergeRoot(rootUrl));
|
|
96
100
|
|
|
97
101
|
private _state = SpaceState.CLOSED;
|
|
98
102
|
|
|
@@ -137,6 +141,7 @@ export class DataSpace {
|
|
|
137
141
|
log('new state', { state: SpaceState[this._state] });
|
|
138
142
|
}
|
|
139
143
|
|
|
144
|
+
@trace.info()
|
|
140
145
|
get key() {
|
|
141
146
|
return this._inner.key;
|
|
142
147
|
}
|
|
@@ -145,6 +150,7 @@ export class DataSpace {
|
|
|
145
150
|
return this._inner.isOpen;
|
|
146
151
|
}
|
|
147
152
|
|
|
153
|
+
@trace.info({ enum: SpaceState })
|
|
148
154
|
get state(): SpaceState {
|
|
149
155
|
return this._state;
|
|
150
156
|
}
|
|
@@ -174,6 +180,14 @@ export class DataSpace {
|
|
|
174
180
|
return this._automergeSpaceState;
|
|
175
181
|
}
|
|
176
182
|
|
|
183
|
+
@trace.info({ depth: null })
|
|
184
|
+
private get _automergeInfo() {
|
|
185
|
+
return {
|
|
186
|
+
rootUrl: this._automergeSpaceState.rootUrl,
|
|
187
|
+
lastEpoch: this._automergeSpaceState.lastEpoch,
|
|
188
|
+
};
|
|
189
|
+
}
|
|
190
|
+
|
|
177
191
|
@synchronized
|
|
178
192
|
async open() {
|
|
179
193
|
await this._open();
|
|
@@ -232,7 +246,7 @@ export class DataSpace {
|
|
|
232
246
|
this.metrics.pipelineInitBegin = new Date();
|
|
233
247
|
await this.initializeDataPipeline();
|
|
234
248
|
} catch (err) {
|
|
235
|
-
if (err instanceof CancelledError) {
|
|
249
|
+
if (err instanceof CancelledError || err instanceof ContextDisposedError) {
|
|
236
250
|
log('data pipeline initialization cancelled', err);
|
|
237
251
|
return;
|
|
238
252
|
}
|
|
@@ -363,6 +377,25 @@ export class DataSpace {
|
|
|
363
377
|
}
|
|
364
378
|
}
|
|
365
379
|
|
|
380
|
+
private _onNewAutomergeRoot(rootUrl: string) {
|
|
381
|
+
log('loading automerge root doc for space', { space: this.key, rootUrl });
|
|
382
|
+
const handle = this._automergeHost.repo.find(rootUrl as any);
|
|
383
|
+
|
|
384
|
+
queueMicrotask(async () => {
|
|
385
|
+
try {
|
|
386
|
+
await asyncTimeout(handle.whenReady(), 5_000);
|
|
387
|
+
const doc = handle.docSync() ?? failedInvariant();
|
|
388
|
+
if (!doc.experimental_spaceKey) {
|
|
389
|
+
handle.change((doc: any) => {
|
|
390
|
+
doc.experimental_spaceKey = this.key.toHex();
|
|
391
|
+
});
|
|
392
|
+
}
|
|
393
|
+
} catch (err) {
|
|
394
|
+
log.warn('error loading automerge root doc', { space: this.key, rootUrl, err });
|
|
395
|
+
}
|
|
396
|
+
});
|
|
397
|
+
}
|
|
398
|
+
|
|
366
399
|
// TODO(dmaretskyi): Use profile from signing context.
|
|
367
400
|
async updateOwnProfile(profile: ProfileDocument) {
|
|
368
401
|
const credential = await this._signingContext.credentialSigner.createCredential({
|
|
@@ -41,7 +41,7 @@ export class SpacesServiceImpl implements SpacesService {
|
|
|
41
41
|
|
|
42
42
|
async createSpace(): Promise<Space> {
|
|
43
43
|
if (!this._identityManager.identity) {
|
|
44
|
-
throw new Error('This device has no HALO identity available. See https://docs.dxos.org/guide/halo');
|
|
44
|
+
throw new Error('This device has no HALO identity available. See https://docs.dxos.org/guide/platform/halo');
|
|
45
45
|
}
|
|
46
46
|
|
|
47
47
|
const dataSpaceManager = await this._getDataSpaceManager();
|
|
@@ -222,8 +222,8 @@ export class SpacesServiceImpl implements SpacesService {
|
|
|
222
222
|
presence: member.removed
|
|
223
223
|
? SpaceMember.PresenceState.REMOVED
|
|
224
224
|
: isMe || peers.length > 0
|
|
225
|
-
|
|
226
|
-
|
|
225
|
+
? SpaceMember.PresenceState.ONLINE
|
|
226
|
+
: SpaceMember.PresenceState.OFFLINE,
|
|
227
227
|
peerStates: peers,
|
|
228
228
|
};
|
|
229
229
|
}),
|
|
@@ -12,16 +12,18 @@ import {
|
|
|
12
12
|
type UpdateStatusRequest,
|
|
13
13
|
type QueryStatusRequest,
|
|
14
14
|
type QueryStatusResponse,
|
|
15
|
+
type Platform,
|
|
15
16
|
} from '@dxos/protocols/proto/dxos/client/services';
|
|
16
17
|
import { jsonKeyReplacer, type MaybePromise } from '@dxos/util';
|
|
17
18
|
|
|
18
19
|
import { type Diagnostics } from '../services';
|
|
20
|
+
import { getPlatform } from '../services/platform';
|
|
19
21
|
|
|
20
22
|
export type SystemServiceOptions = {
|
|
21
23
|
config?: Config;
|
|
22
24
|
statusUpdate: Event<void>;
|
|
23
25
|
getCurrentStatus: () => SystemStatus;
|
|
24
|
-
getDiagnostics: () => Promise<Partial<Diagnostics>>;
|
|
26
|
+
getDiagnostics: () => Promise<Partial<Diagnostics['services']>>;
|
|
25
27
|
onUpdateStatus: (status: SystemStatus) => MaybePromise<void>;
|
|
26
28
|
onReset: () => MaybePromise<void>;
|
|
27
29
|
};
|
|
@@ -73,6 +75,10 @@ export class SystemServiceImpl implements SystemService {
|
|
|
73
75
|
};
|
|
74
76
|
}
|
|
75
77
|
|
|
78
|
+
async getPlatform(): Promise<Platform> {
|
|
79
|
+
return getPlatform();
|
|
80
|
+
}
|
|
81
|
+
|
|
76
82
|
async updateStatus({ status }: UpdateStatusRequest) {
|
|
77
83
|
await this._onUpdateStatus(status);
|
|
78
84
|
}
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { Trigger } from '@dxos/async';
|
|
6
|
-
import { type AuthenticatingInvitation, type CancellableInvitation } from '@dxos/client-protocol';
|
|
6
|
+
import { InvitationEncoder, type AuthenticatingInvitation, type CancellableInvitation } from '@dxos/client-protocol';
|
|
7
7
|
import { invariant } from '@dxos/invariant';
|
|
8
8
|
import { Invitation } from '@dxos/protocols/proto/dxos/client/services';
|
|
9
9
|
|
|
@@ -13,15 +13,7 @@ import { ServiceContext } from '../services';
|
|
|
13
13
|
* Strip secrets from invitation before giving it to the peer.
|
|
14
14
|
*/
|
|
15
15
|
export const sanitizeInvitation = (invitation: Invitation): Invitation => {
|
|
16
|
-
return
|
|
17
|
-
invitationId: invitation.invitationId,
|
|
18
|
-
type: invitation.type,
|
|
19
|
-
kind: invitation.kind,
|
|
20
|
-
authMethod: invitation.authMethod,
|
|
21
|
-
swarmKey: invitation.swarmKey,
|
|
22
|
-
state: invitation.state,
|
|
23
|
-
timeout: invitation.timeout,
|
|
24
|
-
};
|
|
16
|
+
return InvitationEncoder.decode(InvitationEncoder.encode(invitation));
|
|
25
17
|
};
|
|
26
18
|
|
|
27
19
|
export type InvitationHost = {
|
package/src/version.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export const DXOS_VERSION = "0.3.11-main.
|
|
1
|
+
export const DXOS_VERSION = "0.3.11-main.ee2b64c";
|