@dxos/client-services 0.8.3 → 0.8.4-main.28f8d3d

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 (168) hide show
  1. package/dist/lib/browser/{chunk-LBG3C332.mjs → chunk-KVJOLMLK.mjs} +2620 -2412
  2. package/dist/lib/browser/chunk-KVJOLMLK.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +42 -23
  4. package/dist/lib/browser/index.mjs.map +3 -3
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +17 -16
  7. package/dist/lib/browser/testing/index.mjs.map +3 -3
  8. package/dist/lib/node-esm/{chunk-SKGQLRKS.mjs → chunk-67QB26KM.mjs} +2617 -2408
  9. package/dist/lib/node-esm/chunk-67QB26KM.mjs.map +7 -0
  10. package/dist/lib/node-esm/index.mjs +42 -23
  11. package/dist/lib/node-esm/index.mjs.map +3 -3
  12. package/dist/lib/node-esm/meta.json +1 -1
  13. package/dist/lib/node-esm/testing/index.mjs +17 -16
  14. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  15. package/dist/types/src/packlets/agents/edge-agent-service.d.ts +1 -1
  16. package/dist/types/src/packlets/agents/edge-agent-service.d.ts.map +1 -1
  17. package/dist/types/src/packlets/devices/devices-service.d.ts.map +1 -1
  18. package/dist/types/src/packlets/devtools/devtools.d.ts +18 -18
  19. package/dist/types/src/packlets/devtools/devtools.d.ts.map +1 -1
  20. package/dist/types/src/packlets/devtools/feeds.d.ts +1 -1
  21. package/dist/types/src/packlets/devtools/feeds.d.ts.map +1 -1
  22. package/dist/types/src/packlets/devtools/network.d.ts +1 -1
  23. package/dist/types/src/packlets/devtools/network.d.ts.map +1 -1
  24. package/dist/types/src/packlets/diagnostics/browser-diagnostics-broadcast.d.ts +1 -1
  25. package/dist/types/src/packlets/diagnostics/browser-diagnostics-broadcast.d.ts.map +1 -1
  26. package/dist/types/src/packlets/diagnostics/diagnostics-broadcast.d.ts +1 -1
  27. package/dist/types/src/packlets/diagnostics/diagnostics-broadcast.d.ts.map +1 -1
  28. package/dist/types/src/packlets/diagnostics/diagnostics.d.ts +1 -1
  29. package/dist/types/src/packlets/diagnostics/diagnostics.d.ts.map +1 -1
  30. package/dist/types/src/packlets/identity/authenticator.d.ts.map +1 -1
  31. package/dist/types/src/packlets/identity/contacts-service.d.ts +1 -1
  32. package/dist/types/src/packlets/identity/contacts-service.d.ts.map +1 -1
  33. package/dist/types/src/packlets/identity/default-space-state-machine.d.ts +1 -1
  34. package/dist/types/src/packlets/identity/default-space-state-machine.d.ts.map +1 -1
  35. package/dist/types/src/packlets/identity/identity-manager.d.ts +1 -1
  36. package/dist/types/src/packlets/identity/identity-manager.d.ts.map +1 -1
  37. package/dist/types/src/packlets/identity/identity-service.d.ts +1 -1
  38. package/dist/types/src/packlets/identity/identity-service.d.ts.map +1 -1
  39. package/dist/types/src/packlets/identity/identity.d.ts +1 -1
  40. package/dist/types/src/packlets/identity/identity.d.ts.map +1 -1
  41. package/dist/types/src/packlets/invitations/device-invitation-protocol.d.ts +1 -1
  42. package/dist/types/src/packlets/invitations/device-invitation-protocol.d.ts.map +1 -1
  43. package/dist/types/src/packlets/invitations/edge-invitation-handler.d.ts +1 -1
  44. package/dist/types/src/packlets/invitations/edge-invitation-handler.d.ts.map +1 -1
  45. package/dist/types/src/packlets/invitations/index.d.ts +1 -1
  46. package/dist/types/src/packlets/invitations/index.d.ts.map +1 -1
  47. package/dist/types/src/packlets/invitations/invitation-guest-extenstion.d.ts.map +1 -1
  48. package/dist/types/src/packlets/invitations/invitation-host-extension.d.ts.map +1 -1
  49. package/dist/types/src/packlets/invitations/invitation-protocol.d.ts +1 -1
  50. package/dist/types/src/packlets/invitations/invitation-protocol.d.ts.map +1 -1
  51. package/dist/types/src/packlets/invitations/invitations-handler.d.ts.map +1 -1
  52. package/dist/types/src/packlets/invitations/invitations-manager.d.ts.map +1 -1
  53. package/dist/types/src/packlets/invitations/invitations-service.d.ts +1 -1
  54. package/dist/types/src/packlets/invitations/invitations-service.d.ts.map +1 -1
  55. package/dist/types/src/packlets/invitations/space-invitation-protocol.d.ts +1 -1
  56. package/dist/types/src/packlets/invitations/space-invitation-protocol.d.ts.map +1 -1
  57. package/dist/types/src/packlets/invitations/utils.d.ts.map +1 -1
  58. package/dist/types/src/packlets/locks/index.d.ts +1 -1
  59. package/dist/types/src/packlets/locks/index.d.ts.map +1 -1
  60. package/dist/types/src/packlets/logging/logging-service.d.ts +1 -1
  61. package/dist/types/src/packlets/logging/logging-service.d.ts.map +1 -1
  62. package/dist/types/src/packlets/network/network-service.d.ts +2 -2
  63. package/dist/types/src/packlets/network/network-service.d.ts.map +1 -1
  64. package/dist/types/src/packlets/services/client-rpc-server.d.ts.map +1 -1
  65. package/dist/types/src/packlets/services/service-context.d.ts +3 -3
  66. package/dist/types/src/packlets/services/service-context.d.ts.map +1 -1
  67. package/dist/types/src/packlets/services/service-host.d.ts +1 -1
  68. package/dist/types/src/packlets/services/service-host.d.ts.map +1 -1
  69. package/dist/types/src/packlets/space-export/space-archive-writer.d.ts +1 -1
  70. package/dist/types/src/packlets/space-export/space-archive-writer.d.ts.map +1 -1
  71. package/dist/types/src/packlets/spaces/automerge-space-state.d.ts +1 -1
  72. package/dist/types/src/packlets/spaces/automerge-space-state.d.ts.map +1 -1
  73. package/dist/types/src/packlets/spaces/data-space-manager.d.ts +2 -2
  74. package/dist/types/src/packlets/spaces/data-space-manager.d.ts.map +1 -1
  75. package/dist/types/src/packlets/spaces/data-space.d.ts +4 -4
  76. package/dist/types/src/packlets/spaces/data-space.d.ts.map +1 -1
  77. package/dist/types/src/packlets/spaces/notarization-plugin.d.ts.map +1 -1
  78. package/dist/types/src/packlets/spaces/spaces-service.d.ts +2 -2
  79. package/dist/types/src/packlets/spaces/spaces-service.d.ts.map +1 -1
  80. package/dist/types/src/packlets/storage/profile-archive.d.ts.map +1 -1
  81. package/dist/types/src/packlets/storage/storage.d.ts.map +1 -1
  82. package/dist/types/src/packlets/system/system-service.d.ts +1 -1
  83. package/dist/types/src/packlets/system/system-service.d.ts.map +1 -1
  84. package/dist/types/src/packlets/testing/invitation-utils.d.ts.map +1 -1
  85. package/dist/types/src/packlets/testing/test-builder.d.ts +2 -2
  86. package/dist/types/src/packlets/testing/test-builder.d.ts.map +1 -1
  87. package/dist/types/src/packlets/worker/worker-runtime.d.ts.map +1 -1
  88. package/dist/types/src/packlets/worker/worker-session.d.ts.map +1 -1
  89. package/dist/types/src/version.d.ts +1 -1
  90. package/dist/types/src/version.d.ts.map +1 -1
  91. package/dist/types/tsconfig.tsbuildinfo +1 -1
  92. package/package.json +41 -39
  93. package/src/packlets/agents/edge-agent-service.ts +2 -2
  94. package/src/packlets/devices/devices-service.test.ts +4 -3
  95. package/src/packlets/devices/devices-service.ts +1 -1
  96. package/src/packlets/devtools/devtools.ts +28 -27
  97. package/src/packlets/devtools/feeds.ts +2 -2
  98. package/src/packlets/devtools/network.ts +1 -1
  99. package/src/packlets/diagnostics/browser-diagnostics-broadcast.ts +1 -1
  100. package/src/packlets/diagnostics/diagnostics-broadcast.ts +1 -1
  101. package/src/packlets/diagnostics/diagnostics-collector.ts +1 -1
  102. package/src/packlets/diagnostics/diagnostics.ts +1 -1
  103. package/src/packlets/identity/authenticator.node.test.ts +1 -1
  104. package/src/packlets/identity/authenticator.ts +1 -1
  105. package/src/packlets/identity/contacts-service.ts +3 -2
  106. package/src/packlets/identity/default-space-state-machine.ts +1 -1
  107. package/src/packlets/identity/identity-manager.test.ts +3 -3
  108. package/src/packlets/identity/identity-manager.ts +3 -3
  109. package/src/packlets/identity/identity-service.test.ts +3 -2
  110. package/src/packlets/identity/identity-service.ts +2 -1
  111. package/src/packlets/identity/identity.test.ts +5 -5
  112. package/src/packlets/identity/identity.ts +7 -6
  113. package/src/packlets/invitations/device-invitation-protocol.test.ts +4 -4
  114. package/src/packlets/invitations/device-invitation-protocol.ts +2 -1
  115. package/src/packlets/invitations/edge-invitation-handler.ts +1 -1
  116. package/src/packlets/invitations/index.ts +1 -1
  117. package/src/packlets/invitations/invitation-guest-extenstion.ts +1 -1
  118. package/src/packlets/invitations/invitation-host-extension.ts +2 -2
  119. package/src/packlets/invitations/invitation-protocol.ts +1 -1
  120. package/src/packlets/invitations/invitations-handler.test.ts +302 -292
  121. package/src/packlets/invitations/invitations-handler.ts +3 -3
  122. package/src/packlets/invitations/invitations-manager.ts +3 -3
  123. package/src/packlets/invitations/invitations-service.ts +1 -1
  124. package/src/packlets/invitations/space-invitation-protocol.test.ts +9 -9
  125. package/src/packlets/invitations/space-invitation-protocol.ts +3 -2
  126. package/src/packlets/invitations/utils.ts +1 -1
  127. package/src/packlets/locks/browser.ts +1 -1
  128. package/src/packlets/locks/index.ts +1 -1
  129. package/src/packlets/logging/logging-service.ts +3 -2
  130. package/src/packlets/logging/logging.test.ts +1 -1
  131. package/src/packlets/network/network-service.test.ts +4 -3
  132. package/src/packlets/network/network-service.ts +2 -2
  133. package/src/packlets/services/client-rpc-server.ts +1 -1
  134. package/src/packlets/services/service-context.test.ts +1 -1
  135. package/src/packlets/services/service-context.ts +4 -4
  136. package/src/packlets/services/service-host.test.ts +3 -2
  137. package/src/packlets/services/service-host.ts +15 -13
  138. package/src/packlets/services/service-registry.test.ts +2 -1
  139. package/src/packlets/space-export/space-archive-writer.ts +2 -2
  140. package/src/packlets/space-export/tar.test.ts +1 -1
  141. package/src/packlets/spaces/automerge-space-state.ts +1 -1
  142. package/src/packlets/spaces/data-space-manager.ts +16 -15
  143. package/src/packlets/spaces/data-space.ts +9 -8
  144. package/src/packlets/spaces/edge-feed-replicator.test.ts +2 -2
  145. package/src/packlets/spaces/edge-feed-replicator.ts +1 -1
  146. package/src/packlets/spaces/notarization-plugin.test.ts +1 -1
  147. package/src/packlets/spaces/notarization-plugin.ts +3 -3
  148. package/src/packlets/spaces/spaces-service.test.ts +3 -2
  149. package/src/packlets/spaces/spaces-service.ts +16 -15
  150. package/src/packlets/storage/profile-archive.ts +1 -1
  151. package/src/packlets/storage/storage.ts +3 -4
  152. package/src/packlets/system/system-service.test.ts +1 -1
  153. package/src/packlets/system/system-service.ts +4 -4
  154. package/src/packlets/testing/invitation-utils.ts +1 -1
  155. package/src/packlets/testing/test-builder.ts +3 -3
  156. package/src/packlets/worker/worker-runtime.ts +2 -1
  157. package/src/packlets/worker/worker-session.ts +4 -4
  158. package/src/version.ts +1 -5
  159. package/README.yml +0 -5
  160. package/dist/lib/browser/chunk-LBG3C332.mjs.map +0 -7
  161. package/dist/lib/node/chunk-LMGLGOUU.cjs +0 -9311
  162. package/dist/lib/node/chunk-LMGLGOUU.cjs.map +0 -7
  163. package/dist/lib/node/index.cjs +0 -437
  164. package/dist/lib/node/index.cjs.map +0 -7
  165. package/dist/lib/node/meta.json +0 -1
  166. package/dist/lib/node/testing/index.cjs +0 -452
  167. package/dist/lib/node/testing/index.cjs.map +0 -7
  168. package/dist/lib/node-esm/chunk-SKGQLRKS.mjs.map +0 -7
