@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.
Files changed (61) hide show
  1. package/dist/lib/browser/{chunk-XM2TLK6X.mjs → chunk-3DRZQ4U6.mjs} +244 -117
  2. package/dist/lib/browser/chunk-3DRZQ4U6.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-YNYJIGPD.cjs → chunk-JUJNN3NE.cjs} +383 -256
  9. package/dist/lib/node/chunk-JUJNN3NE.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 +19 -17
  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-XM2TLK6X.mjs.map +0 -7
  61. package/dist/lib/node/chunk-YNYJIGPD.cjs.map +0 -7
@@ -483,7 +483,7 @@ function _ts_decorate(decorators, target, key, desc) {
483
483
  return c > 3 && r && Object.defineProperty(target, key, r), r;
484
484
  }
485
485
  var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/identity/identity.ts";
486
- var Identity = class Identity2 {
486
+ var Identity = class {
487
487
  constructor({ space, signer, identityKey, deviceKey }) {
488
488
  this.stateUpdate = new Event();
489
489
  this.space = space;
@@ -665,7 +665,7 @@ function _ts_decorate2(decorators, target, key, desc) {
665
665
  return c > 3 && r && Object.defineProperty(target, key, r), r;
666
666
  }
667
667
  var __dxlog_file3 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/identity/identity-manager.ts";
668
- var IdentityManager = class IdentityManager2 {
668
+ var IdentityManager = class {
669
669
  // TODO(burdon): IdentityManagerParams.
670
670
  // TODO(dmaretskyi): Perhaps this should take/generate the peerKey outside of an initialized identity.
671
671
  constructor(_metadataStore, _keyring, _feedStore, _spaceManager) {
@@ -996,7 +996,7 @@ var IdentityManager = class IdentityManager2 {
996
996
  genesisFeedKey: spaceRecord.genesisFeedKey
997
997
  },
998
998
  swarmIdentity,
999
- onNetworkConnection: () => {
999
+ onAuthorizedConnection: () => {
1000
1000
  },
1001
1001
  onAuthFailure: () => {
1002
1002
  log3.warn("auth failure", void 0, {
@@ -1025,6 +1025,7 @@ import { signPresentation } from "@dxos/credentials";
1025
1025
  import { todo } from "@dxos/debug";
1026
1026
  import { invariant as invariant3 } from "@dxos/invariant";
1027
1027
  var __dxlog_file4 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/identity/identity-service.ts";
1028
+ var CREATE_PROFILE_WITH_AUTOMERGE_DEFAULT = true;
1028
1029
  var IdentityServiceImpl = class {
1029
1030
  constructor(_createIdentity, _identityManager, _keyring, _onProfileUpdate) {
1030
1031
  this._createIdentity = _createIdentity;
@@ -1033,7 +1034,7 @@ var IdentityServiceImpl = class {
1033
1034
  this._onProfileUpdate = _onProfileUpdate;
1034
1035
  }
1035
1036
  async createIdentity(request) {
1036
- await this._createIdentity(request);
1037
+ await this._createIdentity(request.profile ?? {}, request.useAutomerge ?? CREATE_PROFILE_WITH_AUTOMERGE_DEFAULT);
1037
1038
  return this._getIdentity();
1038
1039
  }
1039
1040
  async recoverIdentity(request) {
@@ -1061,7 +1062,7 @@ var IdentityServiceImpl = class {
1061
1062
  async updateProfile(profile) {
1062
1063
  invariant3(this._identityManager.identity, "Identity not initialized.", {
1063
1064
  F: __dxlog_file4,
1064
- L: 60,
1065
+ L: 63,
1065
1066
  S: this,
1066
1067
  A: [
1067
1068
  "this._identityManager.identity",
@@ -1075,7 +1076,7 @@ var IdentityServiceImpl = class {
1075
1076
  async signPresentation({ presentation, nonce }) {
1076
1077
  invariant3(this._identityManager.identity, "Identity not initialized.", {
1077
1078
  F: __dxlog_file4,
1078
- L: 67,
1079
+ L: 70,
1079
1080
  S: this,
1080
1081
  A: [
1081
1082
  "this._identityManager.identity",
@@ -1094,6 +1095,7 @@ var IdentityServiceImpl = class {
1094
1095
 
1095
1096
  // packages/sdk/client-services/src/packlets/invitations/device-invitation-protocol.ts
1096
1097
  import { invariant as invariant4 } from "@dxos/invariant";
1098
+ import { AlreadyJoinedError } from "@dxos/protocols";
1097
1099
  import { Invitation } from "@dxos/protocols/proto/dxos/client/services";
1098
1100
  var __dxlog_file5 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/invitations/device-invitation-protocol.ts";
1099
1101
  var DeviceInvitationProtocol = class {
@@ -1113,7 +1115,7 @@ var DeviceInvitationProtocol = class {
1113
1115
  async admit(request) {
1114
1116
  invariant4(request.device, void 0, {
1115
1117
  F: __dxlog_file5,
1116
- L: 35,
1118
+ L: 36,
1117
1119
  S: this,
1118
1120
  A: [
1119
1121
  "request.device",
@@ -1131,6 +1133,15 @@ var DeviceInvitationProtocol = class {
1131
1133
  }
1132
1134
  };
1133
1135
  }
1136
+ checkInvitation(invitation) {
1137
+ try {
1138
+ const identity = this._getIdentity();
1139
+ if (identity) {
1140
+ return new AlreadyJoinedError("Currently only one identity per client is supported.");
1141
+ }
1142
+ } catch {
1143
+ }
1144
+ }
1134
1145
  createIntroduction() {
1135
1146
  return {};
1136
1147
  }
@@ -1149,7 +1160,7 @@ var DeviceInvitationProtocol = class {
1149
1160
  async accept(response, request) {
1150
1161
  invariant4(response.device, void 0, {
1151
1162
  F: __dxlog_file5,
1152
- L: 68,
1163
+ L: 80,
1153
1164
  S: this,
1154
1165
  A: [
1155
1166
  "response.device",
@@ -1159,7 +1170,7 @@ var DeviceInvitationProtocol = class {
1159
1170
  const { identityKey, haloSpaceKey, genesisFeedKey, controlTimeframe } = response.device;
1160
1171
  invariant4(request.device, void 0, {
1161
1172
  F: __dxlog_file5,
1162
- L: 71,
1173
+ L: 83,
1163
1174
  S: this,
1164
1175
  A: [
1165
1176
  "request.device",
@@ -1941,16 +1952,12 @@ var InvitationsHandler = class {
1941
1952
  }
1942
1953
  }
1943
1954
  }
1944
- } else {
1945
- setState({
1946
- state: Invitation3.State.READY_FOR_AUTHENTICATION
1947
- });
1948
1955
  }
1949
1956
  log5("request admission", {
1950
1957
  ...protocol.toJSON()
1951
1958
  }, {
1952
1959
  F: __dxlog_file7,
1953
- L: 312,
1960
+ L: 309,
1954
1961
  S: this,
1955
1962
  C: (f, a) => f(...a)
1956
1963
  });
@@ -1962,7 +1969,7 @@ var InvitationsHandler = class {
1962
1969
  ...protocol.toJSON()
1963
1970
  }, {
1964
1971
  F: __dxlog_file7,
1965
- L: 323,
1972
+ L: 320,
1966
1973
  S: this,
1967
1974
  C: (f, a) => f(...a)
1968
1975
  });
@@ -1975,7 +1982,7 @@ var InvitationsHandler = class {
1975
1982
  id: traceId
1976
1983
  }), {
1977
1984
  F: __dxlog_file7,
1978
- L: 325,
1985
+ L: 322,
1979
1986
  S: this,
1980
1987
  C: (f, a) => f(...a)
1981
1988
  });
@@ -1985,7 +1992,7 @@ var InvitationsHandler = class {
1985
1992
  ...protocol.toJSON()
1986
1993
  }, {
1987
1994
  F: __dxlog_file7,
1988
- L: 328,
1995
+ L: 325,
1989
1996
  S: this,
1990
1997
  C: (f, a) => f(...a)
1991
1998
  });
@@ -1995,7 +2002,7 @@ var InvitationsHandler = class {
1995
2002
  } else {
1996
2003
  log5("auth failed", err, {
1997
2004
  F: __dxlog_file7,
1998
- L: 331,
2005
+ L: 328,
1999
2006
  S: this,
2000
2007
  C: (f, a) => f(...a)
2001
2008
  });
@@ -2006,7 +2013,7 @@ var InvitationsHandler = class {
2006
2013
  error: err
2007
2014
  }), {
2008
2015
  F: __dxlog_file7,
2009
- L: 334,
2016
+ L: 331,
2010
2017
  S: this,
2011
2018
  C: (f, a) => f(...a)
2012
2019
  });
@@ -2024,7 +2031,7 @@ var InvitationsHandler = class {
2024
2031
  ...protocol.toJSON()
2025
2032
  }, {
2026
2033
  F: __dxlog_file7,
2027
- L: 345,
2034
+ L: 342,
2028
2035
  S: this,
2029
2036
  C: (f, a) => f(...a)
2030
2037
  });
@@ -2034,7 +2041,7 @@ var InvitationsHandler = class {
2034
2041
  } else {
2035
2042
  log5("auth failed", err, {
2036
2043
  F: __dxlog_file7,
2037
- L: 348,
2044
+ L: 345,
2038
2045
  S: this,
2039
2046
  C: (f, a) => f(...a)
2040
2047
  });
@@ -2045,29 +2052,34 @@ var InvitationsHandler = class {
2045
2052
  return extension;
2046
2053
  };
2047
2054
  scheduleTask2(ctx, async () => {
2048
- invariant6(invitation.swarmKey, void 0, {
2049
- F: __dxlog_file7,
2050
- L: 358,
2051
- S: this,
2052
- A: [
2053
- "invitation.swarmKey",
2054
- ""
2055
- ]
2056
- });
2057
- const topic = invitation.swarmKey;
2058
- const swarmConnection = await this._networkManager.joinSwarm({
2059
- topic,
2060
- peerId: PublicKey6.random(),
2061
- protocolProvider: createTeleportProtocolFactory(async (teleport) => {
2062
- teleport.addExtension("dxos.halo.invitations", createExtension());
2063
- }),
2064
- topology: new StarTopology(topic),
2065
- label: "invitation guest"
2066
- });
2067
- ctx.onDispose(() => swarmConnection.close());
2068
- setState({
2069
- state: Invitation3.State.CONNECTING
2070
- });
2055
+ const error = protocol.checkInvitation(invitation);
2056
+ if (error) {
2057
+ stream.error(error);
2058
+ } else {
2059
+ invariant6(invitation.swarmKey, void 0, {
2060
+ F: __dxlog_file7,
2061
+ L: 359,
2062
+ S: this,
2063
+ A: [
2064
+ "invitation.swarmKey",
2065
+ ""
2066
+ ]
2067
+ });
2068
+ const topic = invitation.swarmKey;
2069
+ const swarmConnection = await this._networkManager.joinSwarm({
2070
+ topic,
2071
+ peerId: PublicKey6.random(),
2072
+ protocolProvider: createTeleportProtocolFactory(async (teleport) => {
2073
+ teleport.addExtension("dxos.halo.invitations", createExtension());
2074
+ }),
2075
+ topology: new StarTopology(topic),
2076
+ label: "invitation guest"
2077
+ });
2078
+ ctx.onDispose(() => swarmConnection.close());
2079
+ setState({
2080
+ state: Invitation3.State.CONNECTING
2081
+ });
2082
+ }
2071
2083
  });
2072
2084
  const observable = new AuthenticatingInvitation({
2073
2085
  initialInvitation: invitation,
@@ -2273,6 +2285,7 @@ import { createAdmissionCredentials, getCredentialAssertion } from "@dxos/creden
2273
2285
  import { writeMessages as writeMessages2 } from "@dxos/feed-store";
2274
2286
  import { invariant as invariant8 } from "@dxos/invariant";
2275
2287
  import { log as log7 } from "@dxos/log";
2288
+ import { AlreadyJoinedError as AlreadyJoinedError2 } from "@dxos/protocols";
2276
2289
  import { Invitation as Invitation5 } from "@dxos/protocols/proto/dxos/client/services";
2277
2290
  var __dxlog_file9 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/invitations/space-invitation-protocol.ts";
2278
2291
  var SpaceInvitationProtocol = class {
@@ -2297,7 +2310,7 @@ var SpaceInvitationProtocol = class {
2297
2310
  async admit(request, guestProfile) {
2298
2311
  invariant8(this._spaceKey, void 0, {
2299
2312
  F: __dxlog_file9,
2300
- L: 46,
2313
+ L: 47,
2301
2314
  S: this,
2302
2315
  A: [
2303
2316
  "this._spaceKey",
@@ -2307,7 +2320,7 @@ var SpaceInvitationProtocol = class {
2307
2320
  const space = await this._spaceManager.spaces.get(this._spaceKey);
2308
2321
  invariant8(space, void 0, {
2309
2322
  F: __dxlog_file9,
2310
- L: 48,
2323
+ L: 49,
2311
2324
  S: this,
2312
2325
  A: [
2313
2326
  "space",
@@ -2316,7 +2329,7 @@ var SpaceInvitationProtocol = class {
2316
2329
  });
2317
2330
  invariant8(request.space, void 0, {
2318
2331
  F: __dxlog_file9,
2319
- L: 50,
2332
+ L: 51,
2320
2333
  S: this,
2321
2334
  A: [
2322
2335
  "request.space",
@@ -2329,14 +2342,14 @@ var SpaceInvitationProtocol = class {
2329
2342
  guest: deviceKey
2330
2343
  }, {
2331
2344
  F: __dxlog_file9,
2332
- L: 53,
2345
+ L: 54,
2333
2346
  S: this,
2334
2347
  C: (f, a) => f(...a)
2335
2348
  });
2336
2349
  const credentials = await createAdmissionCredentials(this._signingContext.credentialSigner, identityKey, space.key, space.inner.genesisFeedKey, guestProfile);
2337
2350
  invariant8(credentials[0].credential, void 0, {
2338
2351
  F: __dxlog_file9,
2339
- L: 64,
2352
+ L: 65,
2340
2353
  S: this,
2341
2354
  A: [
2342
2355
  "credentials[0].credential",
@@ -2346,7 +2359,7 @@ var SpaceInvitationProtocol = class {
2346
2359
  const spaceMemberCredential = credentials[0].credential.credential;
2347
2360
  invariant8(getCredentialAssertion(spaceMemberCredential)["@type"] === "dxos.halo.credentials.SpaceMember", void 0, {
2348
2361
  F: __dxlog_file9,
2349
- L: 66,
2362
+ L: 67,
2350
2363
  S: this,
2351
2364
  A: [
2352
2365
  "getCredentialAssertion(spaceMemberCredential)['@type'] === 'dxos.halo.credentials.SpaceMember'",
@@ -2362,6 +2375,11 @@ var SpaceInvitationProtocol = class {
2362
2375
  }
2363
2376
  };
2364
2377
  }
2378
+ checkInvitation(invitation) {
2379
+ if (invitation.spaceKey && this._spaceManager.spaces.has(invitation.spaceKey)) {
2380
+ return new AlreadyJoinedError2("Already joined space.");
2381
+ }
2382
+ }
2365
2383
  createIntroduction() {
2366
2384
  return {
2367
2385
  profile: this._signingContext.getProfile()
@@ -2382,7 +2400,7 @@ var SpaceInvitationProtocol = class {
2382
2400
  async accept(response) {
2383
2401
  invariant8(response.space, void 0, {
2384
2402
  F: __dxlog_file9,
2385
- L: 101,
2403
+ L: 108,
2386
2404
  S: this,
2387
2405
  A: [
2388
2406
  "response.space",
@@ -2393,7 +2411,7 @@ var SpaceInvitationProtocol = class {
2393
2411
  const assertion = getCredentialAssertion(credential);
2394
2412
  invariant8(assertion["@type"] === "dxos.halo.credentials.SpaceMember", "Invalid credential", {
2395
2413
  F: __dxlog_file9,
2396
- L: 104,
2414
+ L: 111,
2397
2415
  S: this,
2398
2416
  A: [
2399
2417
  "assertion['@type'] === 'dxos.halo.credentials.SpaceMember'",
@@ -2402,13 +2420,16 @@ var SpaceInvitationProtocol = class {
2402
2420
  });
2403
2421
  invariant8(credential.subject.id.equals(this._signingContext.identityKey), void 0, {
2404
2422
  F: __dxlog_file9,
2405
- L: 105,
2423
+ L: 112,
2406
2424
  S: this,
2407
2425
  A: [
2408
2426
  "credential.subject.id.equals(this._signingContext.identityKey)",
2409
2427
  ""
2410
2428
  ]
2411
2429
  });
2430
+ if (this._spaceManager.spaces.has(assertion.spaceKey)) {
2431
+ throw new AlreadyJoinedError2("Already joined space.");
2432
+ }
2412
2433
  await this._spaceManager.acceptSpace({
2413
2434
  spaceKey: assertion.spaceKey,
2414
2435
  genesisFeedKey: assertion.genesisFeedKey,
@@ -2437,7 +2458,7 @@ function _ts_decorate3(decorators, target, key, desc) {
2437
2458
  r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
2438
2459
  return c > 3 && r && Object.defineProperty(target, key, r), r;
2439
2460
  }
2440
- var ClientRpcServer = class ClientRpcServer2 {
2461
+ var ClientRpcServer = class {
2441
2462
  constructor(params) {
2442
2463
  this._handlerCache = /* @__PURE__ */ new Map();
2443
2464
  this._callMetrics = new MapCounter();
@@ -2512,29 +2533,32 @@ import { invariant as invariant9 } from "@dxos/invariant";
2512
2533
  import { log as log8 } from "@dxos/log";
2513
2534
  import { STORAGE_VERSION } from "@dxos/protocols";
2514
2535
  import { SpaceMember } from "@dxos/protocols/proto/dxos/client/services";
2536
+ import { TRACE_PROCESSOR } from "@dxos/tracing";
2515
2537
 
2516
2538
  // packages/sdk/client-services/src/packlets/services/platform.ts
2539
+ import { Platform } from "@dxos/protocols/proto/dxos/client/services";
2517
2540
  var getPlatform = () => {
2518
2541
  if (process.browser) {
2519
2542
  if (typeof window !== "undefined") {
2520
2543
  const { userAgent } = window.navigator;
2521
2544
  return {
2522
- type: "browser",
2545
+ type: Platform.PLATFORM_TYPE.BROWSER,
2523
2546
  userAgent,
2524
2547
  uptime: Math.floor((Date.now() - window.performance.timeOrigin) / 1e3)
2525
2548
  };
2526
2549
  } else {
2527
2550
  return {
2528
- type: "shared-worker",
2551
+ type: Platform.PLATFORM_TYPE.SHARED_WORKER,
2529
2552
  uptime: Math.floor((Date.now() - performance.timeOrigin) / 1e3)
2530
2553
  };
2531
2554
  }
2532
2555
  } else {
2533
2556
  const { platform: platform2, version, arch } = process;
2534
2557
  return {
2535
- type: "node",
2536
- platform: `${platform2} ${version} ${arch}`,
2537
- runtime: process.version,
2558
+ type: Platform.PLATFORM_TYPE.NODE,
2559
+ platform: platform2,
2560
+ arch,
2561
+ runtime: version,
2538
2562
  uptime: Math.floor(process.uptime()),
2539
2563
  memory: process.memoryUsage()
2540
2564
  };
@@ -2542,7 +2566,7 @@ var getPlatform = () => {
2542
2566
  };
2543
2567
 
2544
2568
  // packages/sdk/client-services/src/version.ts
2545
- var DXOS_VERSION = "0.3.11-main.ec7a2b3";
2569
+ var DXOS_VERSION = "0.3.11-main.ee2b64c";
2546
2570
 
2547
2571
  // packages/sdk/client-services/src/packlets/services/diagnostics.ts
2548
2572
  var __dxlog_file10 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/services/diagnostics.ts";
@@ -2556,12 +2580,13 @@ var createDiagnostics = async (clientServices, serviceContext, config) => {
2556
2580
  storage: {
2557
2581
  version: STORAGE_VERSION
2558
2582
  }
2559
- }
2583
+ },
2584
+ trace: TRACE_PROCESSOR.getDiagnostics()
2560
2585
  };
2561
2586
  {
2562
2587
  invariant9(clientServices.LoggingService, "SystemService is not available.", {
2563
2588
  F: __dxlog_file10,
2564
- L: 92,
2589
+ L: 111,
2565
2590
  S: void 0,
2566
2591
  A: [
2567
2592
  "clientServices.LoggingService",
@@ -2572,6 +2597,21 @@ var createDiagnostics = async (clientServices, serviceContext, config) => {
2572
2597
  timeout: DEFAULT_TIMEOUT
2573
2598
  }).catch(() => void 0);
2574
2599
  }
2600
+ if (typeof navigator !== "undefined" && navigator.storage) {
2601
+ const map = /* @__PURE__ */ new Map();
2602
+ const dir = await navigator.storage.getDirectory();
2603
+ for await (const filename of dir?.keys()) {
2604
+ const idx = filename.indexOf("-", filename.indexOf("-") + 1);
2605
+ if (idx === -1) {
2606
+ continue;
2607
+ }
2608
+ map.set(filename.slice(0, idx), (map.get(filename.slice(0, idx)) ?? 0) + 1);
2609
+ }
2610
+ diagnostics.storage = Array.from(map.entries()).sort((a, b) => b[1] - a[1]).map(([file, count]) => ({
2611
+ file,
2612
+ count
2613
+ }));
2614
+ }
2575
2615
  const identity = serviceContext.identityManager.identity;
2576
2616
  if (identity) {
2577
2617
  diagnostics.identity = {
@@ -2612,7 +2652,7 @@ var getProperties = (space) => {
2612
2652
  } catch (err) {
2613
2653
  log8.warn(err.message, void 0, {
2614
2654
  F: __dxlog_file10,
2615
- L: 160,
2655
+ L: 196,
2616
2656
  S: void 0,
2617
2657
  C: (f, a) => f(...a)
2618
2658
  });
@@ -2668,11 +2708,12 @@ var getSpaceStats = async (space) => {
2668
2708
  };
2669
2709
 
2670
2710
  // packages/sdk/client-services/src/packlets/spaces/data-space.ts
2671
- import { Event as Event5, scheduleTask as scheduleTask4, sleep as sleep2, synchronized, trackLeaks } from "@dxos/async";
2711
+ import { Event as Event5, asyncTimeout, scheduleTask as scheduleTask4, sleep as sleep2, synchronized, trackLeaks } from "@dxos/async";
2672
2712
  import { AUTH_TIMEOUT as AUTH_TIMEOUT2 } from "@dxos/client-protocol";
2673
- import { cancelWithContext as cancelWithContext2, Context as Context7 } from "@dxos/context";
2713
+ import { cancelWithContext as cancelWithContext2, Context as Context7, ContextDisposedError } from "@dxos/context";
2674
2714
  import { timed } from "@dxos/debug";
2675
2715
  import { createMappedFeedWriter } from "@dxos/echo-pipeline";
2716
+ import { failedInvariant } from "@dxos/invariant";
2676
2717
  import { PublicKey as PublicKey8 } from "@dxos/keys";
2677
2718
  import { log as log10 } from "@dxos/log";
2678
2719
  import { CancelledError, SystemError } from "@dxos/protocols";
@@ -2685,7 +2726,8 @@ import { ComplexSet as ComplexSet3 } from "@dxos/util";
2685
2726
  // packages/sdk/client-services/src/packlets/spaces/automerge-space-state.ts
2686
2727
  import { checkCredentialType } from "@dxos/credentials";
2687
2728
  var AutomergeSpaceState = class {
2688
- constructor() {
2729
+ constructor(_onNewRoot) {
2730
+ this._onNewRoot = _onNewRoot;
2689
2731
  this.rootUrl = void 0;
2690
2732
  this.lastEpoch = void 0;
2691
2733
  }
@@ -2696,6 +2738,7 @@ var AutomergeSpaceState = class {
2696
2738
  this.lastEpoch = credential;
2697
2739
  if (credential.subject.assertion.automergeRoot) {
2698
2740
  this.rootUrl = credential.subject.assertion.automergeRoot;
2741
+ this._onNewRoot(this.rootUrl);
2699
2742
  }
2700
2743
  }
2701
2744
  };
@@ -2981,13 +3024,13 @@ function _ts_decorate4(decorators, target, key, desc) {
2981
3024
  }
2982
3025
  var __dxlog_file12 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/spaces/data-space.ts";
2983
3026
  var ENABLE_FEED_PURGE = false;
2984
- var DataSpace = class DataSpace2 {
3027
+ var DataSpace = class {
2985
3028
  constructor(params) {
2986
3029
  this._ctx = new Context7();
2987
3030
  this._notarizationPlugin = new NotarizationPlugin();
2988
3031
  this._cache = void 0;
2989
3032
  // TODO(dmaretskyi): Move into Space?
2990
- this._automergeSpaceState = new AutomergeSpaceState();
3033
+ this._automergeSpaceState = new AutomergeSpaceState((rootUrl) => this._onNewAutomergeRoot(rootUrl));
2991
3034
  this._state = SpaceState.CLOSED;
2992
3035
  /**
2993
3036
  * Error for _state === SpaceState.ERROR.
@@ -3016,7 +3059,7 @@ var DataSpace = class DataSpace2 {
3016
3059
  state: SpaceState[this._state]
3017
3060
  }, {
3018
3061
  F: __dxlog_file12,
3019
- L: 137,
3062
+ L: 141,
3020
3063
  S: this,
3021
3064
  C: (f, a) => f(...a)
3022
3065
  });
@@ -3049,6 +3092,12 @@ var DataSpace = class DataSpace2 {
3049
3092
  get automergeSpaceState() {
3050
3093
  return this._automergeSpaceState;
3051
3094
  }
3095
+ get _automergeInfo() {
3096
+ return {
3097
+ rootUrl: this._automergeSpaceState.rootUrl,
3098
+ lastEpoch: this._automergeSpaceState.lastEpoch
3099
+ };
3100
+ }
3052
3101
  async open() {
3053
3102
  await this._open();
3054
3103
  }
@@ -3063,7 +3112,7 @@ var DataSpace = class DataSpace2 {
3063
3112
  state: SpaceState[this._state]
3064
3113
  }, {
3065
3114
  F: __dxlog_file12,
3066
- L: 189,
3115
+ L: 203,
3067
3116
  S: this,
3068
3117
  C: (f, a) => f(...a)
3069
3118
  });
@@ -3081,7 +3130,7 @@ var DataSpace = class DataSpace2 {
3081
3130
  state: SpaceState[this._state]
3082
3131
  }, {
3083
3132
  F: __dxlog_file12,
3084
- L: 203,
3133
+ L: 217,
3085
3134
  S: this,
3086
3135
  C: (f, a) => f(...a)
3087
3136
  });
@@ -3110,10 +3159,10 @@ var DataSpace = class DataSpace2 {
3110
3159
  this.metrics.pipelineInitBegin = /* @__PURE__ */ new Date();
3111
3160
  await this.initializeDataPipeline();
3112
3161
  } catch (err) {
3113
- if (err instanceof CancelledError) {
3162
+ if (err instanceof CancelledError || err instanceof ContextDisposedError) {
3114
3163
  log10("data pipeline initialization cancelled", err, {
3115
3164
  F: __dxlog_file12,
3116
- L: 236,
3165
+ L: 250,
3117
3166
  S: this,
3118
3167
  C: (f, a) => f(...a)
3119
3168
  });
@@ -3121,7 +3170,7 @@ var DataSpace = class DataSpace2 {
3121
3170
  }
3122
3171
  log10.error("Error initializing data pipeline", err, {
3123
3172
  F: __dxlog_file12,
3124
- L: 240,
3173
+ L: 254,
3125
3174
  S: this,
3126
3175
  C: (f, a) => f(...a)
3127
3176
  });
@@ -3130,7 +3179,7 @@ var DataSpace = class DataSpace2 {
3130
3179
  state: SpaceState[this._state]
3131
3180
  }, {
3132
3181
  F: __dxlog_file12,
3133
- L: 242,
3182
+ L: 256,
3134
3183
  S: this,
3135
3184
  C: (f, a) => f(...a)
3136
3185
  });
@@ -3150,7 +3199,7 @@ var DataSpace = class DataSpace2 {
3150
3199
  state: SpaceState[this._state]
3151
3200
  }, {
3152
3201
  F: __dxlog_file12,
3153
- L: 258,
3202
+ L: 272,
3154
3203
  S: this,
3155
3204
  C: (f, a) => f(...a)
3156
3205
  });
@@ -3161,7 +3210,7 @@ var DataSpace = class DataSpace2 {
3161
3210
  await cancelWithContext2(this._ctx, this._inner.dataPipeline.ensureEpochInitialized());
3162
3211
  log10("waiting for data pipeline to reach target timeframe", void 0, {
3163
3212
  F: __dxlog_file12,
3164
- L: 272,
3213
+ L: 286,
3165
3214
  S: this,
3166
3215
  C: (f, a) => f(...a)
3167
3216
  });
@@ -3172,7 +3221,7 @@ var DataSpace = class DataSpace2 {
3172
3221
  this.metrics.dataPipelineReady = /* @__PURE__ */ new Date();
3173
3222
  log10("data pipeline ready", void 0, {
3174
3223
  F: __dxlog_file12,
3175
- L: 281,
3224
+ L: 295,
3176
3225
  S: this,
3177
3226
  C: (f, a) => f(...a)
3178
3227
  });
@@ -3182,7 +3231,7 @@ var DataSpace = class DataSpace2 {
3182
3231
  state: SpaceState[this._state]
3183
3232
  }, {
3184
3233
  F: __dxlog_file12,
3185
- L: 285,
3234
+ L: 299,
3186
3235
  S: this,
3187
3236
  C: (f, a) => f(...a)
3188
3237
  });
@@ -3198,7 +3247,7 @@ var DataSpace = class DataSpace2 {
3198
3247
  await this._createWritableFeeds();
3199
3248
  log10("writable feeds created", void 0, {
3200
3249
  F: __dxlog_file12,
3201
- L: 301,
3250
+ L: 315,
3202
3251
  S: this,
3203
3252
  C: (f, a) => f(...a)
3204
3253
  });
@@ -3255,6 +3304,40 @@ var DataSpace = class DataSpace2 {
3255
3304
  await this._metadataStore.setWritableFeedKeys(this.key, this.inner.controlFeedKey, this.inner.dataFeedKey);
3256
3305
  }
3257
3306
  }
3307
+ _onNewAutomergeRoot(rootUrl) {
3308
+ log10("loading automerge root doc for space", {
3309
+ space: this.key,
3310
+ rootUrl
3311
+ }, {
3312
+ F: __dxlog_file12,
3313
+ L: 381,
3314
+ S: this,
3315
+ C: (f, a) => f(...a)
3316
+ });
3317
+ const handle = this._automergeHost.repo.find(rootUrl);
3318
+ queueMicrotask(async () => {
3319
+ try {
3320
+ await asyncTimeout(handle.whenReady(), 5e3);
3321
+ const doc = handle.docSync() ?? failedInvariant();
3322
+ if (!doc.experimental_spaceKey) {
3323
+ handle.change((doc2) => {
3324
+ doc2.experimental_spaceKey = this.key.toHex();
3325
+ });
3326
+ }
3327
+ } catch (err) {
3328
+ log10.warn("error loading automerge root doc", {
3329
+ space: this.key,
3330
+ rootUrl,
3331
+ err
3332
+ }, {
3333
+ F: __dxlog_file12,
3334
+ L: 394,
3335
+ S: this,
3336
+ C: (f, a) => f(...a)
3337
+ });
3338
+ }
3339
+ });
3340
+ }
3258
3341
  // TODO(dmaretskyi): Use profile from signing context.
3259
3342
  async updateOwnProfile(profile) {
3260
3343
  const credential = await this._signingContext.credentialSigner.createCredential({
@@ -3338,13 +3421,29 @@ var DataSpace = class DataSpace2 {
3338
3421
  state: SpaceState[this._state]
3339
3422
  }, {
3340
3423
  F: __dxlog_file12,
3341
- L: 450,
3424
+ L: 483,
3342
3425
  S: this,
3343
3426
  C: (f, a) => f(...a)
3344
3427
  });
3345
3428
  this.stateUpdate.emit();
3346
3429
  }
3347
3430
  };
3431
+ _ts_decorate4([
3432
+ trace6.info()
3433
+ ], DataSpace.prototype, "_inner", void 0);
3434
+ _ts_decorate4([
3435
+ trace6.info()
3436
+ ], DataSpace.prototype, "key", null);
3437
+ _ts_decorate4([
3438
+ trace6.info({
3439
+ enum: SpaceState
3440
+ })
3441
+ ], DataSpace.prototype, "state", null);
3442
+ _ts_decorate4([
3443
+ trace6.info({
3444
+ depth: null
3445
+ })
3446
+ ], DataSpace.prototype, "_automergeInfo", null);
3348
3447
  _ts_decorate4([
3349
3448
  synchronized
3350
3449
  ], DataSpace.prototype, "open", null);
@@ -3371,7 +3470,8 @@ _ts_decorate4([
3371
3470
  synchronized
3372
3471
  ], DataSpace.prototype, "deactivate", null);
3373
3472
  DataSpace = _ts_decorate4([
3374
- trackLeaks("open", "close")
3473
+ trackLeaks("open", "close"),
3474
+ trace6.resource()
3375
3475
  ], DataSpace);
3376
3476
 
3377
3477
  // packages/sdk/client-services/src/packlets/spaces/data-space-manager.ts
@@ -3470,7 +3570,7 @@ function _ts_decorate5(decorators, target, key, desc) {
3470
3570
  var __dxlog_file13 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/spaces/data-space-manager.ts";
3471
3571
  var PRESENCE_ANNOUNCE_INTERVAL = 1e4;
3472
3572
  var PRESENCE_OFFLINE_TIMEOUT = 2e4;
3473
- var DataSpaceManager = class DataSpaceManager2 {
3573
+ var DataSpaceManager = class {
3474
3574
  constructor(_spaceManager, _metadataStore, _dataServiceSubscriptions, _keyring, _signingContext, _feedStore, _automergeHost) {
3475
3575
  this._spaceManager = _spaceManager;
3476
3576
  this._metadataStore = _metadataStore;
@@ -3597,12 +3697,15 @@ var DataSpaceManager = class DataSpaceManager2 {
3597
3697
  });
3598
3698
  const space = await this._constructSpace(metadata);
3599
3699
  const automergeRoot = this._automergeHost.repo.create();
3700
+ automergeRoot.change((doc) => {
3701
+ doc.experimental_spaceKey = spaceKey.toHex();
3702
+ });
3600
3703
  const credentials = await spaceGenesis(this._keyring, this._signingContext, space.inner, automergeRoot.url);
3601
3704
  await this._metadataStore.addSpace(metadata);
3602
3705
  const memberCredential = credentials[1];
3603
3706
  invariant11(getCredentialAssertion2(memberCredential)["@type"] === "dxos.halo.credentials.SpaceMember", void 0, {
3604
3707
  F: __dxlog_file13,
3605
- L: 151,
3708
+ L: 154,
3606
3709
  S: this,
3607
3710
  A: [
3608
3711
  "getCredentialAssertion(memberCredential)['@type'] === 'dxos.halo.credentials.SpaceMember'",
@@ -3620,13 +3723,13 @@ var DataSpaceManager = class DataSpaceManager2 {
3620
3723
  opts
3621
3724
  }, {
3622
3725
  F: __dxlog_file13,
3623
- L: 163,
3726
+ L: 166,
3624
3727
  S: this,
3625
3728
  C: (f, a) => f(...a)
3626
3729
  });
3627
3730
  invariant11(this._isOpen, "Not open.", {
3628
3731
  F: __dxlog_file13,
3629
- L: 164,
3732
+ L: 167,
3630
3733
  S: this,
3631
3734
  A: [
3632
3735
  "this._isOpen",
@@ -3635,7 +3738,7 @@ var DataSpaceManager = class DataSpaceManager2 {
3635
3738
  });
3636
3739
  invariant11(!this._spaces.has(opts.spaceKey), "Space already exists.", {
3637
3740
  F: __dxlog_file13,
3638
- L: 165,
3741
+ L: 168,
3639
3742
  S: this,
3640
3743
  A: [
3641
3744
  "!this._spaces.has(opts.spaceKey)",
@@ -3670,7 +3773,7 @@ var DataSpaceManager = class DataSpaceManager2 {
3670
3773
  metadata
3671
3774
  }, {
3672
3775
  F: __dxlog_file13,
3673
- L: 198,
3776
+ L: 201,
3674
3777
  S: this,
3675
3778
  C: (f, a) => f(...a)
3676
3779
  });
@@ -3697,17 +3800,18 @@ var DataSpaceManager = class DataSpaceManager2 {
3697
3800
  credentialProvider: createAuthProvider(this._signingContext.credentialSigner),
3698
3801
  credentialAuthenticator: deferFunction2(() => dataSpace.authVerifier.verifier)
3699
3802
  },
3700
- onNetworkConnection: (session) => {
3803
+ onAuthorizedConnection: (session) => {
3701
3804
  session.addExtension("dxos.mesh.teleport.gossip", gossip.createExtension({
3702
3805
  remotePeerId: session.remotePeerId
3703
3806
  }));
3704
3807
  session.addExtension("dxos.mesh.teleport.notarization", dataSpace.notarizationPlugin.createExtension());
3808
+ this._automergeHost.authorizeDevice(space.key, session.remotePeerId);
3705
3809
  session.addExtension("dxos.mesh.teleport.automerge", this._automergeHost.createExtension());
3706
3810
  },
3707
3811
  onAuthFailure: () => {
3708
3812
  log11.warn("auth failure", void 0, {
3709
3813
  F: __dxlog_file13,
3710
- L: 234,
3814
+ L: 238,
3711
3815
  S: this,
3712
3816
  C: (f, a) => f(...a)
3713
3817
  });
@@ -3731,7 +3835,7 @@ var DataSpaceManager = class DataSpaceManager2 {
3731
3835
  space: space.key
3732
3836
  }, {
3733
3837
  F: __dxlog_file13,
3734
- L: 252,
3838
+ L: 256,
3735
3839
  S: this,
3736
3840
  C: (f, a) => f(...a)
3737
3841
  });
@@ -3743,7 +3847,7 @@ var DataSpaceManager = class DataSpaceManager2 {
3743
3847
  open: this._isOpen
3744
3848
  }, {
3745
3849
  F: __dxlog_file13,
3746
- L: 259,
3850
+ L: 263,
3747
3851
  S: this,
3748
3852
  C: (f, a) => f(...a)
3749
3853
  });
@@ -3756,7 +3860,7 @@ var DataSpaceManager = class DataSpaceManager2 {
3756
3860
  space: space.key
3757
3861
  }, {
3758
3862
  F: __dxlog_file13,
3759
- L: 265,
3863
+ L: 269,
3760
3864
  S: this,
3761
3865
  C: (f, a) => f(...a)
3762
3866
  });
@@ -3813,7 +3917,7 @@ var SpacesServiceImpl = class {
3813
3917
  }
3814
3918
  async createSpace() {
3815
3919
  if (!this._identityManager.identity) {
3816
- throw new Error("This device has no HALO identity available. See https://docs.dxos.org/guide/halo");
3920
+ throw new Error("This device has no HALO identity available. See https://docs.dxos.org/guide/platform/halo");
3817
3921
  }
3818
3922
  const dataSpaceManager = await this._getDataSpaceManager();
3819
3923
  const space = await dataSpaceManager.createSpace();
@@ -4043,7 +4147,7 @@ function _ts_decorate6(decorators, target, key, desc) {
4043
4147
  return c > 3 && r && Object.defineProperty(target, key, r), r;
4044
4148
  }
4045
4149
  var __dxlog_file15 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/services/service-context.ts";
4046
- var ServiceContext = class ServiceContext2 {
4150
+ var ServiceContext = class {
4047
4151
  constructor(storage, networkManager, signalManager, modelFactory) {
4048
4152
  this.storage = storage;
4049
4153
  this.networkManager = networkManager;
@@ -4312,7 +4416,7 @@ var ServiceRegistry = class {
4312
4416
  };
4313
4417
 
4314
4418
  // packages/sdk/client-services/src/packlets/locks/browser.ts
4315
- import { asyncTimeout, Trigger as Trigger6 } from "@dxos/async";
4419
+ import { asyncTimeout as asyncTimeout2, Trigger as Trigger6 } from "@dxos/async";
4316
4420
  import { RESOURCE_LOCK_TIMEOUT } from "@dxos/client-protocol";
4317
4421
  import { log as log14, logInfo } from "@dxos/log";
4318
4422
  function _ts_decorate7(decorators, target, key, desc) {
@@ -4344,7 +4448,7 @@ var Lock = class {
4344
4448
  }
4345
4449
  async acquire() {
4346
4450
  this._broadcastChannel.postMessage({
4347
- message: Message.ACQUIRING
4451
+ message: "acquiring"
4348
4452
  });
4349
4453
  try {
4350
4454
  log14("aquiring lock...", void 0, {
@@ -4353,7 +4457,7 @@ var Lock = class {
4353
4457
  S: this,
4354
4458
  C: (f, a) => f(...a)
4355
4459
  });
4356
- await asyncTimeout(this._requestLock(), RESOURCE_LOCK_TIMEOUT);
4460
+ await asyncTimeout2(this._requestLock(), RESOURCE_LOCK_TIMEOUT);
4357
4461
  log14("acquired lock", void 0, {
4358
4462
  F: __dxlog_file16,
4359
4463
  L: 44,
@@ -4380,7 +4484,7 @@ var Lock = class {
4380
4484
  this._releaseTrigger.wake();
4381
4485
  }
4382
4486
  _onMessage(event) {
4383
- if (event.data.message === Message.ACQUIRING) {
4487
+ if (event.data.message === "acquiring") {
4384
4488
  this._releaseTrigger.wake();
4385
4489
  }
4386
4490
  }
@@ -4490,7 +4594,7 @@ import { clientServiceBundle, defaultKey, Properties } from "@dxos/client-protoc
4490
4594
  import { Context as Context10 } from "@dxos/context";
4491
4595
  import { DocumentModel as DocumentModel2 } from "@dxos/document-model";
4492
4596
  import { DataServiceImpl } from "@dxos/echo-pipeline";
4493
- import { base } from "@dxos/echo-schema";
4597
+ import { base, getRawDoc } from "@dxos/echo-schema";
4494
4598
  import { invariant as invariant14 } from "@dxos/invariant";
4495
4599
  import { PublicKey as PublicKey11 } from "@dxos/keys";
4496
4600
  import { log as log16 } from "@dxos/log";
@@ -4500,7 +4604,7 @@ import { createSimplePeerTransportFactory, NetworkManager } from "@dxos/network-
4500
4604
  import { trace as trace9 } from "@dxos/protocols";
4501
4605
  import { SystemStatus } from "@dxos/protocols/proto/dxos/client/services";
4502
4606
  import { TextModel } from "@dxos/text-model";
4503
- import { TRACE_PROCESSOR, trace as Trace3 } from "@dxos/tracing";
4607
+ import { TRACE_PROCESSOR as TRACE_PROCESSOR2, trace as Trace3 } from "@dxos/tracing";
4504
4608
  import { WebsocketRpcClient } from "@dxos/websocket-rpc";
4505
4609
 
4506
4610
  // packages/sdk/client-services/src/packlets/devices/devices-service.ts
@@ -4676,6 +4780,7 @@ var NetworkServiceImpl = class {
4676
4780
  const update = () => {
4677
4781
  next({
4678
4782
  swarm: this.networkManager.connectionState,
4783
+ connectionInfo: this.networkManager.connectionLog?.swarms,
4679
4784
  signaling: this.signalManager.getStatus().map(({ host, state }) => ({
4680
4785
  server: host,
4681
4786
  state
@@ -4725,6 +4830,9 @@ var SystemServiceImpl = class {
4725
4830
  })))
4726
4831
  };
4727
4832
  }
4833
+ async getPlatform() {
4834
+ return getPlatform();
4835
+ }
4728
4836
  async updateStatus({ status }) {
4729
4837
  await this._onUpdateStatus(status);
4730
4838
  }
@@ -4777,7 +4885,7 @@ var createGenesisMutationFromTypedObject = (obj) => {
4777
4885
  }
4778
4886
  };
4779
4887
  };
4780
- var ClientServicesHost = class ClientServicesHost2 {
4888
+ var ClientServicesHost = class {
4781
4889
  constructor({
4782
4890
  config,
4783
4891
  modelFactory = createDefaultModelFactory(),
@@ -4788,7 +4896,7 @@ var ClientServicesHost = class ClientServicesHost2 {
4788
4896
  lockKey,
4789
4897
  callbacks
4790
4898
  } = {}) {
4791
- this._tracingService = TRACE_PROCESSOR.createTraceSender();
4899
+ this._tracingService = TRACE_PROCESSOR2.createTraceSender();
4792
4900
  this._statusUpdate = new Event8();
4793
4901
  this._opening = false;
4794
4902
  this._open = false;
@@ -4979,7 +5087,7 @@ var ClientServicesHost = class ClientServicesHost2 {
4979
5087
  this._serviceContext = new ServiceContext(this._storage, this._networkManager, this._signalManager, this._modelFactory);
4980
5088
  this._serviceRegistry.setServices({
4981
5089
  SystemService: this._systemService,
4982
- IdentityService: new IdentityServiceImpl((params) => this._createIdentity(params), this._serviceContext.identityManager, this._serviceContext.keyring, (profile) => this._serviceContext.broadcastProfileUpdate(profile)),
5090
+ IdentityService: new IdentityServiceImpl((params, useAutomerge) => this._createIdentity(params, useAutomerge), this._serviceContext.identityManager, this._serviceContext.keyring, (profile) => this._serviceContext.broadcastProfileUpdate(profile)),
4983
5091
  InvitationsService: new InvitationsServiceImpl(this._serviceContext.invitations, (invitation) => this._serviceContext.getInvitationHandler(invitation)),
4984
5092
  DevicesService: new DevicesServiceImpl(this._serviceContext.identityManager),
4985
5093
  SpacesService: new SpacesServiceImpl(this._serviceContext.identityManager, this._serviceContext.spaceManager, this._serviceContext.dataServiceSubscriptions, async () => {
@@ -5093,25 +5201,44 @@ var ClientServicesHost = class ClientServicesHost2 {
5093
5201
  });
5094
5202
  await this._callbacks?.onReset?.();
5095
5203
  }
5096
- async _createIdentity(params) {
5204
+ async _createIdentity(params, useAutomerge) {
5097
5205
  const identity = await this._serviceContext.createIdentity(params);
5098
5206
  await this._serviceContext.initialized.wait();
5099
5207
  const space = await this._serviceContext.dataSpaceManager.createSpace();
5100
5208
  const obj = new Properties(void 0, {
5101
- automerge: false
5209
+ automerge: useAutomerge
5102
5210
  });
5103
5211
  obj[defaultKey] = identity.identityKey.toHex();
5104
- await this._serviceRegistry.services.DataService.write({
5105
- spaceKey: space.key,
5106
- batch: {
5107
- objects: [
5108
- createGenesisMutationFromTypedObject(obj)
5212
+ if (!useAutomerge) {
5213
+ await this._serviceRegistry.services.DataService.write({
5214
+ spaceKey: space.key,
5215
+ batch: {
5216
+ objects: [
5217
+ createGenesisMutationFromTypedObject(obj)
5218
+ ]
5219
+ }
5220
+ });
5221
+ await this._serviceRegistry.services.DataService.flush({
5222
+ spaceKey: space.key
5223
+ });
5224
+ } else {
5225
+ const automergeIndex = space.automergeSpaceState.rootUrl;
5226
+ invariant14(automergeIndex, void 0, {
5227
+ F: __dxlog_file17,
5228
+ L: 375,
5229
+ S: this,
5230
+ A: [
5231
+ "automergeIndex",
5232
+ ""
5109
5233
  ]
5110
- }
5111
- });
5112
- await this._serviceRegistry.services.DataService.flush({
5113
- spaceKey: space.key
5114
- });
5234
+ });
5235
+ const document = await this._serviceContext.automergeHost.repo.find(automergeIndex);
5236
+ await document.whenReady();
5237
+ document.change((doc) => {
5238
+ doc.objects ??= {};
5239
+ doc.objects[obj[base]._id] = getRawDoc(obj).handle.docSync();
5240
+ });
5241
+ }
5115
5242
  return identity;
5116
5243
  }
5117
5244
  };
@@ -5167,4 +5294,4 @@ export {
5167
5294
  createDefaultModelFactory,
5168
5295
  ClientServicesHost
5169
5296
  };
5170
- //# sourceMappingURL=chunk-XM2TLK6X.mjs.map
5297
+ //# sourceMappingURL=chunk-3DRZQ4U6.mjs.map