@dxos/client-services 0.3.11-main.f14932f → 0.3.11-main.f4c1077

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/dist/lib/browser/{chunk-V3KUSOU6.mjs → chunk-RAYHTZLK.mjs} +245 -117
  2. package/dist/lib/browser/chunk-RAYHTZLK.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +1 -1
  4. package/dist/lib/browser/index.mjs.map +1 -1
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/packlets/testing/index.mjs +4 -11
  7. package/dist/lib/browser/packlets/testing/index.mjs.map +3 -3
  8. package/dist/lib/node/{chunk-AP42ZGGV.cjs → chunk-UFRBNZVF.cjs} +384 -256
  9. package/dist/lib/node/chunk-UFRBNZVF.cjs.map +7 -0
  10. package/dist/lib/node/index.cjs +37 -37
  11. package/dist/lib/node/index.cjs.map +1 -1
  12. package/dist/lib/node/meta.json +1 -1
  13. package/dist/lib/node/packlets/testing/index.cjs +11 -18
  14. package/dist/lib/node/packlets/testing/index.cjs.map +3 -3
  15. package/dist/types/src/packlets/identity/identity-service.d.ts +3 -3
  16. package/dist/types/src/packlets/identity/identity-service.d.ts.map +1 -1
  17. package/dist/types/src/packlets/invitations/device-invitation-protocol.d.ts +2 -0
  18. package/dist/types/src/packlets/invitations/device-invitation-protocol.d.ts.map +1 -1
  19. package/dist/types/src/packlets/invitations/invitation-protocol.d.ts +28 -3
  20. package/dist/types/src/packlets/invitations/invitation-protocol.d.ts.map +1 -1
  21. package/dist/types/src/packlets/invitations/invitations-handler.d.ts.map +1 -1
  22. package/dist/types/src/packlets/invitations/space-invitation-protocol.d.ts +2 -0
  23. package/dist/types/src/packlets/invitations/space-invitation-protocol.d.ts.map +1 -1
  24. package/dist/types/src/packlets/network/network-service.d.ts.map +1 -1
  25. package/dist/types/src/packlets/services/diagnostics.d.ts +32 -16
  26. package/dist/types/src/packlets/services/diagnostics.d.ts.map +1 -1
  27. package/dist/types/src/packlets/services/platform.d.ts +1 -14
  28. package/dist/types/src/packlets/services/platform.d.ts.map +1 -1
  29. package/dist/types/src/packlets/services/service-host.d.ts.map +1 -1
  30. package/dist/types/src/packlets/spaces/automerge-space-state.d.ts +2 -0
  31. package/dist/types/src/packlets/spaces/automerge-space-state.d.ts.map +1 -1
  32. package/dist/types/src/packlets/spaces/data-space-manager.d.ts.map +1 -1
  33. package/dist/types/src/packlets/spaces/data-space.d.ts +2 -0
  34. package/dist/types/src/packlets/spaces/data-space.d.ts.map +1 -1
  35. package/dist/types/src/packlets/system/system-service.d.ts +3 -2
  36. package/dist/types/src/packlets/system/system-service.d.ts.map +1 -1
  37. package/dist/types/src/packlets/testing/invitation-utils.d.ts.map +1 -1
  38. package/dist/types/src/version.d.ts +1 -1
  39. package/package.json +35 -35
  40. package/src/packlets/identity/identity-manager.ts +1 -1
  41. package/src/packlets/identity/identity-service.test.ts +1 -1
  42. package/src/packlets/identity/identity-service.ts +6 -3
  43. package/src/packlets/invitations/device-invitation-protocol.test.ts +14 -0
  44. package/src/packlets/invitations/device-invitation-protocol.ts +14 -0
  45. package/src/packlets/invitations/invitation-protocol.ts +44 -6
  46. package/src/packlets/invitations/invitations-handler.ts +20 -18
  47. package/src/packlets/invitations/space-invitation-protocol.test.ts +28 -0
  48. package/src/packlets/invitations/space-invitation-protocol.ts +11 -0
  49. package/src/packlets/network/network-service.ts +5 -1
  50. package/src/packlets/services/diagnostics.ts +52 -16
  51. package/src/packlets/services/platform.ts +7 -19
  52. package/src/packlets/services/service-host.ts +27 -12
  53. package/src/packlets/spaces/automerge-space-state.ts +4 -0
  54. package/src/packlets/spaces/data-space-manager.ts +5 -1
  55. package/src/packlets/spaces/data-space.ts +37 -4
  56. package/src/packlets/spaces/spaces-service.ts +3 -3
  57. package/src/packlets/system/system-service.ts +7 -1
  58. package/src/packlets/testing/invitation-utils.ts +2 -10
  59. package/src/version.ts +1 -1
  60. package/dist/lib/browser/chunk-V3KUSOU6.mjs.map +0 -7
  61. package/dist/lib/node/chunk-AP42ZGGV.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
- onNetworkConnection: (session) => {
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
- ? SpaceMember.PresenceState.ONLINE
226
- : SpaceMember.PresenceState.OFFLINE,
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.f14932f";
1
+ export const DXOS_VERSION = "0.3.11-main.f4c1077";