@@ -2,7 +2,7 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- import { type PushStream, scheduleTask, TimeoutError, type Trigger } from '@dxos/async';
5
+ import { type PushStream, TimeoutError, type Trigger, scheduleTask } from '@dxos/async';
6
6
  import { INVITATION_TIMEOUT, getExpirationTime } from '@dxos/client-protocol';
7
7
  import { type Context, ContextDisposedError } from '@dxos/context';
8
8
  import { createKeyPair, sign } from '@dxos/crypto';
@@ -10,7 +10,7 @@ import { type EdgeHttpClient } from '@dxos/edge-client';
10
10
  import { invariant } from '@dxos/invariant';
11
11
  import { PublicKey } from '@dxos/keys';
12
12
  import { log } from '@dxos/log';
13
- import { createTeleportProtocolFactory, type SwarmNetworkManager, type SwarmConnection } from '@dxos/network-manager';
13
+ import { type SwarmConnection, type SwarmNetworkManager, createTeleportProtocolFactory } from '@dxos/network-manager';
14
14
  import { InvalidInvitationError, InvalidInvitationExtensionRoleError, trace } from '@dxos/protocols';
15
15
  import { type AdmissionKeypair, Invitation } from '@dxos/protocols/proto/dxos/client/services';
16
16
  import { type DeviceProfileDocument } from '@dxos/protocols/proto/dxos/halo/credentials';
