@dxos/client-services 0.3.11-main.a8d7a97 → 0.3.11-main.afa73e0
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-6DHQ2QXZ.mjs → chunk-YD2GBB3W.mjs} +199 -103
- package/dist/lib/browser/chunk-YD2GBB3W.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-O3RVCYRH.cjs → chunk-S5IK5PCE.cjs} +282 -186
- package/dist/lib/node/chunk-S5IK5PCE.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/services/diagnostics.d.ts +4 -0
- package/dist/types/src/packlets/services/diagnostics.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 +1 -0
- package/dist/types/src/packlets/spaces/data-space.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/services/diagnostics.ts +18 -0
- 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 +21 -1
- package/src/packlets/spaces/spaces-service.ts +1 -1
- package/src/packlets/testing/invitation-utils.ts +2 -10
- package/src/version.ts +1 -1
- package/dist/lib/browser/chunk-6DHQ2QXZ.mjs.map +0 -7
- package/dist/lib/node/chunk-O3RVCYRH.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
|
|
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
|
|
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
|
-
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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
|
-
|
|
2049
|
-
|
|
2050
|
-
|
|
2051
|
-
|
|
2052
|
-
|
|
2053
|
-
|
|
2054
|
-
|
|
2055
|
-
|
|
2056
|
-
|
|
2057
|
-
|
|
2058
|
-
|
|
2059
|
-
|
|
2060
|
-
|
|
2061
|
-
|
|
2062
|
-
|
|
2063
|
-
|
|
2064
|
-
|
|
2065
|
-
|
|
2066
|
-
|
|
2067
|
-
|
|
2068
|
-
|
|
2069
|
-
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
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
|
|
2461
|
+
var ClientRpcServer = class {
|
|
2441
2462
|
constructor(params) {
|
|
2442
2463
|
this._handlerCache = /* @__PURE__ */ new Map();
|
|
2443
2464
|
this._callMetrics = new MapCounter();
|
|
@@ -2542,7 +2563,7 @@ var getPlatform = () => {
|
|
|
2542
2563
|
};
|
|
2543
2564
|
|
|
2544
2565
|
// packages/sdk/client-services/src/version.ts
|
|
2545
|
-
var DXOS_VERSION = "0.3.11-main.
|
|
2566
|
+
var DXOS_VERSION = "0.3.11-main.afa73e0";
|
|
2546
2567
|
|
|
2547
2568
|
// packages/sdk/client-services/src/packlets/services/diagnostics.ts
|
|
2548
2569
|
var __dxlog_file10 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/services/diagnostics.ts";
|
|
@@ -2561,7 +2582,7 @@ var createDiagnostics = async (clientServices, serviceContext, config) => {
|
|
|
2561
2582
|
{
|
|
2562
2583
|
invariant9(clientServices.LoggingService, "SystemService is not available.", {
|
|
2563
2584
|
F: __dxlog_file10,
|
|
2564
|
-
L:
|
|
2585
|
+
L: 93,
|
|
2565
2586
|
S: void 0,
|
|
2566
2587
|
A: [
|
|
2567
2588
|
"clientServices.LoggingService",
|
|
@@ -2572,6 +2593,21 @@ var createDiagnostics = async (clientServices, serviceContext, config) => {
|
|
|
2572
2593
|
timeout: DEFAULT_TIMEOUT
|
|
2573
2594
|
}).catch(() => void 0);
|
|
2574
2595
|
}
|
|
2596
|
+
if (typeof navigator !== "undefined" && navigator.storage) {
|
|
2597
|
+
const map = /* @__PURE__ */ new Map();
|
|
2598
|
+
const dir = await navigator.storage.getDirectory();
|
|
2599
|
+
for await (const filename of dir?.keys()) {
|
|
2600
|
+
const idx = filename.indexOf("-", filename.indexOf("-") + 1);
|
|
2601
|
+
if (idx === -1) {
|
|
2602
|
+
continue;
|
|
2603
|
+
}
|
|
2604
|
+
map.set(filename.slice(0, idx), (map.get(filename.slice(0, idx)) ?? 0) + 1);
|
|
2605
|
+
}
|
|
2606
|
+
diagnostics.storage = Array.from(map.entries()).sort((a, b) => b[1] - a[1]).map(([file, count]) => ({
|
|
2607
|
+
file,
|
|
2608
|
+
count
|
|
2609
|
+
}));
|
|
2610
|
+
}
|
|
2575
2611
|
const identity = serviceContext.identityManager.identity;
|
|
2576
2612
|
if (identity) {
|
|
2577
2613
|
diagnostics.identity = {
|
|
@@ -2612,7 +2648,7 @@ var getProperties = (space) => {
|
|
|
2612
2648
|
} catch (err) {
|
|
2613
2649
|
log8.warn(err.message, void 0, {
|
|
2614
2650
|
F: __dxlog_file10,
|
|
2615
|
-
L:
|
|
2651
|
+
L: 178,
|
|
2616
2652
|
S: void 0,
|
|
2617
2653
|
C: (f, a) => f(...a)
|
|
2618
2654
|
});
|
|
@@ -2673,6 +2709,7 @@ import { AUTH_TIMEOUT as AUTH_TIMEOUT2 } from "@dxos/client-protocol";
|
|
|
2673
2709
|
import { cancelWithContext as cancelWithContext2, Context as Context7 } from "@dxos/context";
|
|
2674
2710
|
import { timed } from "@dxos/debug";
|
|
2675
2711
|
import { createMappedFeedWriter } from "@dxos/echo-pipeline";
|
|
2712
|
+
import { failedInvariant } from "@dxos/invariant";
|
|
2676
2713
|
import { PublicKey as PublicKey8 } from "@dxos/keys";
|
|
2677
2714
|
import { log as log10 } from "@dxos/log";
|
|
2678
2715
|
import { CancelledError, SystemError } from "@dxos/protocols";
|
|
@@ -2685,7 +2722,8 @@ import { ComplexSet as ComplexSet3 } from "@dxos/util";
|
|
|
2685
2722
|
// packages/sdk/client-services/src/packlets/spaces/automerge-space-state.ts
|
|
2686
2723
|
import { checkCredentialType } from "@dxos/credentials";
|
|
2687
2724
|
var AutomergeSpaceState = class {
|
|
2688
|
-
constructor() {
|
|
2725
|
+
constructor(_onNewRoot) {
|
|
2726
|
+
this._onNewRoot = _onNewRoot;
|
|
2689
2727
|
this.rootUrl = void 0;
|
|
2690
2728
|
this.lastEpoch = void 0;
|
|
2691
2729
|
}
|
|
@@ -2696,6 +2734,7 @@ var AutomergeSpaceState = class {
|
|
|
2696
2734
|
this.lastEpoch = credential;
|
|
2697
2735
|
if (credential.subject.assertion.automergeRoot) {
|
|
2698
2736
|
this.rootUrl = credential.subject.assertion.automergeRoot;
|
|
2737
|
+
this._onNewRoot(this.rootUrl);
|
|
2699
2738
|
}
|
|
2700
2739
|
}
|
|
2701
2740
|
};
|
|
@@ -2981,13 +3020,13 @@ function _ts_decorate4(decorators, target, key, desc) {
|
|
|
2981
3020
|
}
|
|
2982
3021
|
var __dxlog_file12 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/spaces/data-space.ts";
|
|
2983
3022
|
var ENABLE_FEED_PURGE = false;
|
|
2984
|
-
var DataSpace = class
|
|
3023
|
+
var DataSpace = class {
|
|
2985
3024
|
constructor(params) {
|
|
2986
3025
|
this._ctx = new Context7();
|
|
2987
3026
|
this._notarizationPlugin = new NotarizationPlugin();
|
|
2988
3027
|
this._cache = void 0;
|
|
2989
3028
|
// TODO(dmaretskyi): Move into Space?
|
|
2990
|
-
this._automergeSpaceState = new AutomergeSpaceState();
|
|
3029
|
+
this._automergeSpaceState = new AutomergeSpaceState((rootUrl) => this._onNewAutomergeRoot(rootUrl));
|
|
2991
3030
|
this._state = SpaceState.CLOSED;
|
|
2992
3031
|
/**
|
|
2993
3032
|
* Error for _state === SpaceState.ERROR.
|
|
@@ -3016,7 +3055,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3016
3055
|
state: SpaceState[this._state]
|
|
3017
3056
|
}, {
|
|
3018
3057
|
F: __dxlog_file12,
|
|
3019
|
-
L:
|
|
3058
|
+
L: 138,
|
|
3020
3059
|
S: this,
|
|
3021
3060
|
C: (f, a) => f(...a)
|
|
3022
3061
|
});
|
|
@@ -3063,7 +3102,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3063
3102
|
state: SpaceState[this._state]
|
|
3064
3103
|
}, {
|
|
3065
3104
|
F: __dxlog_file12,
|
|
3066
|
-
L:
|
|
3105
|
+
L: 190,
|
|
3067
3106
|
S: this,
|
|
3068
3107
|
C: (f, a) => f(...a)
|
|
3069
3108
|
});
|
|
@@ -3081,7 +3120,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3081
3120
|
state: SpaceState[this._state]
|
|
3082
3121
|
}, {
|
|
3083
3122
|
F: __dxlog_file12,
|
|
3084
|
-
L:
|
|
3123
|
+
L: 204,
|
|
3085
3124
|
S: this,
|
|
3086
3125
|
C: (f, a) => f(...a)
|
|
3087
3126
|
});
|
|
@@ -3113,7 +3152,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3113
3152
|
if (err instanceof CancelledError) {
|
|
3114
3153
|
log10("data pipeline initialization cancelled", err, {
|
|
3115
3154
|
F: __dxlog_file12,
|
|
3116
|
-
L:
|
|
3155
|
+
L: 237,
|
|
3117
3156
|
S: this,
|
|
3118
3157
|
C: (f, a) => f(...a)
|
|
3119
3158
|
});
|
|
@@ -3121,7 +3160,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3121
3160
|
}
|
|
3122
3161
|
log10.error("Error initializing data pipeline", err, {
|
|
3123
3162
|
F: __dxlog_file12,
|
|
3124
|
-
L:
|
|
3163
|
+
L: 241,
|
|
3125
3164
|
S: this,
|
|
3126
3165
|
C: (f, a) => f(...a)
|
|
3127
3166
|
});
|
|
@@ -3130,7 +3169,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3130
3169
|
state: SpaceState[this._state]
|
|
3131
3170
|
}, {
|
|
3132
3171
|
F: __dxlog_file12,
|
|
3133
|
-
L:
|
|
3172
|
+
L: 243,
|
|
3134
3173
|
S: this,
|
|
3135
3174
|
C: (f, a) => f(...a)
|
|
3136
3175
|
});
|
|
@@ -3150,7 +3189,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3150
3189
|
state: SpaceState[this._state]
|
|
3151
3190
|
}, {
|
|
3152
3191
|
F: __dxlog_file12,
|
|
3153
|
-
L:
|
|
3192
|
+
L: 259,
|
|
3154
3193
|
S: this,
|
|
3155
3194
|
C: (f, a) => f(...a)
|
|
3156
3195
|
});
|
|
@@ -3161,7 +3200,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3161
3200
|
await cancelWithContext2(this._ctx, this._inner.dataPipeline.ensureEpochInitialized());
|
|
3162
3201
|
log10("waiting for data pipeline to reach target timeframe", void 0, {
|
|
3163
3202
|
F: __dxlog_file12,
|
|
3164
|
-
L:
|
|
3203
|
+
L: 273,
|
|
3165
3204
|
S: this,
|
|
3166
3205
|
C: (f, a) => f(...a)
|
|
3167
3206
|
});
|
|
@@ -3172,7 +3211,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3172
3211
|
this.metrics.dataPipelineReady = /* @__PURE__ */ new Date();
|
|
3173
3212
|
log10("data pipeline ready", void 0, {
|
|
3174
3213
|
F: __dxlog_file12,
|
|
3175
|
-
L:
|
|
3214
|
+
L: 282,
|
|
3176
3215
|
S: this,
|
|
3177
3216
|
C: (f, a) => f(...a)
|
|
3178
3217
|
});
|
|
@@ -3182,7 +3221,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3182
3221
|
state: SpaceState[this._state]
|
|
3183
3222
|
}, {
|
|
3184
3223
|
F: __dxlog_file12,
|
|
3185
|
-
L:
|
|
3224
|
+
L: 286,
|
|
3186
3225
|
S: this,
|
|
3187
3226
|
C: (f, a) => f(...a)
|
|
3188
3227
|
});
|
|
@@ -3198,7 +3237,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3198
3237
|
await this._createWritableFeeds();
|
|
3199
3238
|
log10("writable feeds created", void 0, {
|
|
3200
3239
|
F: __dxlog_file12,
|
|
3201
|
-
L:
|
|
3240
|
+
L: 302,
|
|
3202
3241
|
S: this,
|
|
3203
3242
|
C: (f, a) => f(...a)
|
|
3204
3243
|
});
|
|
@@ -3255,6 +3294,40 @@ var DataSpace = class DataSpace2 {
|
|
|
3255
3294
|
await this._metadataStore.setWritableFeedKeys(this.key, this.inner.controlFeedKey, this.inner.dataFeedKey);
|
|
3256
3295
|
}
|
|
3257
3296
|
}
|
|
3297
|
+
_onNewAutomergeRoot(rootUrl) {
|
|
3298
|
+
log10.info("loading automerge root doc for space", {
|
|
3299
|
+
space: this.key,
|
|
3300
|
+
rootUrl
|
|
3301
|
+
}, {
|
|
3302
|
+
F: __dxlog_file12,
|
|
3303
|
+
L: 368,
|
|
3304
|
+
S: this,
|
|
3305
|
+
C: (f, a) => f(...a)
|
|
3306
|
+
});
|
|
3307
|
+
const handle = this._automergeHost.repo.find(rootUrl);
|
|
3308
|
+
queueMicrotask(async () => {
|
|
3309
|
+
try {
|
|
3310
|
+
await handle.whenReady();
|
|
3311
|
+
const doc = handle.docSync() ?? failedInvariant();
|
|
3312
|
+
if (!doc.experimental_spaceKey) {
|
|
3313
|
+
handle.change((doc2) => {
|
|
3314
|
+
doc2.experimental_spaceKey = this.key.toHex();
|
|
3315
|
+
});
|
|
3316
|
+
}
|
|
3317
|
+
} catch (err) {
|
|
3318
|
+
log10.warn("error loading automerge root doc", {
|
|
3319
|
+
space: this.key,
|
|
3320
|
+
rootUrl,
|
|
3321
|
+
err
|
|
3322
|
+
}, {
|
|
3323
|
+
F: __dxlog_file12,
|
|
3324
|
+
L: 381,
|
|
3325
|
+
S: this,
|
|
3326
|
+
C: (f, a) => f(...a)
|
|
3327
|
+
});
|
|
3328
|
+
}
|
|
3329
|
+
});
|
|
3330
|
+
}
|
|
3258
3331
|
// TODO(dmaretskyi): Use profile from signing context.
|
|
3259
3332
|
async updateOwnProfile(profile) {
|
|
3260
3333
|
const credential = await this._signingContext.credentialSigner.createCredential({
|
|
@@ -3338,7 +3411,7 @@ var DataSpace = class DataSpace2 {
|
|
|
3338
3411
|
state: SpaceState[this._state]
|
|
3339
3412
|
}, {
|
|
3340
3413
|
F: __dxlog_file12,
|
|
3341
|
-
L:
|
|
3414
|
+
L: 470,
|
|
3342
3415
|
S: this,
|
|
3343
3416
|
C: (f, a) => f(...a)
|
|
3344
3417
|
});
|
|
@@ -3470,7 +3543,7 @@ function _ts_decorate5(decorators, target, key, desc) {
|
|
|
3470
3543
|
var __dxlog_file13 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/spaces/data-space-manager.ts";
|
|
3471
3544
|
var PRESENCE_ANNOUNCE_INTERVAL = 1e4;
|
|
3472
3545
|
var PRESENCE_OFFLINE_TIMEOUT = 2e4;
|
|
3473
|
-
var DataSpaceManager = class
|
|
3546
|
+
var DataSpaceManager = class {
|
|
3474
3547
|
constructor(_spaceManager, _metadataStore, _dataServiceSubscriptions, _keyring, _signingContext, _feedStore, _automergeHost) {
|
|
3475
3548
|
this._spaceManager = _spaceManager;
|
|
3476
3549
|
this._metadataStore = _metadataStore;
|
|
@@ -3597,12 +3670,15 @@ var DataSpaceManager = class DataSpaceManager2 {
|
|
|
3597
3670
|
});
|
|
3598
3671
|
const space = await this._constructSpace(metadata);
|
|
3599
3672
|
const automergeRoot = this._automergeHost.repo.create();
|
|
3673
|
+
automergeRoot.change((doc) => {
|
|
3674
|
+
doc.experimental_spaceKey = spaceKey.toHex();
|
|
3675
|
+
});
|
|
3600
3676
|
const credentials = await spaceGenesis(this._keyring, this._signingContext, space.inner, automergeRoot.url);
|
|
3601
3677
|
await this._metadataStore.addSpace(metadata);
|
|
3602
3678
|
const memberCredential = credentials[1];
|
|
3603
3679
|
invariant11(getCredentialAssertion2(memberCredential)["@type"] === "dxos.halo.credentials.SpaceMember", void 0, {
|
|
3604
3680
|
F: __dxlog_file13,
|
|
3605
|
-
L:
|
|
3681
|
+
L: 154,
|
|
3606
3682
|
S: this,
|
|
3607
3683
|
A: [
|
|
3608
3684
|
"getCredentialAssertion(memberCredential)['@type'] === 'dxos.halo.credentials.SpaceMember'",
|
|
@@ -3620,13 +3696,13 @@ var DataSpaceManager = class DataSpaceManager2 {
|
|
|
3620
3696
|
opts
|
|
3621
3697
|
}, {
|
|
3622
3698
|
F: __dxlog_file13,
|
|
3623
|
-
L:
|
|
3699
|
+
L: 166,
|
|
3624
3700
|
S: this,
|
|
3625
3701
|
C: (f, a) => f(...a)
|
|
3626
3702
|
});
|
|
3627
3703
|
invariant11(this._isOpen, "Not open.", {
|
|
3628
3704
|
F: __dxlog_file13,
|
|
3629
|
-
L:
|
|
3705
|
+
L: 167,
|
|
3630
3706
|
S: this,
|
|
3631
3707
|
A: [
|
|
3632
3708
|
"this._isOpen",
|
|
@@ -3635,7 +3711,7 @@ var DataSpaceManager = class DataSpaceManager2 {
|
|
|
3635
3711
|
});
|
|
3636
3712
|
invariant11(!this._spaces.has(opts.spaceKey), "Space already exists.", {
|
|
3637
3713
|
F: __dxlog_file13,
|
|
3638
|
-
L:
|
|
3714
|
+
L: 168,
|
|
3639
3715
|
S: this,
|
|
3640
3716
|
A: [
|
|
3641
3717
|
"!this._spaces.has(opts.spaceKey)",
|
|
@@ -3670,7 +3746,7 @@ var DataSpaceManager = class DataSpaceManager2 {
|
|
|
3670
3746
|
metadata
|
|
3671
3747
|
}, {
|
|
3672
3748
|
F: __dxlog_file13,
|
|
3673
|
-
L:
|
|
3749
|
+
L: 201,
|
|
3674
3750
|
S: this,
|
|
3675
3751
|
C: (f, a) => f(...a)
|
|
3676
3752
|
});
|
|
@@ -3697,17 +3773,18 @@ var DataSpaceManager = class DataSpaceManager2 {
|
|
|
3697
3773
|
credentialProvider: createAuthProvider(this._signingContext.credentialSigner),
|
|
3698
3774
|
credentialAuthenticator: deferFunction2(() => dataSpace.authVerifier.verifier)
|
|
3699
3775
|
},
|
|
3700
|
-
|
|
3776
|
+
onAuthorizedConnection: (session) => {
|
|
3701
3777
|
session.addExtension("dxos.mesh.teleport.gossip", gossip.createExtension({
|
|
3702
3778
|
remotePeerId: session.remotePeerId
|
|
3703
3779
|
}));
|
|
3704
3780
|
session.addExtension("dxos.mesh.teleport.notarization", dataSpace.notarizationPlugin.createExtension());
|
|
3781
|
+
this._automergeHost.authorizeDevice(space.key, session.remotePeerId);
|
|
3705
3782
|
session.addExtension("dxos.mesh.teleport.automerge", this._automergeHost.createExtension());
|
|
3706
3783
|
},
|
|
3707
3784
|
onAuthFailure: () => {
|
|
3708
3785
|
log11.warn("auth failure", void 0, {
|
|
3709
3786
|
F: __dxlog_file13,
|
|
3710
|
-
L:
|
|
3787
|
+
L: 238,
|
|
3711
3788
|
S: this,
|
|
3712
3789
|
C: (f, a) => f(...a)
|
|
3713
3790
|
});
|
|
@@ -3731,7 +3808,7 @@ var DataSpaceManager = class DataSpaceManager2 {
|
|
|
3731
3808
|
space: space.key
|
|
3732
3809
|
}, {
|
|
3733
3810
|
F: __dxlog_file13,
|
|
3734
|
-
L:
|
|
3811
|
+
L: 256,
|
|
3735
3812
|
S: this,
|
|
3736
3813
|
C: (f, a) => f(...a)
|
|
3737
3814
|
});
|
|
@@ -3743,7 +3820,7 @@ var DataSpaceManager = class DataSpaceManager2 {
|
|
|
3743
3820
|
open: this._isOpen
|
|
3744
3821
|
}, {
|
|
3745
3822
|
F: __dxlog_file13,
|
|
3746
|
-
L:
|
|
3823
|
+
L: 263,
|
|
3747
3824
|
S: this,
|
|
3748
3825
|
C: (f, a) => f(...a)
|
|
3749
3826
|
});
|
|
@@ -3756,7 +3833,7 @@ var DataSpaceManager = class DataSpaceManager2 {
|
|
|
3756
3833
|
space: space.key
|
|
3757
3834
|
}, {
|
|
3758
3835
|
F: __dxlog_file13,
|
|
3759
|
-
L:
|
|
3836
|
+
L: 269,
|
|
3760
3837
|
S: this,
|
|
3761
3838
|
C: (f, a) => f(...a)
|
|
3762
3839
|
});
|
|
@@ -3813,7 +3890,7 @@ var SpacesServiceImpl = class {
|
|
|
3813
3890
|
}
|
|
3814
3891
|
async createSpace() {
|
|
3815
3892
|
if (!this._identityManager.identity) {
|
|
3816
|
-
throw new Error("This device has no HALO identity available. See https://docs.dxos.org/guide/halo");
|
|
3893
|
+
throw new Error("This device has no HALO identity available. See https://docs.dxos.org/guide/platform/halo");
|
|
3817
3894
|
}
|
|
3818
3895
|
const dataSpaceManager = await this._getDataSpaceManager();
|
|
3819
3896
|
const space = await dataSpaceManager.createSpace();
|
|
@@ -4043,7 +4120,7 @@ function _ts_decorate6(decorators, target, key, desc) {
|
|
|
4043
4120
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
4044
4121
|
}
|
|
4045
4122
|
var __dxlog_file15 = "/home/runner/work/dxos/dxos/packages/sdk/client-services/src/packlets/services/service-context.ts";
|
|
4046
|
-
var ServiceContext = class
|
|
4123
|
+
var ServiceContext = class {
|
|
4047
4124
|
constructor(storage, networkManager, signalManager, modelFactory) {
|
|
4048
4125
|
this.storage = storage;
|
|
4049
4126
|
this.networkManager = networkManager;
|
|
@@ -4344,7 +4421,7 @@ var Lock = class {
|
|
|
4344
4421
|
}
|
|
4345
4422
|
async acquire() {
|
|
4346
4423
|
this._broadcastChannel.postMessage({
|
|
4347
|
-
message:
|
|
4424
|
+
message: "acquiring"
|
|
4348
4425
|
});
|
|
4349
4426
|
try {
|
|
4350
4427
|
log14("aquiring lock...", void 0, {
|
|
@@ -4380,7 +4457,7 @@ var Lock = class {
|
|
|
4380
4457
|
this._releaseTrigger.wake();
|
|
4381
4458
|
}
|
|
4382
4459
|
_onMessage(event) {
|
|
4383
|
-
if (event.data.message ===
|
|
4460
|
+
if (event.data.message === "acquiring") {
|
|
4384
4461
|
this._releaseTrigger.wake();
|
|
4385
4462
|
}
|
|
4386
4463
|
}
|
|
@@ -4490,7 +4567,7 @@ import { clientServiceBundle, defaultKey, Properties } from "@dxos/client-protoc
|
|
|
4490
4567
|
import { Context as Context10 } from "@dxos/context";
|
|
4491
4568
|
import { DocumentModel as DocumentModel2 } from "@dxos/document-model";
|
|
4492
4569
|
import { DataServiceImpl } from "@dxos/echo-pipeline";
|
|
4493
|
-
import { base } from "@dxos/echo-schema";
|
|
4570
|
+
import { base, getRawDoc } from "@dxos/echo-schema";
|
|
4494
4571
|
import { invariant as invariant14 } from "@dxos/invariant";
|
|
4495
4572
|
import { PublicKey as PublicKey11 } from "@dxos/keys";
|
|
4496
4573
|
import { log as log16 } from "@dxos/log";
|
|
@@ -4777,7 +4854,7 @@ var createGenesisMutationFromTypedObject = (obj) => {
|
|
|
4777
4854
|
}
|
|
4778
4855
|
};
|
|
4779
4856
|
};
|
|
4780
|
-
var ClientServicesHost = class
|
|
4857
|
+
var ClientServicesHost = class {
|
|
4781
4858
|
constructor({
|
|
4782
4859
|
config,
|
|
4783
4860
|
modelFactory = createDefaultModelFactory(),
|
|
@@ -4979,7 +5056,7 @@ var ClientServicesHost = class ClientServicesHost2 {
|
|
|
4979
5056
|
this._serviceContext = new ServiceContext(this._storage, this._networkManager, this._signalManager, this._modelFactory);
|
|
4980
5057
|
this._serviceRegistry.setServices({
|
|
4981
5058
|
SystemService: this._systemService,
|
|
4982
|
-
IdentityService: new IdentityServiceImpl((params) => this._createIdentity(params), this._serviceContext.identityManager, this._serviceContext.keyring, (profile) => this._serviceContext.broadcastProfileUpdate(profile)),
|
|
5059
|
+
IdentityService: new IdentityServiceImpl((params, useAutomerge) => this._createIdentity(params, useAutomerge), this._serviceContext.identityManager, this._serviceContext.keyring, (profile) => this._serviceContext.broadcastProfileUpdate(profile)),
|
|
4983
5060
|
InvitationsService: new InvitationsServiceImpl(this._serviceContext.invitations, (invitation) => this._serviceContext.getInvitationHandler(invitation)),
|
|
4984
5061
|
DevicesService: new DevicesServiceImpl(this._serviceContext.identityManager),
|
|
4985
5062
|
SpacesService: new SpacesServiceImpl(this._serviceContext.identityManager, this._serviceContext.spaceManager, this._serviceContext.dataServiceSubscriptions, async () => {
|
|
@@ -5093,25 +5170,44 @@ var ClientServicesHost = class ClientServicesHost2 {
|
|
|
5093
5170
|
});
|
|
5094
5171
|
await this._callbacks?.onReset?.();
|
|
5095
5172
|
}
|
|
5096
|
-
async _createIdentity(params) {
|
|
5173
|
+
async _createIdentity(params, useAutomerge) {
|
|
5097
5174
|
const identity = await this._serviceContext.createIdentity(params);
|
|
5098
5175
|
await this._serviceContext.initialized.wait();
|
|
5099
5176
|
const space = await this._serviceContext.dataSpaceManager.createSpace();
|
|
5100
5177
|
const obj = new Properties(void 0, {
|
|
5101
|
-
automerge:
|
|
5178
|
+
automerge: useAutomerge
|
|
5102
5179
|
});
|
|
5103
5180
|
obj[defaultKey] = identity.identityKey.toHex();
|
|
5104
|
-
|
|
5105
|
-
|
|
5106
|
-
|
|
5107
|
-
|
|
5108
|
-
|
|
5181
|
+
if (!useAutomerge) {
|
|
5182
|
+
await this._serviceRegistry.services.DataService.write({
|
|
5183
|
+
spaceKey: space.key,
|
|
5184
|
+
batch: {
|
|
5185
|
+
objects: [
|
|
5186
|
+
createGenesisMutationFromTypedObject(obj)
|
|
5187
|
+
]
|
|
5188
|
+
}
|
|
5189
|
+
});
|
|
5190
|
+
await this._serviceRegistry.services.DataService.flush({
|
|
5191
|
+
spaceKey: space.key
|
|
5192
|
+
});
|
|
5193
|
+
} else {
|
|
5194
|
+
const automergeIndex = space.automergeSpaceState.rootUrl;
|
|
5195
|
+
invariant14(automergeIndex, void 0, {
|
|
5196
|
+
F: __dxlog_file17,
|
|
5197
|
+
L: 375,
|
|
5198
|
+
S: this,
|
|
5199
|
+
A: [
|
|
5200
|
+
"automergeIndex",
|
|
5201
|
+
""
|
|
5109
5202
|
]
|
|
5110
|
-
}
|
|
5111
|
-
|
|
5112
|
-
|
|
5113
|
-
|
|
5114
|
-
|
|
5203
|
+
});
|
|
5204
|
+
const document = await this._serviceContext.automergeHost.repo.find(automergeIndex);
|
|
5205
|
+
await document.whenReady();
|
|
5206
|
+
document.change((doc) => {
|
|
5207
|
+
doc.objects ??= {};
|
|
5208
|
+
doc.objects[obj[base]._id] = getRawDoc(obj).handle.docSync();
|
|
5209
|
+
});
|
|
5210
|
+
}
|
|
5115
5211
|
return identity;
|
|
5116
5212
|
}
|
|
5117
5213
|
};
|
|
@@ -5167,4 +5263,4 @@ export {
|
|
|
5167
5263
|
createDefaultModelFactory,
|
|
5168
5264
|
ClientServicesHost
|
|
5169
5265
|
};
|
|
5170
|
-
//# sourceMappingURL=chunk-
|
|
5266
|
+
//# sourceMappingURL=chunk-YD2GBB3W.mjs.map
|