@@ -22,7 +22,7 @@ import { ComplexSet } from '@dxos/util';
22
22
 
23
23
  import { type EdgeInvitationConfig, EdgeInvitationHandler } from './edge-invitation-handler';
24
24
  import { InvitationGuestExtension } from './invitation-guest-extenstion';
25
- import { InvitationHostExtension, isAuthenticationRequired, MAX_OTP_ATTEMPTS } from './invitation-host-extension';
25
+ import { InvitationHostExtension, MAX_OTP_ATTEMPTS, isAuthenticationRequired } from './invitation-host-extension';
26
26
  import { type InvitationProtocol } from './invitation-protocol';
27
27
  import { createGuardedInvitationState } from './invitation-state';
28
28
  import { InvitationTopology } from './invitation-topology';
@@ -4,14 +4,14 @@
4
4
 
5
5
  import { Event, PushStream, TimeoutError, Trigger } from '@dxos/async';
6
6
  import {
7
- AuthenticatingInvitation,
8
7
  AUTHENTICATION_CODE_LENGTH,
8
+ AuthenticatingInvitation,
9
9
  CancellableInvitation,
10
10
  INVITATION_TIMEOUT,
11
11
  } from '@dxos/client-protocol';
12
12
  import { Context } from '@dxos/context';
13
13
  import { generatePasscode } from '@dxos/credentials';
14
- import { hasInvitationExpired, type MetadataStore } from '@dxos/echo-pipeline';
14
+ import { type MetadataStore, hasInvitationExpired } from '@dxos/echo-pipeline';
15
15
  import { invariant } from '@dxos/invariant';
16
16
  import { PublicKey } from '@dxos/keys';
17
17
  import { log } from '@dxos/log';
@@ -23,7 +23,7 @@ import {
23
23
  import { SpaceMember } from '@dxos/protocols/proto/dxos/halo/credentials';
24
24
 
25
25
  import type { InvitationProtocol } from './invitation-protocol';
26
- import { createAdmissionKeypair, type InvitationsHandler } from './invitations-handler';
26
+ import { type InvitationsHandler, createAdmissionKeypair } from './invitations-handler';
27
27
 
28
28
  /**
29
29
  * Entry point for creating and accepting invitations, keeps track of existing invitation set and
@@ -4,8 +4,8 @@
4
4
 
5
5
  import { Stream } from '@dxos/codec-protobuf/stream';
6
6
  import {
7
- type AuthenticationRequest,
8
7
  type AcceptInvitationRequest,
8
+ type AuthenticationRequest,
9
9
  type Invitation,
10
10
  type InvitationsService,
11
11
  QueryInvitationsResponse,
@@ -2,9 +2,9 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- import { onTestFinished, describe, expect, test } from 'vitest';
5
+ import { describe, expect, onTestFinished, test } from 'vitest';
6
6
 
7
- import { asyncChain, Trigger } from '@dxos/async';
7
+ import { Trigger, chain } from '@dxos/async';
8
8
  import { raise } from '@dxos/debug';
9
9
  import { AlreadyJoinedError } from '@dxos/protocols';
10
10
  import { Invitation } from '@dxos/protocols/proto/dxos/client/services';
@@ -22,7 +22,7 @@ const closeAfterTest = async (peer: ServiceContext) => {
22
22
 
23
23
  describe('services/space-invitations-protocol', () => {
24
24
  test('genesis', async () => {
25
- const [peer] = await asyncChain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(1));
25
+ const [peer] = await chain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(1));
26
26
 
27
27
  const space = await peer.dataSpaceManager!.createSpace();
28
28
  expect(peer.dataSpaceManager!.spaces.has(space.key)).to.be.true;
@@ -31,7 +31,7 @@ describe('services/space-invitations-protocol', () => {
31
31
  });
32
32
 
33
33
  test('genesis & ready', async () => {
34
- const [peer] = await asyncChain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(1));
34
+ const [peer] = await chain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(1));
35
35
 
36
36
  const space = await peer.dataSpaceManager!.createSpace();
37
37
  expect(peer.dataSpaceManager!.spaces.has(space.key)).to.be.true;
@@ -41,7 +41,7 @@ describe('services/space-invitations-protocol', () => {
41
41
  });
42
42
 
43
43
  test('invitation with no auth', async () => {
44
- const [host, guest] = await asyncChain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
44
+ const [host, guest] = await chain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
45
45
 
46
46
  const space1 = await host.dataSpaceManager!.createSpace();
47
47
  const spaceKey = space1.key;
@@ -65,7 +65,7 @@ describe('services/space-invitations-protocol', () => {
65
65
  });
66
66
 
67
67
  test('invitation when already joined', async () => {
68
- const [host, guest] = await asyncChain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
68
+ const [host, guest] = await chain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
69
69
 
70
70
  const space1 = await host.dataSpaceManager!.createSpace();
71
71
  const spaceKey = space1.key;
@@ -92,7 +92,7 @@ describe('services/space-invitations-protocol', () => {
92
92
  });
93
93
 
94
94
  test('creates and accepts invitation with retry', async () => {
95
- const [host, guest] = await asyncChain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
95
+ const [host, guest] = await chain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
96
96
 
97
97
  let attempt = 0;
98
98
 
@@ -153,7 +153,7 @@ describe('services/space-invitations-protocol', () => {
153
153
  });
154
154
 
155
155
  test('timeout', async () => {
156
- const [host, guest] = await asyncChain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
156
+ const [host, guest] = await chain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
157
157
  const space = await host.dataSpaceManager!.createSpace();
158
158
  const hostInvitation = await createInvitation(host, {
159
159
  kind: Invitation.Kind.SPACE,
@@ -175,7 +175,7 @@ describe('services/space-invitations-protocol', () => {
175
175
  });
176
176
 
177
177
  test('cancels invitation', async () => {
178
- const [host, guest] = await asyncChain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
178
+ const [host, guest] = await chain<ServiceContext>([createIdentity, closeAfterTest])(createPeers(2));
179
179
 
180
180
  const hostConnected = new Trigger<Invitation>();
181
181
  const guestConnected = new Trigger<Invitation>();
@@ -20,16 +20,17 @@ import {
20
20
  SpaceNotFoundError,
21
21
  } from '@dxos/protocols';
22
22
  import { Invitation } from '@dxos/protocols/proto/dxos/client/services';
23
- import { SpaceMember, type ProfileDocument } from '@dxos/protocols/proto/dxos/halo/credentials';
23
+ import { type ProfileDocument, SpaceMember } from '@dxos/protocols/proto/dxos/halo/credentials';
24
24
  import {
25
25
  type AdmissionRequest,
26
26
  type AdmissionResponse,
27
27
  type IntroductionRequest,
28
28
  } from '@dxos/protocols/proto/dxos/halo/invitations';
29
29
 
30
+ import { type DataSpaceManager, type SigningContext } from '../spaces';
31
+
30
32
  import { type InvitationProtocol } from './invitation-protocol';
31
33
  import { computeExpirationTime } from './utils';
32
- import { type DataSpaceManager, type SigningContext } from '../spaces';
33
34
 
34
35
  export class SpaceInvitationProtocol implements InvitationProtocol {
35
36
  constructor(
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import { type Mutex, type MutexGuard } from '@dxos/async';
6
- import { cancelWithContext, type Context, ContextDisposedError } from '@dxos/context';
6
+ import { type Context, ContextDisposedError, cancelWithContext } from '@dxos/context';
7
7
  import { Invitation } from '@dxos/protocols/proto/dxos/client/services';
8
8
 
9
9
  export const stateToString = (state: Invitation.State): string => {
@@ -2,7 +2,7 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { asyncTimeout, Trigger } from '@dxos/async';
5
+ import { Trigger, asyncTimeout } from '@dxos/async';
6
6
  import { RESOURCE_LOCK_TIMEOUT } from '@dxos/client-protocol';
7
7
  import { log, logInfo } from '@dxos/log';
8
8
 
@@ -2,5 +2,5 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- export * from './resource-lock';
5
+ export type * from './resource-lock';
6
6
  export * from './node';
@@ -13,12 +13,12 @@ import {
13
13
  log,
14
14
  } from '@dxos/log';
15
15
  import {
16
+ type ControlMetricsRequest,
17
+ type ControlMetricsResponse,
16
18
  type LogEntry,
17
19
  type LoggingService,
18
20
  type Metrics,
19
21
  QueryLogsRequest,
20
- type ControlMetricsRequest,
21
- type ControlMetricsResponse,
22
22
  type QueryMetricsRequest,
23
23
  type QueryMetricsResponse,
24
24
  } from '@dxos/protocols/proto/dxos/client/services';
@@ -112,6 +112,7 @@ export class LoggingServiceImpl implements LoggingService {
112
112
 
113
113
  const record: LogEntry = {
114
114
  ...entry,
115
+ message: entry.message ?? (entry.error ? (entry.error.message ?? String(entry.error)) : ''),
115
116
  context: jsonify(getContextFromEntry(entry)),
116
117
  timestamp: new Date(),
117
118
  meta: {
@@ -5,7 +5,7 @@
5
5
  import { afterEach, beforeEach, describe, expect, test } from 'vitest';
6
6
 
7
7
  import { Trigger } from '@dxos/async';
8
- import { log, LogLevel } from '@dxos/log';
8
+ import { LogLevel, log } from '@dxos/log';
9
9
  import { type LogEntry } from '@dxos/protocols/proto/dxos/client/services';
10
10
 
11
11
  import { LoggingServiceImpl } from './logging-service';
@@ -2,16 +2,17 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { afterEach, onTestFinished, beforeEach, describe, expect, test } from 'vitest';
5
+ import { afterEach, beforeEach, describe, expect, onTestFinished, test } from 'vitest';
6
6
 
7
7
  import { Trigger } from '@dxos/async';
8
8
  import { Context } from '@dxos/context';
9
- import { type NetworkService, ConnectionState } from '@dxos/protocols/proto/dxos/client/services';
9
+ import { ConnectionState, type NetworkService } from '@dxos/protocols/proto/dxos/client/services';
10
10
 
11
- import { NetworkServiceImpl } from './network-service';
12
11
  import { type ServiceContext } from '../services';
13
12
  import { createServiceContext } from '../testing';
14
13
 
14
+ import { NetworkServiceImpl } from './network-service';
15
+
15
16
  describe('NetworkService', () => {
16
17
  let serviceContext: ServiceContext;
17
18
  let networkService: NetworkService;
@@ -7,15 +7,15 @@ import { type EdgeConnection } from '@dxos/edge-client';
7
7
  import { type SignalManager } from '@dxos/messaging';
8
8
  import { type SwarmNetworkManager } from '@dxos/network-manager';
9
9
  import {
10
- type SubscribeSwarmStateRequest,
11
10
  type NetworkService,
12
11
  type NetworkStatus,
12
+ type SubscribeSwarmStateRequest,
13
13
  type UpdateConfigRequest,
14
14
  } from '@dxos/protocols/proto/dxos/client/services';
15
15
  import { type Peer, type SwarmResponse } from '@dxos/protocols/proto/dxos/edge/messenger';
16
16
  import {
17
- type LeaveRequest,
18
17
  type JoinRequest,
18
+ type LeaveRequest,
19
19
  type Message,
20
20
  type QueryRequest,
21
21
  } from '@dxos/protocols/proto/dxos/edge/signal';
@@ -5,7 +5,7 @@
5
5
  import { type ClientServices } from '@dxos/client-protocol';
6
6
  import { type Any, type ServiceHandler, Stream } from '@dxos/codec-protobuf';
7
7
  import { raise } from '@dxos/debug';
8
- import { parseMethodName, RpcPeer, type RpcPeerOptions, type ServiceBundle } from '@dxos/rpc';
8
+ import { RpcPeer, type RpcPeerOptions, type ServiceBundle, parseMethodName } from '@dxos/rpc';
9
9
  import { MapCounter, trace } from '@dxos/tracing';
10
10
  import { type MaybePromise } from '@dxos/util';
11
11
 
@@ -4,7 +4,7 @@
4
4
 
5
5
  import { describe, test } from 'vitest';
6
6
 
7
- import { MemorySignalManagerContext, MemorySignalManager } from '@dxos/messaging';
7
+ import { MemorySignalManager, MemorySignalManagerContext } from '@dxos/messaging';
8
8
  import { Invitation } from '@dxos/protocols/proto/dxos/client/services';
9
9
  import { openAndClose } from '@dxos/test-utils';
10
10
 
@@ -4,7 +4,7 @@
4
4
 
5
5
  import { Mutex, Trigger } from '@dxos/async';
6
6
  import { Context, Resource } from '@dxos/context';
7
- import { getCredentialAssertion, type CredentialProcessor } from '@dxos/credentials';
7
+ import { type CredentialProcessor, getCredentialAssertion } from '@dxos/credentials';
8
8
  import { failUndefined, warnAfterTimeout } from '@dxos/debug';
9
9
  import {
10
10
  EchoEdgeReplicator,
@@ -15,7 +15,7 @@ import {
15
15
  valueEncoding,
16
16
  } from '@dxos/echo-pipeline';
17
17
  import { createChainEdgeIdentity, createEphemeralEdgeIdentity } from '@dxos/edge-client';
18
- import type { EdgeHttpClient, EdgeConnection, EdgeIdentity } from '@dxos/edge-client';
18
+ import type { EdgeConnection, EdgeHttpClient, EdgeIdentity } from '@dxos/edge-client';
19
19
  import { FeedFactory, FeedStore } from '@dxos/feed-store';
20
20
  import { invariant } from '@dxos/invariant';
21
21
  import { Keyring } from '@dxos/keyring';
@@ -36,8 +36,8 @@ import { safeInstanceof } from '@dxos/util';
36
36
 
37
37
  import { EdgeAgentManager } from '../agents';
38
38
  import {
39
- IdentityManager,
40
39
  type CreateIdentityOptions,
40
+ IdentityManager,
41
41
  type IdentityManagerParams,
42
42
  type JoinIdentityParams,
43
43
  } from '../identity';
@@ -45,10 +45,10 @@ import { EdgeIdentityRecoveryManager } from '../identity/identity-recovery-manag
45
45
  import {
46
46
  DeviceInvitationProtocol,
47
47
  type InvitationConnectionParams,
48
+ type InvitationProtocol,
48
49
  InvitationsHandler,
49
50
  InvitationsManager,
50
51
  SpaceInvitationProtocol,
51
- type InvitationProtocol,
52
52
  } from '../invitations';
53
53
  import { DataSpaceManager, type DataSpaceManagerRuntimeParams, type SigningContext } from '../spaces';
54
54
 
@@ -3,9 +3,10 @@
3
3
  //
4
4
 
5
5
  import { rmSync } from 'node:fs';
6
- import { afterEach, onTestFinished, describe, expect, test } from 'vitest';
7
6
 
8
- import { asyncTimeout, latch, Trigger } from '@dxos/async';
7
+ import { afterEach, describe, expect, onTestFinished, test } from 'vitest';
8
+
9
+ import { Trigger, asyncTimeout, latch } from '@dxos/async';
9
10
  import { Config } from '@dxos/config';
10
11
  import { Context } from '@dxos/context';
11
12
  import { verifyPresentation } from '@dxos/credentials';
@@ -3,20 +3,20 @@
3
3
  //
4
4
 
5
5
  import { Event, synchronized } from '@dxos/async';
6
- import { clientServiceBundle, type ClientServices } from '@dxos/client-protocol';
6
+ import { type ClientServices, clientServiceBundle } from '@dxos/client-protocol';
7
7
  import { type Config } from '@dxos/config';
8
8
  import { Context } from '@dxos/context';
9
- import { EdgeClient, EdgeHttpClient, createStubEdgeIdentity, type EdgeConnection } from '@dxos/edge-client';
9
+ import { EdgeClient, type EdgeConnection, EdgeHttpClient, createStubEdgeIdentity } from '@dxos/edge-client';
10
10
  import { invariant } from '@dxos/invariant';
11
11
  import { PublicKey } from '@dxos/keys';
12
12
  import { type LevelDB } from '@dxos/kv-store';
13
13
  import { log } from '@dxos/log';
14
- import { EdgeSignalManager, WebsocketSignalManager, type SignalManager } from '@dxos/messaging';
14
+ import { EdgeSignalManager, type SignalManager, WebsocketSignalManager } from '@dxos/messaging';
15
15
  import {
16
16
  SwarmNetworkManager,
17
+ type TransportFactory,
17
18
  createIceProvider,
18
19
  createRtcTransportFactory,
19
- type TransportFactory,
20
20
  } from '@dxos/network-manager';
21
21
  import { trace } from '@dxos/protocols';
22
22
  import { SystemStatus } from '@dxos/protocols/proto/dxos/client/services';
@@ -24,17 +24,15 @@ import { type Storage } from '@dxos/random-access-storage';
24
24
  import { TRACE_PROCESSOR, trace as Trace } from '@dxos/tracing';
25
25
  import { WebsocketRpcClient } from '@dxos/websocket-rpc';
26
26
 
27
- import { ServiceContext, type ServiceContextRuntimeParams } from './service-context';
28
- import { ServiceRegistry } from './service-registry';
29
27
  import { EdgeAgentServiceImpl } from '../agents';
30
28
  import { DevicesServiceImpl } from '../devices';
31
29
  import { DevtoolsHostEvents, DevtoolsServiceImpl } from '../devtools';
32
30
  import {
31
+ type CollectDiagnosticsBroadcastHandler,
33
32
  createCollectDiagnosticsBroadcastHandler,
34
33
  createDiagnostics,
35
- type CollectDiagnosticsBroadcastHandler,
36
34
  } from '../diagnostics';
37
- import { IdentityServiceImpl, type CreateIdentityOptions } from '../identity';
35
+ import { type CreateIdentityOptions, IdentityServiceImpl } from '../identity';
38
36
  import { ContactsServiceImpl } from '../identity/contacts-service';
39
37
  import { InvitationsServiceImpl } from '../invitations';
40
38
  import { Lock, type ResourceLock } from '../locks';
@@ -44,6 +42,9 @@ import { SpacesServiceImpl } from '../spaces';
44
42
  import { createLevel, createStorageObjects } from '../storage';
45
43
  import { SystemServiceImpl } from '../system';
46
44
 
45
+ import { ServiceContext, type ServiceContextRuntimeParams } from './service-context';
46
+ import { ServiceRegistry } from './service-registry';
47
+
47
48
  export type ClientServicesHostParams = {
48
49
  /**
49
50
  * Can be omitted if `initialize` is later called.
@@ -81,8 +82,9 @@ export class ClientServicesHost {
81
82
  private readonly _loggingService: LoggingServiceImpl;
82
83
  private readonly _tracingService = TRACE_PROCESSOR.createTraceSender();
83
84
 
84
- private _config?: Config;
85
85
  private readonly _statusUpdate = new Event<void>();
86
+
87
+ private _config?: Config;
86
88
  private _signalManager?: SignalManager;
87
89
  private _networkManager?: SwarmNetworkManager;
88
90
  private _storage?: Storage;
@@ -219,10 +221,10 @@ export class ClientServicesHost {
219
221
  log.warn('running signaling without telemetry metadata.');
220
222
  }
221
223
 
222
- const edgeEndpoint = config?.get('runtime.services.edge.url');
223
- if (edgeEndpoint) {
224
- this._edgeConnection = new EdgeClient(createStubEdgeIdentity(), { socketEndpoint: edgeEndpoint });
225
- this._edgeHttpClient = new EdgeHttpClient(edgeEndpoint);
224
+ const endpoint = config?.get('runtime.services.edge.url');
225
+ if (endpoint) {
226
+ this._edgeConnection = new EdgeClient(createStubEdgeIdentity(), { socketEndpoint: endpoint });
227
+ this._edgeHttpClient = new EdgeHttpClient(endpoint);
226
228
  }
227
229
 
228
230
  const {
@@ -13,10 +13,11 @@ import { schema } from '@dxos/protocols/proto';
13
13
  import { type SystemService, SystemStatus } from '@dxos/protocols/proto/dxos/client/services';
14
14
  import { createLinkedPorts, createProtoRpcPeer, createServiceBundle } from '@dxos/rpc';
15
15
 
16
- import { ServiceRegistry } from './service-registry';
17
16
  import { SystemServiceImpl } from '../system';
18
17
  import { createServiceContext } from '../testing';
19
18
 
19
+ import { ServiceRegistry } from './service-registry';
20
+
20
21
  // TODO(burdon): Create TestService (that doesn't require peers).
21
22
 
22
23
  type TestServices = {
@@ -4,10 +4,10 @@
4
4
 
5
5
  import type * as tar from '@obsidize/tar-browserify';
6
6
 
7
- import { Resource, type Context } from '@dxos/context';
7
+ import { type Context, Resource } from '@dxos/context';
8
8
  import { assertArgument, assertState } from '@dxos/invariant';
9
9
  import type { IdentityDid, SpaceId } from '@dxos/keys';
10
- import { SpaceArchiveFileStructure, SpaceArchiveVersion, type SpaceArchiveMetadata } from '@dxos/protocols';
10
+ import { SpaceArchiveFileStructure, type SpaceArchiveMetadata, SpaceArchiveVersion } from '@dxos/protocols';
11
11
  import type { SpaceArchive } from '@dxos/protocols/proto/dxos/client/services';
12
12
 
13
13
  export type SpaceArchiveBeginProps = {
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import { Archive } from '@obsidize/tar-browserify';
6
- import { describe, it, expect } from 'vitest';
6
+ import { describe, expect, it } from 'vitest';
7
7
 
8
8
  describe('tar', () => {
9
9
  it('should create a tar archive', async () => {
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import { Event } from '@dxos/async';
6
- import { Resource, type Context } from '@dxos/context';
6
+ import { type Context, Resource } from '@dxos/context';
7
7
  import { type CredentialProcessor, type SpecificCredential, checkCredentialType } from '@dxos/credentials';
8
8
  import { type Credential, type Epoch } from '@dxos/protocols/proto/dxos/halo/credentials';
9
9
 
@@ -3,43 +3,43 @@
3
3
  //
4
4
 
5
5
  import { type Doc } from '@automerge/automerge';
6
- import { interpretAsDocumentId, type AutomergeUrl, type DocHandle, type DocumentId } from '@automerge/automerge-repo';
6
+ import { type AutomergeUrl, type DocHandle, type DocumentId, interpretAsDocumentId } from '@automerge/automerge-repo';
7
7
 
8
8
  import { Event, synchronized, trackLeaks } from '@dxos/async';
9
9
  import { PropertiesType, TYPE_PROPERTIES } from '@dxos/client-protocol';
10
10
  import { Context, LifecycleState, Resource, cancelWithContext } from '@dxos/context';
11
11
  import {
12
- createAdmissionCredentials,
13
- getCredentialAssertion,
14
12
  type CredentialSigner,
15
13
  type DelegateInvitationCredential,
16
14
  type MemberInfo,
15
+ createAdmissionCredentials,
16
+ getCredentialAssertion,
17
17
  } from '@dxos/credentials';
18
18
  import {
19
+ AuthStatus,
20
+ CredentialServerExtension,
19
21
  DatabaseRoot,
20
- findInlineObjectOfType,
21
22
  type EchoEdgeReplicator,
22
23
  type EchoHost,
23
- AuthStatus,
24
- CredentialServerExtension,
24
+ FIND_PARAMS,
25
25
  type MeshEchoReplicator,
26
26
  type MetadataStore,
27
27
  type Space,
28
28
  type SpaceManager,
29
29
  type SpaceProtocol,
30
30
  type SpaceProtocolSession,
31
- FIND_PARAMS,
31
+ findInlineObjectOfType,
32
32
  } from '@dxos/echo-pipeline';
33
33
  import {
34
+ type DatabaseDirectory,
35
+ type ObjectStructure,
34
36
  SpaceDocVersion,
35
37
  createIdFromSpaceKey,
36
38
  encodeReference,
37
- type ObjectStructure,
38
- type DatabaseDirectory,
39
39
  } from '@dxos/echo-protocol';
40
40
  import { ObjectId, getTypeReference } from '@dxos/echo-schema';
41
41
  import type { EdgeConnection, EdgeHttpClient } from '@dxos/edge-client';
42
- import { writeMessages, type FeedStore } from '@dxos/feed-store';
42
+ import { type FeedStore, writeMessages } from '@dxos/feed-store';
43
43
  import { assertArgument, assertState, failedInvariant, invariant } from '@dxos/invariant';
44
44
  import { type Keyring } from '@dxos/keyring';
45
45
  import { PublicKey, type SpaceId } from '@dxos/keys';
@@ -48,21 +48,22 @@ import { AlreadyJoinedError, trace as Trace } from '@dxos/protocols';
48
48
  import { Invitation, SpaceState } from '@dxos/protocols/proto/dxos/client/services';
49
49
  import { type Runtime } from '@dxos/protocols/proto/dxos/config';
50
50
  import { type FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';
51
- import { type SpaceMetadata, EdgeReplicationSetting } from '@dxos/protocols/proto/dxos/echo/metadata';
52
- import { SpaceMember, type Credential, type ProfileDocument } from '@dxos/protocols/proto/dxos/halo/credentials';
51
+ import { EdgeReplicationSetting, type SpaceMetadata } from '@dxos/protocols/proto/dxos/echo/metadata';
52
+ import { type Credential, type ProfileDocument, SpaceMember } from '@dxos/protocols/proto/dxos/halo/credentials';
53
53
  import { type DelegateSpaceInvitation } from '@dxos/protocols/proto/dxos/halo/invitations';
54
54
  import { type PeerState } from '@dxos/protocols/proto/dxos/mesh/presence';
55
55
  import { type Teleport } from '@dxos/teleport';
56
56
  import { Gossip, Presence } from '@dxos/teleport-extension-gossip';
57
57
  import { type Timeframe } from '@dxos/timeframe';
58
58
  import { trace } from '@dxos/tracing';
59
- import { ComplexMap, setDeep, deferFunction, forEachAsync } from '@dxos/util';
59
+ import { ComplexMap, deferFunction, forEachAsync, setDeep } from '@dxos/util';
60
60
 
61
- import { DataSpace } from './data-space';
62
- import { spaceGenesis } from './genesis';
63
61
  import { createAuthProvider } from '../identity';
64
62
  import { type InvitationsManager } from '../invitations';
65
63
 
64
+ import { DataSpace } from './data-space';
65
+ import { spaceGenesis } from './genesis';
66
+
66
67
  const PRESENCE_ANNOUNCE_INTERVAL = 10_000;
67
68
  const PRESENCE_OFFLINE_TIMEOUT = 20_000;
68
69
 
@@ -11,14 +11,14 @@ import { Context, ContextDisposedError, cancelWithContext } from '@dxos/context'
11
11
  import type { SpecificCredential } from '@dxos/credentials';
12
12
  import { timed, warnAfterTimeout } from '@dxos/debug';
13
13
  import {
14
- type EchoHost,
15
14
  type DatabaseRoot,
16
- createMappedFeedWriter,
15
+ type EchoHost,
16
+ FIND_PARAMS,
17
17
  type MetadataStore,
18
18
  type Space,
19
- FIND_PARAMS,
19
+ createMappedFeedWriter,
20
20
  } from '@dxos/echo-pipeline';
21
- import { SpaceDocVersion, type DatabaseDirectory } from '@dxos/echo-protocol';
21
+ import { type DatabaseDirectory, SpaceDocVersion } from '@dxos/echo-protocol';
22
22
  import type { EdgeConnection, EdgeHttpClient } from '@dxos/edge-client';
23
23
  import { type FeedStore, type FeedWrapper } from '@dxos/feed-store';
24
24
  import { failedInvariant, invariant } from '@dxos/invariant';
@@ -28,31 +28,32 @@ import { log } from '@dxos/log';
28
28
  import { CancelledError, SystemError } from '@dxos/protocols';
29
29
  import {
30
30
  type CreateEpochRequest,
31
- SpaceState,
32
31
  type Space as SpaceProto,
32
+ SpaceState,
33
33
  } from '@dxos/protocols/proto/dxos/client/services';
34
34
  import { type Runtime } from '@dxos/protocols/proto/dxos/config';
35
35
  import { type FeedMessage } from '@dxos/protocols/proto/dxos/echo/feed';
36
36
  import { type SpaceCache } from '@dxos/protocols/proto/dxos/echo/metadata';
37
37
  import {
38
38
  AdmittedFeed,
39
- SpaceMember,
40
39
  type Credential,
41
40
  type Epoch,
42
41
  type ProfileDocument,
42
+ SpaceMember,
43
43
  } from '@dxos/protocols/proto/dxos/halo/credentials';
44
44
  import { type GossipMessage } from '@dxos/protocols/proto/dxos/mesh/teleport/gossip';
45
45
  import { type Gossip, type Presence } from '@dxos/teleport-extension-gossip';
46
46
  import { Timeframe } from '@dxos/timeframe';
47
47
  import { trace } from '@dxos/tracing';
48
- import { CallbackCollection, ComplexSet, type AsyncCallback } from '@dxos/util';
48
+ import { type AsyncCallback, CallbackCollection, ComplexSet } from '@dxos/util';
49
+
50
+ import { TrustedKeySetAuthVerifier } from '../identity';
49
51
 
50
52
  import { AutomergeSpaceState } from './automerge-space-state';
51
53
  import { type SigningContext } from './data-space-manager';
52
54
  import { EdgeFeedReplicator } from './edge-feed-replicator';
53
55
  import { runEpochMigration } from './epoch-migrations';
54
56
  import { NotarizationPlugin } from './notarization-plugin';
55
- import { TrustedKeySetAuthVerifier } from '../identity';
56
57
 
57
58
  export type DataSpaceCallbacks = {
58
59
  /**
@@ -6,10 +6,10 @@ import { decode as decodeCbor, encode as encodeCbor } from 'cbor-x';
6
6
  import { getPort } from 'get-port-please';
7
7
  import { describe, expect, onTestFinished, test, vi } from 'vitest';
8
8
 
9
- import { sleep, Trigger } from '@dxos/async';
9
+ import { Trigger, sleep } from '@dxos/async';
10
10
  import { Context } from '@dxos/context';
11
11
  import { valueEncoding } from '@dxos/echo-pipeline';
12
- import { createEphemeralEdgeIdentity, EdgeClient, EdgeIdentityChangedError } from '@dxos/edge-client';
12
+ import { EdgeClient, EdgeIdentityChangedError, createEphemeralEdgeIdentity } from '@dxos/edge-client';
13
13
  import { createTestEdgeWsServer } from '@dxos/edge-client/testing';
14
14
  import { FeedFactory, FeedStore, type FeedWrapper } from '@dxos/feed-store';
15
15
  import { Keyring } from '@dxos/keyring';
@@ -15,8 +15,8 @@ import { log, logInfo } from '@dxos/log';
15
15
  import { EdgeService } from '@dxos/protocols';
16
16
  import { buf } from '@dxos/protocols/buf';
17
17
  import {
18
- MessageSchema as RouterMessageSchema,
19
18
  type Message as RouterMessage,
19
+ MessageSchema as RouterMessageSchema,
20
20
  } from '@dxos/protocols/buf/dxos/edge/messenger_pb';
21
21
  import type { FeedBlock, ProtocolMessage } from '@dxos/protocols/feed-replication';
22
22
  import { EdgeStatus } from '@dxos/protocols/proto/dxos/client/services';
@@ -2,7 +2,7 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { onTestFinished, describe, expect, test } from 'vitest';
5
+ import { describe, expect, onTestFinished, test } from 'vitest';
6
6
 
7
7
  import { Context } from '@dxos/context';
8
8
  import { CredentialGenerator } from '@dxos/credentials';