@fluidframework/local-driver 2.0.0-dev-rc.1.0.0.228517 → 2.0.0-dev-rc.2.0.0.245554

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 (113) hide show
  1. package/{.eslintrc.js → .eslintrc.cjs} +5 -5
  2. package/{.mocharc.js → .mocharc.cjs} +1 -1
  3. package/CHANGELOG.md +20 -0
  4. package/{api-extractor-esm.json → api-extractor-cjs.json} +5 -1
  5. package/api-extractor-lint.json +1 -1
  6. package/api-extractor.json +1 -1
  7. package/api-report/local-driver.api.md +7 -3
  8. package/dist/index.d.ts +7 -7
  9. package/dist/index.d.ts.map +1 -1
  10. package/dist/index.js +16 -16
  11. package/dist/index.js.map +1 -1
  12. package/dist/local-driver-alpha.d.ts +4 -2
  13. package/dist/local-driver-beta.d.ts +10 -0
  14. package/dist/local-driver-public.d.ts +10 -0
  15. package/dist/local-driver-untrimmed.d.ts +31 -4
  16. package/dist/localDocumentService.d.ts +4 -3
  17. package/dist/localDocumentService.d.ts.map +1 -1
  18. package/dist/localDocumentService.js +10 -8
  19. package/dist/localDocumentService.js.map +1 -1
  20. package/dist/localDocumentServiceFactory.d.ts +0 -1
  21. package/dist/localDocumentServiceFactory.d.ts.map +1 -1
  22. package/dist/localDocumentServiceFactory.js +6 -8
  23. package/dist/localDocumentServiceFactory.js.map +1 -1
  24. package/dist/localDocumentStorageService.d.ts +27 -2
  25. package/dist/localDocumentStorageService.d.ts.map +1 -1
  26. package/dist/localDocumentStorageService.js +130 -3
  27. package/dist/localDocumentStorageService.js.map +1 -1
  28. package/dist/localResolver.d.ts +0 -1
  29. package/dist/localResolver.d.ts.map +1 -1
  30. package/dist/localResolver.js +4 -6
  31. package/dist/localResolver.js.map +1 -1
  32. package/dist/localSessionStorageDb.js +2 -2
  33. package/dist/localSessionStorageDb.js.map +1 -1
  34. package/dist/package.json +3 -0
  35. package/dist/tsdoc-metadata.json +1 -1
  36. package/lib/{auth.d.mts → auth.d.ts} +1 -1
  37. package/lib/auth.d.ts.map +1 -0
  38. package/lib/{auth.mjs → auth.js} +1 -1
  39. package/lib/auth.js.map +1 -0
  40. package/lib/{index.mjs → index.d.ts} +8 -8
  41. package/lib/index.d.ts.map +1 -0
  42. package/lib/{index.d.mts → index.js} +8 -8
  43. package/lib/index.js.map +1 -0
  44. package/lib/{local-driver-alpha.d.mts → local-driver-alpha.d.ts} +4 -2
  45. package/lib/{local-driver-beta.d.mts → local-driver-beta.d.ts} +10 -0
  46. package/lib/{local-driver-public.d.mts → local-driver-public.d.ts} +10 -0
  47. package/lib/{local-driver-untrimmed.d.mts → local-driver-untrimmed.d.ts} +31 -4
  48. package/lib/{localCreateDocument.d.mts → localCreateDocument.d.ts} +1 -1
  49. package/lib/localCreateDocument.d.ts.map +1 -0
  50. package/lib/{localCreateDocument.mjs → localCreateDocument.js} +1 -1
  51. package/lib/localCreateDocument.js.map +1 -0
  52. package/lib/{localDeltaStorageService.d.mts → localDeltaStorageService.d.ts} +1 -1
  53. package/lib/localDeltaStorageService.d.ts.map +1 -0
  54. package/lib/{localDeltaStorageService.mjs → localDeltaStorageService.js} +1 -1
  55. package/lib/localDeltaStorageService.js.map +1 -0
  56. package/lib/{localDocumentDeltaConnection.d.mts → localDocumentDeltaConnection.d.ts} +1 -1
  57. package/lib/localDocumentDeltaConnection.d.ts.map +1 -0
  58. package/lib/{localDocumentDeltaConnection.mjs → localDocumentDeltaConnection.js} +1 -1
  59. package/lib/localDocumentDeltaConnection.js.map +1 -0
  60. package/lib/{localDocumentService.d.mts → localDocumentService.d.ts} +5 -4
  61. package/lib/localDocumentService.d.ts.map +1 -0
  62. package/lib/{localDocumentService.mjs → localDocumentService.js} +8 -6
  63. package/lib/localDocumentService.js.map +1 -0
  64. package/lib/{localDocumentServiceFactory.d.mts → localDocumentServiceFactory.d.ts} +1 -2
  65. package/lib/localDocumentServiceFactory.d.ts.map +1 -0
  66. package/lib/{localDocumentServiceFactory.mjs → localDocumentServiceFactory.js} +5 -7
  67. package/lib/localDocumentServiceFactory.js.map +1 -0
  68. package/lib/{localDocumentStorageService.d.mts → localDocumentStorageService.d.ts} +28 -3
  69. package/lib/localDocumentStorageService.d.ts.map +1 -0
  70. package/lib/localDocumentStorageService.js +211 -0
  71. package/lib/localDocumentStorageService.js.map +1 -0
  72. package/lib/{localResolver.d.mts → localResolver.d.ts} +1 -2
  73. package/lib/localResolver.d.ts.map +1 -0
  74. package/lib/{localResolver.mjs → localResolver.js} +4 -6
  75. package/lib/localResolver.js.map +1 -0
  76. package/lib/{localSessionStorageDb.d.mts → localSessionStorageDb.d.ts} +1 -1
  77. package/lib/localSessionStorageDb.d.ts.map +1 -0
  78. package/lib/{localSessionStorageDb.mjs → localSessionStorageDb.js} +6 -2
  79. package/lib/localSessionStorageDb.js.map +1 -0
  80. package/lib/test/localResolverTest.spec.js +47 -0
  81. package/lib/test/localResolverTest.spec.js.map +1 -0
  82. package/lib/test/types/validateLocalDriverPrevious.generated.js +26 -0
  83. package/lib/test/types/validateLocalDriverPrevious.generated.js.map +1 -0
  84. package/package.json +56 -57
  85. package/src/index.ts +7 -7
  86. package/src/localDocumentService.ts +13 -6
  87. package/src/localDocumentServiceFactory.ts +5 -7
  88. package/src/localDocumentStorageService.ts +180 -4
  89. package/src/localResolver.ts +3 -5
  90. package/src/localSessionStorageDb.ts +1 -1
  91. package/tsconfig.cjs.json +7 -0
  92. package/tsconfig.json +2 -5
  93. package/lib/auth.d.mts.map +0 -1
  94. package/lib/auth.mjs.map +0 -1
  95. package/lib/index.d.mts.map +0 -1
  96. package/lib/index.mjs.map +0 -1
  97. package/lib/localCreateDocument.d.mts.map +0 -1
  98. package/lib/localCreateDocument.mjs.map +0 -1
  99. package/lib/localDeltaStorageService.d.mts.map +0 -1
  100. package/lib/localDeltaStorageService.mjs.map +0 -1
  101. package/lib/localDocumentDeltaConnection.d.mts.map +0 -1
  102. package/lib/localDocumentDeltaConnection.mjs.map +0 -1
  103. package/lib/localDocumentService.d.mts.map +0 -1
  104. package/lib/localDocumentService.mjs.map +0 -1
  105. package/lib/localDocumentServiceFactory.d.mts.map +0 -1
  106. package/lib/localDocumentServiceFactory.mjs.map +0 -1
  107. package/lib/localDocumentStorageService.d.mts.map +0 -1
  108. package/lib/localDocumentStorageService.mjs +0 -84
  109. package/lib/localDocumentStorageService.mjs.map +0 -1
  110. package/lib/localResolver.d.mts.map +0 -1
  111. package/lib/localResolver.mjs.map +0 -1
  112. package/lib/localSessionStorageDb.d.mts.map +0 -1
  113. package/lib/localSessionStorageDb.mjs.map +0 -1
@@ -2,11 +2,11 @@
2
2
  * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
3
  * Licensed under the MIT License.
4
4
  */
5
- export { LocalDeltaStorageService } from "./localDeltaStorageService.mjs";
6
- export { LocalDocumentDeltaConnection } from "./localDocumentDeltaConnection.mjs";
7
- export { createLocalDocumentService, LocalDocumentService } from "./localDocumentService.mjs";
8
- export { LocalDocumentServiceFactory } from "./localDocumentServiceFactory.mjs";
9
- export { LocalDocumentStorageService } from "./localDocumentStorageService.mjs";
10
- export { createLocalResolverCreateNewRequest, LocalResolver } from "./localResolver.mjs";
11
- export { LocalSessionStorageDbFactory } from "./localSessionStorageDb.mjs";
12
- //# sourceMappingURL=index.mjs.map
5
+ export { LocalDeltaStorageService } from "./localDeltaStorageService.js";
6
+ export { LocalDocumentDeltaConnection } from "./localDocumentDeltaConnection.js";
7
+ export { createLocalDocumentService, LocalDocumentService } from "./localDocumentService.js";
8
+ export { LocalDocumentServiceFactory } from "./localDocumentServiceFactory.js";
9
+ export { LocalDocumentStorageService } from "./localDocumentStorageService.js";
10
+ export { createLocalResolverCreateNewRequest, LocalResolver } from "./localResolver.js";
11
+ export { LocalSessionStorageDbFactory } from "./localSessionStorageDb.js";
12
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;AACjF,OAAO,EAAE,0BAA0B,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,EAAE,mCAAmC,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACxF,OAAO,EAAE,4BAA4B,EAAE,MAAM,4BAA4B,CAAC"}
@@ -2,11 +2,11 @@
2
2
  * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
3
  * Licensed under the MIT License.
4
4
  */
5
- export { LocalDeltaStorageService } from "./localDeltaStorageService.mjs";
6
- export { LocalDocumentDeltaConnection } from "./localDocumentDeltaConnection.mjs";
7
- export { createLocalDocumentService, LocalDocumentService } from "./localDocumentService.mjs";
8
- export { LocalDocumentServiceFactory } from "./localDocumentServiceFactory.mjs";
9
- export { LocalDocumentStorageService } from "./localDocumentStorageService.mjs";
10
- export { createLocalResolverCreateNewRequest, LocalResolver } from "./localResolver.mjs";
11
- export { LocalSessionStorageDbFactory } from "./localSessionStorageDb.mjs";
12
- //# sourceMappingURL=index.d.mts.map
5
+ export { LocalDeltaStorageService } from "./localDeltaStorageService.js";
6
+ export { LocalDocumentDeltaConnection } from "./localDocumentDeltaConnection.js";
7
+ export { createLocalDocumentService, LocalDocumentService } from "./localDocumentService.js";
8
+ export { LocalDocumentServiceFactory } from "./localDocumentServiceFactory.js";
9
+ export { LocalDocumentStorageService } from "./localDocumentStorageService.js";
10
+ export { createLocalResolverCreateNewRequest, LocalResolver } from "./localResolver.js";
11
+ export { LocalSessionStorageDbFactory } from "./localSessionStorageDb.js";
12
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;AACjF,OAAO,EAAE,0BAA0B,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,EAAE,mCAAmC,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACxF,OAAO,EAAE,4BAA4B,EAAE,MAAM,4BAA4B,CAAC","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nexport { LocalDeltaStorageService } from \"./localDeltaStorageService.js\";\nexport { LocalDocumentDeltaConnection } from \"./localDocumentDeltaConnection.js\";\nexport { createLocalDocumentService, LocalDocumentService } from \"./localDocumentService.js\";\nexport { LocalDocumentServiceFactory } from \"./localDocumentServiceFactory.js\";\nexport { LocalDocumentStorageService } from \"./localDocumentStorageService.js\";\nexport { createLocalResolverCreateNewRequest, LocalResolver } from \"./localResolver.js\";\nexport { LocalSessionStorageDbFactory } from \"./localSessionStorageDb.js\";\n"]}
@@ -8,6 +8,7 @@ import { IDocumentDeltaConnection } from '@fluidframework/driver-definitions';
8
8
  import { IDocumentDeltaStorageService } from '@fluidframework/driver-definitions';
9
9
  import { IDocumentMessage } from '@fluidframework/protocol-definitions';
10
10
  import { IDocumentService } from '@fluidframework/driver-definitions';
11
+ import { IDocumentServiceEvents } from '@fluidframework/driver-definitions';
11
12
  import { IDocumentServiceFactory } from '@fluidframework/driver-definitions';
12
13
  import { IDocumentServicePolicies } from '@fluidframework/driver-definitions';
13
14
  import { IDocumentStorageService } from '@fluidframework/driver-definitions';
@@ -16,6 +17,8 @@ import { ILocalDeltaConnectionServer } from '@fluidframework/server-local-server
16
17
  import { IRequest } from '@fluidframework/core-interfaces';
17
18
  import { IResolvedUrl } from '@fluidframework/driver-definitions';
18
19
  import { ISequencedDocumentMessage } from '@fluidframework/protocol-definitions';
20
+ import { ISnapshot } from '@fluidframework/driver-definitions';
21
+ import { ISnapshotFetchOptions } from '@fluidframework/driver-definitions';
19
22
  import { ISnapshotTreeEx } from '@fluidframework/protocol-definitions';
20
23
  import { IStream } from '@fluidframework/driver-definitions';
21
24
  import { ISummaryContext } from '@fluidframework/driver-definitions';
@@ -29,6 +32,7 @@ import { IVersion } from '@fluidframework/protocol-definitions';
29
32
  import { IWebSocketServer } from '@fluidframework/server-services-core';
30
33
  import { NackErrorType } from '@fluidframework/protocol-definitions';
31
34
  import type { Socket } from 'socket.io-client';
35
+ import { TypedEventEmitter } from '@fluid-internal/client-utils';
32
36
 
33
37
  /* Excluded from this release type: createLocalDocumentService */
34
38
 
@@ -56,7 +60,6 @@ export declare class LocalDocumentServiceFactory implements IDocumentServiceFact
56
60
  private readonly documentDeltaConnectionsMap;
57
61
  /**
58
62
  * @param localDeltaConnectionServer - delta connection server for ops
59
- * @alpha
60
63
  */
61
64
  constructor(localDeltaConnectionServer: ILocalDeltaConnectionServer, policies?: IDocumentServicePolicies | undefined, innerDocumentService?: IDocumentService | undefined);
62
65
  createContainer(createNewSummary: ISummaryTree | undefined, resolvedUrl: IResolvedUrl, logger?: ITelemetryBaseLogger, clientIsSummarizer?: boolean): Promise<IDocumentService>;
@@ -98,7 +101,6 @@ export declare class LocalResolver implements IUrlResolver {
98
101
  * token from constant test strings. The root of the URL is fake, but the
99
102
  * remaining relative URL can still be parsed.
100
103
  * @param request - request to handle
101
- * @alpha
102
104
  */
103
105
  resolve(request: IRequest): Promise<IResolvedUrl>;
104
106
  getAbsoluteUrl(resolvedUrl: IResolvedUrl, relativeUrl: string): Promise<string>;
@@ -8,6 +8,7 @@ import { IDocumentDeltaConnection } from '@fluidframework/driver-definitions';
8
8
  import { IDocumentDeltaStorageService } from '@fluidframework/driver-definitions';
9
9
  import { IDocumentMessage } from '@fluidframework/protocol-definitions';
10
10
  import { IDocumentService } from '@fluidframework/driver-definitions';
11
+ import { IDocumentServiceEvents } from '@fluidframework/driver-definitions';
11
12
  import { IDocumentServiceFactory } from '@fluidframework/driver-definitions';
12
13
  import { IDocumentServicePolicies } from '@fluidframework/driver-definitions';
13
14
  import { IDocumentStorageService } from '@fluidframework/driver-definitions';
@@ -16,6 +17,8 @@ import { ILocalDeltaConnectionServer } from '@fluidframework/server-local-server
16
17
  import { IRequest } from '@fluidframework/core-interfaces';
17
18
  import { IResolvedUrl } from '@fluidframework/driver-definitions';
18
19
  import { ISequencedDocumentMessage } from '@fluidframework/protocol-definitions';
20
+ import { ISnapshot } from '@fluidframework/driver-definitions';
21
+ import { ISnapshotFetchOptions } from '@fluidframework/driver-definitions';
19
22
  import { ISnapshotTreeEx } from '@fluidframework/protocol-definitions';
20
23
  import { IStream } from '@fluidframework/driver-definitions';
21
24
  import { ISummaryContext } from '@fluidframework/driver-definitions';
@@ -29,6 +32,7 @@ import { IVersion } from '@fluidframework/protocol-definitions';
29
32
  import { IWebSocketServer } from '@fluidframework/server-services-core';
30
33
  import { NackErrorType } from '@fluidframework/protocol-definitions';
31
34
  import type { Socket } from 'socket.io-client';
35
+ import { TypedEventEmitter } from '@fluid-internal/client-utils';
32
36
 
33
37
  /* Excluded from this release type: createLocalDocumentService */
34
38
 
@@ -42,6 +46,8 @@ import type { Socket } from 'socket.io-client';
42
46
 
43
47
  /* Excluded from this release type: IDocumentService */
44
48
 
49
+ /* Excluded from this release type: IDocumentServiceEvents */
50
+
45
51
  /* Excluded from this release type: IDocumentServiceFactory */
46
52
 
47
53
  /* Excluded from this release type: IDocumentServicePolicies */
@@ -52,6 +58,10 @@ import type { Socket } from 'socket.io-client';
52
58
 
53
59
  /* Excluded from this release type: IResolvedUrl */
54
60
 
61
+ /* Excluded from this release type: ISnapshot */
62
+
63
+ /* Excluded from this release type: ISnapshotFetchOptions */
64
+
55
65
  /* Excluded from this release type: IStream */
56
66
 
57
67
  /* Excluded from this release type: ISummaryContext */
@@ -8,6 +8,7 @@ import { IDocumentDeltaConnection } from '@fluidframework/driver-definitions';
8
8
  import { IDocumentDeltaStorageService } from '@fluidframework/driver-definitions';
9
9
  import { IDocumentMessage } from '@fluidframework/protocol-definitions';
10
10
  import { IDocumentService } from '@fluidframework/driver-definitions';
11
+ import { IDocumentServiceEvents } from '@fluidframework/driver-definitions';
11
12
  import { IDocumentServiceFactory } from '@fluidframework/driver-definitions';
12
13
  import { IDocumentServicePolicies } from '@fluidframework/driver-definitions';
13
14
  import { IDocumentStorageService } from '@fluidframework/driver-definitions';
@@ -16,6 +17,8 @@ import { ILocalDeltaConnectionServer } from '@fluidframework/server-local-server
16
17
  import { IRequest } from '@fluidframework/core-interfaces';
17
18
  import { IResolvedUrl } from '@fluidframework/driver-definitions';
18
19
  import { ISequencedDocumentMessage } from '@fluidframework/protocol-definitions';
20
+ import { ISnapshot } from '@fluidframework/driver-definitions';
21
+ import { ISnapshotFetchOptions } from '@fluidframework/driver-definitions';
19
22
  import { ISnapshotTreeEx } from '@fluidframework/protocol-definitions';
20
23
  import { IStream } from '@fluidframework/driver-definitions';
21
24
  import { ISummaryContext } from '@fluidframework/driver-definitions';
@@ -29,6 +32,7 @@ import { IVersion } from '@fluidframework/protocol-definitions';
29
32
  import { IWebSocketServer } from '@fluidframework/server-services-core';
30
33
  import { NackErrorType } from '@fluidframework/protocol-definitions';
31
34
  import type { Socket } from 'socket.io-client';
35
+ import { TypedEventEmitter } from '@fluid-internal/client-utils';
32
36
 
33
37
  /* Excluded from this release type: createLocalDocumentService */
34
38
 
@@ -42,6 +46,8 @@ import type { Socket } from 'socket.io-client';
42
46
 
43
47
  /* Excluded from this release type: IDocumentService */
44
48
 
49
+ /* Excluded from this release type: IDocumentServiceEvents */
50
+
45
51
  /* Excluded from this release type: IDocumentServiceFactory */
46
52
 
47
53
  /* Excluded from this release type: IDocumentServicePolicies */
@@ -52,6 +58,10 @@ import type { Socket } from 'socket.io-client';
52
58
 
53
59
  /* Excluded from this release type: IResolvedUrl */
54
60
 
61
+ /* Excluded from this release type: ISnapshot */
62
+
63
+ /* Excluded from this release type: ISnapshotFetchOptions */
64
+
55
65
  /* Excluded from this release type: IStream */
56
66
 
57
67
  /* Excluded from this release type: ISummaryContext */
@@ -8,6 +8,7 @@ import { IDocumentDeltaConnection } from '@fluidframework/driver-definitions';
8
8
  import { IDocumentDeltaStorageService } from '@fluidframework/driver-definitions';
9
9
  import { IDocumentMessage } from '@fluidframework/protocol-definitions';
10
10
  import { IDocumentService } from '@fluidframework/driver-definitions';
11
+ import { IDocumentServiceEvents } from '@fluidframework/driver-definitions';
11
12
  import { IDocumentServiceFactory } from '@fluidframework/driver-definitions';
12
13
  import { IDocumentServicePolicies } from '@fluidframework/driver-definitions';
13
14
  import { IDocumentStorageService } from '@fluidframework/driver-definitions';
@@ -16,6 +17,8 @@ import { ILocalDeltaConnectionServer } from '@fluidframework/server-local-server
16
17
  import { IRequest } from '@fluidframework/core-interfaces';
17
18
  import { IResolvedUrl } from '@fluidframework/driver-definitions';
18
19
  import { ISequencedDocumentMessage } from '@fluidframework/protocol-definitions';
20
+ import { ISnapshot } from '@fluidframework/driver-definitions';
21
+ import { ISnapshotFetchOptions } from '@fluidframework/driver-definitions';
19
22
  import { ISnapshotTreeEx } from '@fluidframework/protocol-definitions';
20
23
  import { IStream } from '@fluidframework/driver-definitions';
21
24
  import { ISummaryContext } from '@fluidframework/driver-definitions';
@@ -29,6 +32,7 @@ import { IVersion } from '@fluidframework/protocol-definitions';
29
32
  import { IWebSocketServer } from '@fluidframework/server-services-core';
30
33
  import { NackErrorType } from '@fluidframework/protocol-definitions';
31
34
  import type { Socket } from 'socket.io-client';
35
+ import { TypedEventEmitter } from '@fluid-internal/client-utils';
32
36
 
33
37
  /**
34
38
  * Creates and returns a document service for local use.
@@ -101,7 +105,7 @@ export declare class LocalDocumentDeltaConnection extends DocumentDeltaConnectio
101
105
  * Basic implementation of a document service for local use.
102
106
  * @internal
103
107
  */
104
- export declare class LocalDocumentService implements IDocumentService {
108
+ export declare class LocalDocumentService extends TypedEventEmitter<IDocumentServiceEvents> implements IDocumentService {
105
109
  readonly resolvedUrl: IResolvedUrl;
106
110
  private readonly localDeltaConnectionServer;
107
111
  private readonly tokenProvider;
@@ -145,7 +149,6 @@ export declare class LocalDocumentServiceFactory implements IDocumentServiceFact
145
149
  private readonly documentDeltaConnectionsMap;
146
150
  /**
147
151
  * @param localDeltaConnectionServer - delta connection server for ops
148
- * @alpha
149
152
  */
150
153
  constructor(localDeltaConnectionServer: ILocalDeltaConnectionServer, policies?: IDocumentServicePolicies | undefined, innerDocumentService?: IDocumentService | undefined);
151
154
  createContainer(createNewSummary: ISummaryTree | undefined, resolvedUrl: IResolvedUrl, logger?: ITelemetryBaseLogger, clientIsSummarizer?: boolean): Promise<IDocumentService>;
@@ -182,10 +185,35 @@ export declare class LocalDocumentStorageService implements IDocumentStorageServ
182
185
  private readonly resolvedUrl?;
183
186
  protected readonly blobsShaCache: Map<string, string>;
184
187
  private readonly summaryTreeUploadManager;
185
- readonly repositoryUrl: string;
186
188
  constructor(id: string, manager: GitManager, policies: IDocumentStorageServicePolicies, localDeltaConnectionServer?: ILocalDeltaConnectionServer | undefined, resolvedUrl?: IResolvedUrl | undefined);
187
189
  getVersions(versionId: string | null, count: number): Promise<IVersion[]>;
188
190
  getSnapshotTree(version?: IVersion): Promise<ISnapshotTreeEx | null>;
191
+ getSnapshot(snapshotFetchOptions?: ISnapshotFetchOptions): Promise<ISnapshot>;
192
+ /**
193
+ * Strips the tree or any subtree of data if it has a groupId.
194
+ *
195
+ * @param tree - The tree to strip of loading groupIds
196
+ * @returns a tree that has trees with groupIds that are empty
197
+ */
198
+ private stripTreeOfLoadingGroupIds;
199
+ /**
200
+ * Named differently as the algorithm is a little more involved.
201
+ *
202
+ * We want to strip the tree if it has a groupId that is not in the loadingGroupIds or if it doesn't have a descendent or ancestor
203
+ * that has a groupId that is in the loadingGroupIds.
204
+ *
205
+ * We keep the tree in the opposite case.
206
+ *
207
+ * @param tree - the tree to strip of any data that is not in the loadingGroupIds
208
+ * @param loadingGroupIds - the set of groupIds that are being loaded
209
+ * @param ancestorGroupIdInLoadingGroup - whether the ancestor of the tree has a groupId that is in the loadingGroupIds
210
+ * @returns whether or not it or descendant has a groupId that is in the loadingGroupIds
211
+ */
212
+ private filterTreeByLoadingGroupIds;
213
+ private populateBlobContents;
214
+ private populateGroupId;
215
+ private stripTree;
216
+ private readGroupId;
189
217
  readBlob(blobId: string): Promise<ArrayBufferLike>;
190
218
  uploadSummaryWithContext(summary: ISummaryTree, context: ISummaryContext): Promise<string>;
191
219
  createBlob(file: ArrayBufferLike): Promise<ICreateBlobResponse>;
@@ -207,7 +235,6 @@ export declare class LocalResolver implements IUrlResolver {
207
235
  * token from constant test strings. The root of the URL is fake, but the
208
236
  * remaining relative URL can still be parsed.
209
237
  * @param request - request to handle
210
- * @alpha
211
238
  */
212
239
  resolve(request: IRequest): Promise<IResolvedUrl>;
213
240
  getAbsoluteUrl(resolvedUrl: IResolvedUrl, relativeUrl: string): Promise<string>;
@@ -5,4 +5,4 @@
5
5
  import { IResolvedUrl } from "@fluidframework/driver-definitions";
6
6
  import { ISummaryTree } from "@fluidframework/protocol-definitions";
7
7
  export declare function createDocument(localDeltaConnectionServer: any, resolvedUrl: IResolvedUrl, summary: ISummaryTree): Promise<void>;
8
- //# sourceMappingURL=localCreateDocument.d.mts.map
8
+ //# sourceMappingURL=localCreateDocument.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localCreateDocument.d.ts","sourceRoot":"","sources":["../src/localCreateDocument.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAMlE,OAAO,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAIpE,wBAAsB,cAAc,CACnC,0BAA0B,KAAA,EAC1B,WAAW,EAAE,YAAY,EACzB,OAAO,EAAE,YAAY,iBA6BrB"}
@@ -21,4 +21,4 @@ export async function createDocument(localDeltaConnectionServer, resolvedUrl, su
21
21
  const sequenceNumber = documentAttributes.sequenceNumber;
22
22
  await documentStorage.createDocument(tenantId, id, appSummary, sequenceNumber, defaultHash, resolvedUrl.endpoints.ordererUrl ?? "", resolvedUrl.endpoints.storageUrl ?? "", resolvedUrl.endpoints.deltaStorageUrl ?? "", quorumValues, false /* enableDiscovery */, false /* isEphemeralContainer */);
23
23
  }
24
- //# sourceMappingURL=localCreateDocument.mjs.map
24
+ //# sourceMappingURL=localCreateDocument.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localCreateDocument.js","sourceRoot":"","sources":["../src/localCreateDocument.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EACN,mCAAmC,EACnC,kCAAkC,EAClC,+BAA+B,GAC/B,MAAM,8BAA8B,CAAC;AAGtC,OAAO,EAAE,WAAW,EAAE,MAAM,wCAAwC,CAAC;AAErE,MAAM,CAAC,KAAK,UAAU,cAAc,CACnC,0BAA0B,EAC1B,WAAyB,EACzB,OAAqB;IAErB,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC;IACnD,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACpC,MAAM,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAC7C,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACvC,MAAM,eAAe,GAAI,0BAAyD;SAChF,eAAe,CAAC;IAClB,IAAI,CAAC,+BAA+B,CAAC,OAAO,CAAC,EAAE;QAC9C,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;KACzE;IACD,MAAM,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAClD,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACxC,MAAM,kBAAkB,GAAG,mCAAmC,CAAC,eAAe,CAAC,CAAC;IAChF,MAAM,YAAY,GAAG,kCAAkC,CAAC,eAAe,CAAC,CAAC;IACzE,MAAM,cAAc,GAAG,kBAAkB,CAAC,cAAc,CAAC;IACzD,MAAM,eAAe,CAAC,cAAc,CACnC,QAAQ,EACR,EAAE,EACF,UAAU,EACV,cAAc,EACd,WAAW,EACX,WAAW,CAAC,SAAS,CAAC,UAAU,IAAI,EAAE,EACtC,WAAW,CAAC,SAAS,CAAC,UAAU,IAAI,EAAE,EACtC,WAAW,CAAC,SAAS,CAAC,eAAe,IAAI,EAAE,EAC3C,YAAY,EACZ,KAAK,CAAC,qBAAqB,EAC3B,KAAK,CAAC,0BAA0B,CAChC,CAAC;AACH,CAAC","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { IResolvedUrl } from \"@fluidframework/driver-definitions\";\nimport {\n\tgetDocAttributesFromProtocolSummary,\n\tgetQuorumValuesFromProtocolSummary,\n\tisCombinedAppAndProtocolSummary,\n} from \"@fluidframework/driver-utils\";\nimport { ISummaryTree } from \"@fluidframework/protocol-definitions\";\nimport { LocalDeltaConnectionServer } from \"@fluidframework/server-local-server\";\nimport { defaultHash } from \"@fluidframework/server-services-client\";\n\nexport async function createDocument(\n\tlocalDeltaConnectionServer,\n\tresolvedUrl: IResolvedUrl,\n\tsummary: ISummaryTree,\n) {\n\tconst pathName = new URL(resolvedUrl.url).pathname;\n\tconst pathArr = pathName.split(\"/\");\n\tconst tenantId = pathArr[pathArr.length - 2];\n\tconst id = pathArr[pathArr.length - 1];\n\tconst documentStorage = (localDeltaConnectionServer as LocalDeltaConnectionServer)\n\t\t.documentStorage;\n\tif (!isCombinedAppAndProtocolSummary(summary)) {\n\t\tthrow new Error(\"Protocol and App Summary required in the full summary\");\n\t}\n\tconst protocolSummary = summary.tree[\".protocol\"];\n\tconst appSummary = summary.tree[\".app\"];\n\tconst documentAttributes = getDocAttributesFromProtocolSummary(protocolSummary);\n\tconst quorumValues = getQuorumValuesFromProtocolSummary(protocolSummary);\n\tconst sequenceNumber = documentAttributes.sequenceNumber;\n\tawait documentStorage.createDocument(\n\t\ttenantId,\n\t\tid,\n\t\tappSummary,\n\t\tsequenceNumber,\n\t\tdefaultHash,\n\t\tresolvedUrl.endpoints.ordererUrl ?? \"\",\n\t\tresolvedUrl.endpoints.storageUrl ?? \"\",\n\t\tresolvedUrl.endpoints.deltaStorageUrl ?? \"\",\n\t\tquorumValues,\n\t\tfalse /* enableDiscovery */,\n\t\tfalse /* isEphemeralContainer */,\n\t);\n}\n"]}
@@ -17,4 +17,4 @@ export declare class LocalDeltaStorageService implements IDocumentDeltaStorageSe
17
17
  fetchMessages(from: number, to: number | undefined, abortSignal?: AbortSignal, cachedOnly?: boolean): IStream<ISequencedDocumentMessage[]>;
18
18
  private getCore;
19
19
  }
20
- //# sourceMappingURL=localDeltaStorageService.d.mts.map
20
+ //# sourceMappingURL=localDeltaStorageService.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDeltaStorageService.d.ts","sourceRoot":"","sources":["../src/localDeltaStorageService.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,4BAA4B,EAAE,OAAO,EAAE,MAAM,oCAAoC,CAAC;AAC3F,OAAO,EAAE,yBAAyB,EAAE,MAAM,sCAAsC,CAAC;AACjF,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AAGxE;;;GAGG;AACH,qBAAa,wBAAyB,YAAW,4BAA4B;IAE3E,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,EAAE;IACnB,OAAO,CAAC,QAAQ,CAAC,eAAe;gBAFf,QAAQ,EAAE,MAAM,EAChB,EAAE,EAAE,MAAM,EACV,eAAe,EAAE,gBAAgB;IAG5C,aAAa,CACnB,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,MAAM,GAAG,SAAS,EACtB,WAAW,CAAC,EAAE,WAAW,EACzB,UAAU,CAAC,EAAE,OAAO,GAClB,OAAO,CAAC,yBAAyB,EAAE,CAAC;YAIzB,OAAO;CAcrB"}
@@ -29,4 +29,4 @@ export class LocalDeltaStorageService {
29
29
  return messages;
30
30
  }
31
31
  }
32
- //# sourceMappingURL=localDeltaStorageService.mjs.map
32
+ //# sourceMappingURL=localDeltaStorageService.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDeltaStorageService.js","sourceRoot":"","sources":["../src/localDeltaStorageService.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAKH,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAElE;;;GAGG;AACH,MAAM,OAAO,wBAAwB;IACpC,YACkB,QAAgB,EAChB,EAAU,EACV,eAAiC;QAFjC,aAAQ,GAAR,QAAQ,CAAQ;QAChB,OAAE,GAAF,EAAE,CAAQ;QACV,oBAAe,GAAf,eAAe,CAAkB;IAChD,CAAC;IAEG,aAAa,CACnB,IAAY,EACZ,EAAsB,EACtB,WAAyB,EACzB,UAAoB;QAEpB,OAAO,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;IACnD,CAAC;IAEO,KAAK,CAAC,OAAO,CAAC,IAAY,EAAE,EAAW;QAC9C,MAAM,KAAK,GAAG,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC/D,KAAK,CAAC,0BAA0B,CAAC,GAAG,EAAE,CAAC;QACvC,KAAK,CAAC,0BAA0B,CAAC,CAAC,GAAG,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,oBAAoB;QAEtE,kFAAkF;QAClF,iBAAiB;QACjB,KAAK,CAAC,0BAA0B,CAAC,CAAC,GAAG,GAAG,EAAE,IAAI,MAAM,CAAC,gBAAgB,CAAC;QAEtE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;QACxF,MAAM,QAAQ,GAAG,MAAM,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,0BAA0B,EAAE,CAAC,EAAE,CAAC,CAAC;QAChF,MAAM,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC1D,OAAO,QAAQ,CAAC;IACjB,CAAC;CACD","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { IDocumentDeltaStorageService, IStream } from \"@fluidframework/driver-definitions\";\nimport { ISequencedDocumentMessage } from \"@fluidframework/protocol-definitions\";\nimport { IDatabaseManager } from \"@fluidframework/server-services-core\";\nimport { streamFromMessages } from \"@fluidframework/driver-utils\";\n\n/**\n * Provides access to the underlying delta storage on the server for local driver.\n * @internal\n */\nexport class LocalDeltaStorageService implements IDocumentDeltaStorageService {\n\tconstructor(\n\t\tprivate readonly tenantId: string,\n\t\tprivate readonly id: string,\n\t\tprivate readonly databaseManager: IDatabaseManager,\n\t) {}\n\n\tpublic fetchMessages(\n\t\tfrom: number,\n\t\tto: number | undefined,\n\t\tabortSignal?: AbortSignal,\n\t\tcachedOnly?: boolean,\n\t): IStream<ISequencedDocumentMessage[]> {\n\t\treturn streamFromMessages(this.getCore(from, to));\n\t}\n\n\tprivate async getCore(from: number, to?: number) {\n\t\tconst query = { documentId: this.id, tenantId: this.tenantId };\n\t\tquery[\"operation.sequenceNumber\"] = {};\n\t\tquery[\"operation.sequenceNumber\"].$gt = from - 1; // from is inclusive\n\n\t\t// This looks like a bug. It used to work without setting $lt key. Now it does not\n\t\t// Need follow up\n\t\tquery[\"operation.sequenceNumber\"].$lt = to ?? Number.MAX_SAFE_INTEGER;\n\n\t\tconst allDeltas = await this.databaseManager.getDeltaCollection(this.tenantId, this.id);\n\t\tconst dbDeltas = await allDeltas.find(query, { \"operation.sequenceNumber\": 1 });\n\t\tconst messages = dbDeltas.map((delta) => delta.operation);\n\t\treturn messages;\n\t}\n}\n"]}
@@ -45,4 +45,4 @@ export declare class LocalDocumentDeltaConnection extends DocumentDeltaConnectio
45
45
  */
46
46
  nackClient(code: number | undefined, type: NackErrorType | undefined, message: any): void;
47
47
  }
48
- //# sourceMappingURL=localDocumentDeltaConnection.d.mts.map
48
+ //# sourceMappingURL=localDocumentDeltaConnection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDocumentDeltaConnection.d.ts","sourceRoot":"","sources":["../src/localDocumentDeltaConnection.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EACN,OAAO,EAEP,gBAAgB,EAChB,aAAa,EACb,MAAM,sCAAsC,CAAC;AAG9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAC;AACxE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAIvE;;;GAGG;AACH,qBAAa,4BAA6B,SAAQ,uBAAuB;IACxE;;;;;;;;;OASG;WACiB,MAAM,CACzB,QAAQ,EAAE,MAAM,EAChB,EAAE,EAAE,MAAM,EACV,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,OAAO,EACf,eAAe,EAAE,gBAAgB,EACjC,SAAS,SAAQ,EACjB,MAAM,CAAC,EAAE,oBAAoB,GAC3B,OAAO,CAAC,4BAA4B,CAAC;gBAqB5B,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,oBAAoB;IAI7E;;OAEG;IACI,MAAM,CAAC,QAAQ,EAAE,gBAAgB,EAAE,GAAG,IAAI;IAQjD;;OAEG;IACI,YAAY,CAAC,OAAO,EAAE,GAAG,GAAG,IAAI;IAIvC;;;OAGG;IACI,gBAAgB,CAAC,gBAAgB,EAAE,MAAM;IAIhD;;;;;OAKG;IACI,UAAU,CAChB,IAAI,oBAAc,EAClB,IAAI,2BAA+C,EACnD,OAAO,EAAE,GAAG;CAab"}
@@ -83,4 +83,4 @@ export class LocalDocumentDeltaConnection extends DocumentDeltaConnection {
83
83
  this.socket.emit("nack", "", [nackMessage]);
84
84
  }
85
85
  }
86
- //# sourceMappingURL=localDocumentDeltaConnection.mjs.map
86
+ //# sourceMappingURL=localDocumentDeltaConnection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDocumentDeltaConnection.js","sourceRoot":"","sources":["../src/localDocumentDeltaConnection.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EAIN,aAAa,GACb,MAAM,sCAAsC,CAAC;AAC9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AAMpE,MAAM,oBAAoB,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;AAE5D;;;GAGG;AACH,MAAM,OAAO,4BAA6B,SAAQ,uBAAuB;IACxE;;;;;;;;;OASG;IACI,MAAM,CAAC,KAAK,CAAC,MAAM,CACzB,QAAgB,EAChB,EAAU,EACV,KAAa,EACb,MAAe,EACf,eAAiC,EACjC,SAAS,GAAG,KAAK,EACjB,MAA6B;QAE7B,MAAM,MAAM,GAAI,eAAwC,CAAC,gBAAgB,EAAE,CAAC;QAE5E,4GAA4G;QAC5G,0EAA0E;QAC1E,MAAM,kBAAkB,GAAG,MAA2B,CAAC;QAEvD,MAAM,eAAe,GAAG,IAAI,4BAA4B,CAAC,kBAAkB,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;QAEzF,MAAM,cAAc,GAAa;YAChC,MAAM;YACN,EAAE;YACF,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,QAAQ;YACR,KAAK;YACL,QAAQ,EAAE,oBAAoB;SAC9B,CAAC;QACF,MAAM,eAAe,CAAC,UAAU,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;QAC5D,OAAO,eAAe,CAAC;IACxB,CAAC;IAED,YAAY,MAAc,EAAE,UAAkB,EAAE,MAA6B;QAC5E,KAAK,CAAC,MAAM,EAAE,UAAU,EAAE,iBAAiB,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,QAA4B;QACzC,kFAAkF;QAClF,mEAAmE;QACnE,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YAC3B,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,OAAY;QAC/B,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC;IAED;;;OAGG;IACI,gBAAgB,CAAC,gBAAwB;QAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;IAClD,CAAC;IAED;;;;;OAKG;IACI,UAAU,CAChB,OAAe,GAAG,EAClB,OAAsB,aAAa,CAAC,eAAe,EACnD,OAAY;QAEZ,MAAM,WAAW,GAAG;YACnB,SAAS,EAAE,SAAS;YACpB,cAAc,EAAE,CAAC,CAAC;YAClB,OAAO,EAAE;gBACR,IAAI;gBACJ,IAAI;gBACJ,OAAO;aACP;SACD,CAAC;QACF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;IAC7C,CAAC;CACD","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { DocumentDeltaConnection } from \"@fluidframework/driver-base\";\nimport {\n\tIClient,\n\tIConnect,\n\tIDocumentMessage,\n\tNackErrorType,\n} from \"@fluidframework/protocol-definitions\";\nimport { createChildLogger } from \"@fluidframework/telemetry-utils\";\nimport { LocalWebSocketServer } from \"@fluidframework/server-local-server\";\nimport { IWebSocketServer } from \"@fluidframework/server-services-core\";\nimport type { Socket } from \"socket.io-client\";\nimport { ITelemetryBaseLogger } from \"@fluidframework/core-interfaces\";\n\nconst testProtocolVersions = [\"^0.3.0\", \"^0.2.0\", \"^0.1.0\"];\n\n/**\n * Represents a connection to a stream of delta updates\n * @internal\n */\nexport class LocalDocumentDeltaConnection extends DocumentDeltaConnection {\n\t/**\n\t * Create a LocalDocumentDeltaConnection\n\t * Handle initial messages, contents or signals if they were in queue\n\t *\n\t * @param tenantId - the ID of the tenant\n\t * @param id - document ID\n\t * @param token - authorization token for storage service\n\t * @param client - information about the client\n\t * @param webSocketServer - web socket server to create connection\n\t */\n\tpublic static async create(\n\t\ttenantId: string,\n\t\tid: string,\n\t\ttoken: string,\n\t\tclient: IClient,\n\t\twebSocketServer: IWebSocketServer,\n\t\ttimeoutMs = 60000,\n\t\tlogger?: ITelemetryBaseLogger,\n\t): Promise<LocalDocumentDeltaConnection> {\n\t\tconst socket = (webSocketServer as LocalWebSocketServer).createConnection();\n\n\t\t// Cast LocalWebSocket to SocketIOClient.Socket which is the socket that the base class needs. This is hacky\n\t\t// but should be fine because this delta connection is for local use only.\n\t\tconst socketWithListener = socket as unknown as Socket;\n\n\t\tconst deltaConnection = new LocalDocumentDeltaConnection(socketWithListener, id, logger);\n\n\t\tconst connectMessage: IConnect = {\n\t\t\tclient,\n\t\t\tid,\n\t\t\tmode: client.mode,\n\t\t\ttenantId,\n\t\t\ttoken, // Token is going to indicate tenant level information, etc...\n\t\t\tversions: testProtocolVersions,\n\t\t};\n\t\tawait deltaConnection.initialize(connectMessage, timeoutMs);\n\t\treturn deltaConnection;\n\t}\n\n\tconstructor(socket: Socket, documentId: string, logger?: ITelemetryBaseLogger) {\n\t\tsuper(socket, documentId, createChildLogger({ logger }));\n\t}\n\n\t/**\n\t * Submits a new delta operation to the server\n\t */\n\tpublic submit(messages: IDocumentMessage[]): void {\n\t\t// We use a promise resolve to force a turn break given message processing is sync\n\t\t// eslint-disable-next-line @typescript-eslint/no-floating-promises\n\t\tPromise.resolve().then(() => {\n\t\t\tthis.emitMessages(\"submitOp\", [messages]);\n\t\t});\n\t}\n\n\t/**\n\t * Submits a new signal to the server\n\t */\n\tpublic submitSignal(message: any): void {\n\t\tthis.emitMessages(\"submitSignal\", [[message]]);\n\t}\n\n\t/**\n\t * Send a \"disconnect\" message on the socket.\n\t * @param disconnectReason - The reason of the disconnection.\n\t */\n\tpublic disconnectClient(disconnectReason: string) {\n\t\tthis.socket.emit(\"disconnect\", disconnectReason);\n\t}\n\n\t/**\n\t * * Sends a \"nack\" message on the socket.\n\t * @param code - An error code number that represents the error. It will be a valid HTTP error code.\n\t * @param type - Type of the Nack.\n\t * @param message - A message about the nack for debugging/logging/telemetry purposes.\n\t */\n\tpublic nackClient(\n\t\tcode: number = 400,\n\t\ttype: NackErrorType = NackErrorType.ThrottlingError,\n\t\tmessage: any,\n\t) {\n\t\tconst nackMessage = {\n\t\t\toperation: undefined,\n\t\t\tsequenceNumber: -1,\n\t\t\tcontent: {\n\t\t\t\tcode,\n\t\t\t\ttype,\n\t\t\t\tmessage,\n\t\t\t},\n\t\t};\n\t\tthis.socket.emit(\"nack\", \"\", [nackMessage]);\n\t}\n}\n"]}
@@ -2,17 +2,18 @@
2
2
  * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
3
  * Licensed under the MIT License.
4
4
  */
5
- import { IDocumentDeltaConnection, IDocumentDeltaStorageService, IDocumentService, IDocumentServicePolicies, IDocumentStorageService, IResolvedUrl } from "@fluidframework/driver-definitions";
5
+ import { TypedEventEmitter } from "@fluid-internal/client-utils";
6
+ import { IDocumentDeltaConnection, IDocumentDeltaStorageService, IDocumentService, IDocumentServiceEvents, IDocumentServicePolicies, IDocumentStorageService, IResolvedUrl } from "@fluidframework/driver-definitions";
6
7
  import { IClient } from "@fluidframework/protocol-definitions";
7
8
  import { ITokenProvider } from "@fluidframework/routerlicious-driver";
8
9
  import { ILocalDeltaConnectionServer } from "@fluidframework/server-local-server";
9
10
  import { ITelemetryBaseLogger } from "@fluidframework/core-interfaces";
10
- import { LocalDocumentDeltaConnection } from "./localDocumentDeltaConnection.mjs";
11
+ import { LocalDocumentDeltaConnection } from "./localDocumentDeltaConnection.js";
11
12
  /**
12
13
  * Basic implementation of a document service for local use.
13
14
  * @internal
14
15
  */
15
- export declare class LocalDocumentService implements IDocumentService {
16
+ export declare class LocalDocumentService extends TypedEventEmitter<IDocumentServiceEvents> implements IDocumentService {
16
17
  readonly resolvedUrl: IResolvedUrl;
17
18
  private readonly localDeltaConnectionServer;
18
19
  private readonly tokenProvider;
@@ -53,4 +54,4 @@ export declare class LocalDocumentService implements IDocumentService {
53
54
  * @internal
54
55
  */
55
56
  export declare function createLocalDocumentService(resolvedUrl: IResolvedUrl, localDeltaConnectionServer: ILocalDeltaConnectionServer, tokenProvider: ITokenProvider, tenantId: string, documentId: string, documentDeltaConnectionsMap: Map<string, LocalDocumentDeltaConnection>, policies?: IDocumentServicePolicies, innerDocumentService?: IDocumentService, logger?: ITelemetryBaseLogger): IDocumentService;
56
- //# sourceMappingURL=localDocumentService.d.mts.map
57
+ //# sourceMappingURL=localDocumentService.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDocumentService.d.ts","sourceRoot":"","sources":["../src/localDocumentService.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EACN,wBAAwB,EACxB,4BAA4B,EAC5B,gBAAgB,EAChB,sBAAsB,EACtB,wBAAwB,EACxB,uBAAuB,EACvB,YAAY,EACZ,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,sCAAsC,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,sCAAsC,CAAC;AAGtE,OAAO,EAAE,2BAA2B,EAAE,MAAM,qCAAqC,CAAC;AAClF,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAEvE,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;AAGjF;;;GAGG;AACH,qBAAa,oBACZ,SAAQ,iBAAiB,CAAC,sBAAsB,CAChD,YAAW,gBAAgB;aASV,WAAW,EAAE,YAAY;IACzC,OAAO,CAAC,QAAQ,CAAC,0BAA0B;IAC3C,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,2BAA2B;aAC5B,QAAQ,EAAE,wBAAwB;IAClD,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;IAfzB;;;;;OAKG;gBAEc,WAAW,EAAE,YAAY,EACxB,0BAA0B,EAAE,2BAA2B,EACvD,aAAa,EAAE,cAAc,EAC7B,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,2BAA2B,EAAE,GAAG,CAAC,MAAM,EAAE,4BAA4B,CAAC,EACvE,QAAQ,GAAE,wBAA0D,EACnE,oBAAoB,CAAC,8BAAkB,EACvC,MAAM,CAAC,kCAAsB;IAKxC,OAAO;IAEd;;OAEG;IACU,gBAAgB,IAAI,OAAO,CAAC,uBAAuB,CAAC;IAcjE;;OAEG;IACU,qBAAqB,IAAI,OAAO,CAAC,4BAA4B,CAAC;IAW3E;;;OAGG;IACU,oBAAoB,CAAC,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,wBAAwB,CAAC;CAgCrF;AAED;;;;;;;GAOG;AACH,wBAAgB,0BAA0B,CACzC,WAAW,EAAE,YAAY,EACzB,0BAA0B,EAAE,2BAA2B,EACvD,aAAa,EAAE,cAAc,EAC7B,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,2BAA2B,EAAE,GAAG,CAAC,MAAM,EAAE,4BAA4B,CAAC,EACtE,QAAQ,CAAC,EAAE,wBAAwB,EACnC,oBAAoB,CAAC,EAAE,gBAAgB,EACvC,MAAM,CAAC,EAAE,oBAAoB,GAC3B,gBAAgB,CAYlB"}
@@ -2,23 +2,25 @@
2
2
  * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
3
  * Licensed under the MIT License.
4
4
  */
5
+ import { TypedEventEmitter } from "@fluid-internal/client-utils";
5
6
  import { GitManager } from "@fluidframework/server-services-client";
6
7
  import { TestHistorian } from "@fluidframework/server-test-utils";
7
- import { LocalDocumentStorageService } from "./localDocumentStorageService.mjs";
8
- import { LocalDocumentDeltaConnection } from "./localDocumentDeltaConnection.mjs";
9
- import { LocalDeltaStorageService } from "./localDeltaStorageService.mjs";
8
+ import { LocalDocumentStorageService } from "./localDocumentStorageService.js";
9
+ import { LocalDocumentDeltaConnection } from "./localDocumentDeltaConnection.js";
10
+ import { LocalDeltaStorageService } from "./localDeltaStorageService.js";
10
11
  /**
11
12
  * Basic implementation of a document service for local use.
12
13
  * @internal
13
14
  */
14
- export class LocalDocumentService {
15
+ export class LocalDocumentService extends TypedEventEmitter {
15
16
  /**
16
17
  * @param localDeltaConnectionServer - delta connection server for ops
17
18
  * @param tokenProvider - token provider
18
19
  * @param tenantId - ID of tenant
19
20
  * @param documentId - ID of document
20
21
  */
21
- constructor(resolvedUrl, localDeltaConnectionServer, tokenProvider, tenantId, documentId, documentDeltaConnectionsMap, policies = {}, innerDocumentService, logger) {
22
+ constructor(resolvedUrl, localDeltaConnectionServer, tokenProvider, tenantId, documentId, documentDeltaConnectionsMap, policies = { supportGetSnapshotApi: true }, innerDocumentService, logger) {
23
+ super();
22
24
  this.resolvedUrl = resolvedUrl;
23
25
  this.localDeltaConnectionServer = localDeltaConnectionServer;
24
26
  this.tokenProvider = tokenProvider;
@@ -81,4 +83,4 @@ export class LocalDocumentService {
81
83
  export function createLocalDocumentService(resolvedUrl, localDeltaConnectionServer, tokenProvider, tenantId, documentId, documentDeltaConnectionsMap, policies, innerDocumentService, logger) {
82
84
  return new LocalDocumentService(resolvedUrl, localDeltaConnectionServer, tokenProvider, tenantId, documentId, documentDeltaConnectionsMap, policies, innerDocumentService, logger);
83
85
  }
84
- //# sourceMappingURL=localDocumentService.mjs.map
86
+ //# sourceMappingURL=localDocumentService.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDocumentService.js","sourceRoot":"","sources":["../src/localDocumentService.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAYjE,OAAO,EAAE,UAAU,EAAE,MAAM,wCAAwC,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAGlE,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;AACjF,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAEzE;;;GAGG;AACH,MAAM,OAAO,oBACZ,SAAQ,iBAAyC;IAGjD;;;;;OAKG;IACH,YACiB,WAAyB,EACxB,0BAAuD,EACvD,aAA6B,EAC7B,QAAgB,EAChB,UAAkB,EAClB,2BAAsE,EACvE,WAAqC,EAAE,qBAAqB,EAAE,IAAI,EAAE,EACnE,oBAAuC,EACvC,MAA6B;QAE9C,KAAK,EAAE,CAAC;QAVQ,gBAAW,GAAX,WAAW,CAAc;QACxB,+BAA0B,GAA1B,0BAA0B,CAA6B;QACvD,kBAAa,GAAb,aAAa,CAAgB;QAC7B,aAAQ,GAAR,QAAQ,CAAQ;QAChB,eAAU,GAAV,UAAU,CAAQ;QAClB,gCAA2B,GAA3B,2BAA2B,CAA2C;QACvE,aAAQ,GAAR,QAAQ,CAA4D;QACnE,yBAAoB,GAApB,oBAAoB,CAAmB;QACvC,WAAM,GAAN,MAAM,CAAuB;IAG/C,CAAC;IAEM,OAAO,KAAI,CAAC;IAEnB;;OAEG;IACI,KAAK,CAAC,gBAAgB;QAC5B,OAAO,IAAI,2BAA2B,CACrC,IAAI,CAAC,UAAU,EACf,IAAI,UAAU,CACb,IAAI,aAAa,CAAC,IAAI,CAAC,0BAA0B,CAAC,aAAa,CAAC,YAAY,CAAC,CAC7E,EACD;YACC,sBAAsB,EAAE,SAAW,EAAE,yFAAyF;SAC9H,EACD,IAAI,CAAC,0BAA0B,EAC/B,IAAI,CAAC,WAAW,CAChB,CAAC;IACH,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,qBAAqB;QACjC,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC9B,OAAO,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,EAAE,CAAC;SACzD;QACD,OAAO,IAAI,wBAAwB,CAClC,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,0BAA0B,CAAC,eAAe,CAC/C,CAAC;IACH,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,oBAAoB,CAAC,MAAe;QAChD,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,KAAK,IAAI,EAAE;YACvC,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;SACtE;QACD,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC9B,OAAO,IAAI,CAAC,oBAAoB,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;SAC9D;QACD,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAC9D,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,UAAU,CACf,CAAC;QACF,MAAM,uBAAuB,GAAG,MAAM,4BAA4B,CAAC,MAAM,CACxE,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,UAAU,EACf,YAAY,CAAC,GAAG,EAChB,MAAM,EACN,IAAI,CAAC,0BAA0B,CAAC,eAAe,EAC/C,SAAS,EACT,IAAI,CAAC,MAAM,CACX,CAAC;QACF,MAAM,QAAQ,GAAG,uBAAuB,CAAC,QAAQ,CAAC;QAElD,8EAA8E;QAC9E,IAAI,CAAC,2BAA2B,CAAC,GAAG,CAAC,QAAQ,EAAE,uBAAuB,CAAC,CAAC;QAExE,kFAAkF;QAClF,uBAAuB,CAAC,EAAE,CAAC,YAAY,EAAE,GAAG,EAAE;YAC7C,IAAI,CAAC,2BAA2B,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;QAEH,OAAO,uBAAuB,CAAC;IAChC,CAAC;CACD;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,0BAA0B,CACzC,WAAyB,EACzB,0BAAuD,EACvD,aAA6B,EAC7B,QAAgB,EAChB,UAAkB,EAClB,2BAAsE,EACtE,QAAmC,EACnC,oBAAuC,EACvC,MAA6B;IAE7B,OAAO,IAAI,oBAAoB,CAC9B,WAAW,EACX,0BAA0B,EAC1B,aAAa,EACb,QAAQ,EACR,UAAU,EACV,2BAA2B,EAC3B,QAAQ,EACR,oBAAoB,EACpB,MAAM,CACN,CAAC;AACH,CAAC","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { TypedEventEmitter } from \"@fluid-internal/client-utils\";\nimport {\n\tIDocumentDeltaConnection,\n\tIDocumentDeltaStorageService,\n\tIDocumentService,\n\tIDocumentServiceEvents,\n\tIDocumentServicePolicies,\n\tIDocumentStorageService,\n\tIResolvedUrl,\n} from \"@fluidframework/driver-definitions\";\nimport { IClient } from \"@fluidframework/protocol-definitions\";\nimport { ITokenProvider } from \"@fluidframework/routerlicious-driver\";\nimport { GitManager } from \"@fluidframework/server-services-client\";\nimport { TestHistorian } from \"@fluidframework/server-test-utils\";\nimport { ILocalDeltaConnectionServer } from \"@fluidframework/server-local-server\";\nimport { ITelemetryBaseLogger } from \"@fluidframework/core-interfaces\";\nimport { LocalDocumentStorageService } from \"./localDocumentStorageService.js\";\nimport { LocalDocumentDeltaConnection } from \"./localDocumentDeltaConnection.js\";\nimport { LocalDeltaStorageService } from \"./localDeltaStorageService.js\";\n\n/**\n * Basic implementation of a document service for local use.\n * @internal\n */\nexport class LocalDocumentService\n\textends TypedEventEmitter<IDocumentServiceEvents>\n\timplements IDocumentService\n{\n\t/**\n\t * @param localDeltaConnectionServer - delta connection server for ops\n\t * @param tokenProvider - token provider\n\t * @param tenantId - ID of tenant\n\t * @param documentId - ID of document\n\t */\n\tconstructor(\n\t\tpublic readonly resolvedUrl: IResolvedUrl,\n\t\tprivate readonly localDeltaConnectionServer: ILocalDeltaConnectionServer,\n\t\tprivate readonly tokenProvider: ITokenProvider,\n\t\tprivate readonly tenantId: string,\n\t\tprivate readonly documentId: string,\n\t\tprivate readonly documentDeltaConnectionsMap: Map<string, LocalDocumentDeltaConnection>,\n\t\tpublic readonly policies: IDocumentServicePolicies = { supportGetSnapshotApi: true },\n\t\tprivate readonly innerDocumentService?: IDocumentService,\n\t\tprivate readonly logger?: ITelemetryBaseLogger,\n\t) {\n\t\tsuper();\n\t}\n\n\tpublic dispose() {}\n\n\t/**\n\t * Creates and returns a document storage service for local use.\n\t */\n\tpublic async connectToStorage(): Promise<IDocumentStorageService> {\n\t\treturn new LocalDocumentStorageService(\n\t\t\tthis.documentId,\n\t\t\tnew GitManager(\n\t\t\t\tnew TestHistorian(this.localDeltaConnectionServer.testDbFactory.testDatabase),\n\t\t\t),\n\t\t\t{\n\t\t\t\tmaximumCacheDurationMs: 432_000_000, // 5 days in ms. Not actually enforced but shouldn't matter for any local driver scenario\n\t\t\t},\n\t\t\tthis.localDeltaConnectionServer,\n\t\t\tthis.resolvedUrl,\n\t\t);\n\t}\n\n\t/**\n\t * Creates and returns a delta storage service for local use.\n\t */\n\tpublic async connectToDeltaStorage(): Promise<IDocumentDeltaStorageService> {\n\t\tif (this.innerDocumentService) {\n\t\t\treturn this.innerDocumentService.connectToDeltaStorage();\n\t\t}\n\t\treturn new LocalDeltaStorageService(\n\t\t\tthis.tenantId,\n\t\t\tthis.documentId,\n\t\t\tthis.localDeltaConnectionServer.databaseManager,\n\t\t);\n\t}\n\n\t/**\n\t * Creates and returns a delta stream for local use.\n\t * @param client - client data\n\t */\n\tpublic async connectToDeltaStream(client: IClient): Promise<IDocumentDeltaConnection> {\n\t\tif (this.policies.storageOnly === true) {\n\t\t\tthrow new Error(\"can't connect to delta stream in storage-only mode\");\n\t\t}\n\t\tif (this.innerDocumentService) {\n\t\t\treturn this.innerDocumentService.connectToDeltaStream(client);\n\t\t}\n\t\tconst ordererToken = await this.tokenProvider.fetchOrdererToken(\n\t\t\tthis.tenantId,\n\t\t\tthis.documentId,\n\t\t);\n\t\tconst documentDeltaConnection = await LocalDocumentDeltaConnection.create(\n\t\t\tthis.tenantId,\n\t\t\tthis.documentId,\n\t\t\tordererToken.jwt,\n\t\t\tclient,\n\t\t\tthis.localDeltaConnectionServer.webSocketServer,\n\t\t\tundefined,\n\t\t\tthis.logger,\n\t\t);\n\t\tconst clientId = documentDeltaConnection.clientId;\n\n\t\t// Add this document service for the clientId in the document service factory.\n\t\tthis.documentDeltaConnectionsMap.set(clientId, documentDeltaConnection);\n\n\t\t// Add a listener to remove this document service when the client is disconnected.\n\t\tdocumentDeltaConnection.on(\"disconnect\", () => {\n\t\t\tthis.documentDeltaConnectionsMap.delete(clientId);\n\t\t});\n\n\t\treturn documentDeltaConnection;\n\t}\n}\n\n/**\n * Creates and returns a document service for local use.\n * @param localDeltaConnectionServer - delta connection server for ops\n * @param tokenProvider - token provider with a single token\n * @param tenantId - ID of tenant\n * @param documentId - ID of document\n * @internal\n */\nexport function createLocalDocumentService(\n\tresolvedUrl: IResolvedUrl,\n\tlocalDeltaConnectionServer: ILocalDeltaConnectionServer,\n\ttokenProvider: ITokenProvider,\n\ttenantId: string,\n\tdocumentId: string,\n\tdocumentDeltaConnectionsMap: Map<string, LocalDocumentDeltaConnection>,\n\tpolicies?: IDocumentServicePolicies,\n\tinnerDocumentService?: IDocumentService,\n\tlogger?: ITelemetryBaseLogger,\n): IDocumentService {\n\treturn new LocalDocumentService(\n\t\tresolvedUrl,\n\t\tlocalDeltaConnectionServer,\n\t\ttokenProvider,\n\t\ttenantId,\n\t\tdocumentId,\n\t\tdocumentDeltaConnectionsMap,\n\t\tpolicies,\n\t\tinnerDocumentService,\n\t\tlogger,\n\t);\n}\n"]}
@@ -17,7 +17,6 @@ export declare class LocalDocumentServiceFactory implements IDocumentServiceFact
17
17
  private readonly documentDeltaConnectionsMap;
18
18
  /**
19
19
  * @param localDeltaConnectionServer - delta connection server for ops
20
- * @alpha
21
20
  */
22
21
  constructor(localDeltaConnectionServer: ILocalDeltaConnectionServer, policies?: IDocumentServicePolicies | undefined, innerDocumentService?: IDocumentService | undefined);
23
22
  createContainer(createNewSummary: ISummaryTree | undefined, resolvedUrl: IResolvedUrl, logger?: ITelemetryBaseLogger, clientIsSummarizer?: boolean): Promise<IDocumentService>;
@@ -42,4 +41,4 @@ export declare class LocalDocumentServiceFactory implements IDocumentServiceFact
42
41
  */
43
42
  nackClient(clientId: string, code?: number, type?: NackErrorType, message?: any): void;
44
43
  }
45
- //# sourceMappingURL=localDocumentServiceFactory.d.mts.map
44
+ //# sourceMappingURL=localDocumentServiceFactory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDocumentServiceFactory.d.ts","sourceRoot":"","sources":["../src/localDocumentServiceFactory.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EACN,gBAAgB,EAChB,uBAAuB,EACvB,wBAAwB,EACxB,YAAY,EACZ,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAEvE,OAAO,EAAE,2BAA2B,EAAE,MAAM,qCAAqC,CAAC;AAClF,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAKnF;;;GAGG;AACH,qBAAa,2BAA4B,YAAW,uBAAuB;IASzE,OAAO,CAAC,QAAQ,CAAC,0BAA0B;IAC3C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAC1B,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC;IATvC,OAAO,CAAC,QAAQ,CAAC,2BAA2B,CACjC;IAEX;;OAEG;gBAEe,0BAA0B,EAAE,2BAA2B,EACvD,QAAQ,CAAC,sCAA0B,EACnC,oBAAoB,CAAC,8BAAkB;IAG5C,eAAe,CAC3B,gBAAgB,EAAE,YAAY,GAAG,SAAS,EAC1C,WAAW,EAAE,YAAY,EACzB,MAAM,CAAC,EAAE,oBAAoB,EAC7B,kBAAkB,CAAC,EAAE,OAAO,GAC1B,OAAO,CAAC,gBAAgB,CAAC;IAU5B;;;;OAIG;IACU,qBAAqB,CACjC,WAAW,EAAE,YAAY,EACzB,MAAM,CAAC,EAAE,oBAAoB,EAC7B,kBAAkB,CAAC,EAAE,OAAO,GAC1B,OAAO,CAAC,gBAAgB,CAAC;IA8B5B;;;;OAIG;IACI,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM;IAQlE;;;;;;OAMG;IACI,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,aAAa,EAAE,OAAO,CAAC,EAAE,GAAG;CAOtF"}
@@ -2,10 +2,9 @@
2
2
  * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
3
  * Licensed under the MIT License.
4
4
  */
5
- import { parse } from "url";
6
5
  import { DefaultTokenProvider } from "@fluidframework/routerlicious-driver";
7
- import { createLocalDocumentService } from "./localDocumentService.mjs";
8
- import { createDocument } from "./localCreateDocument.mjs";
6
+ import { createLocalDocumentService } from "./localDocumentService.js";
7
+ import { createDocument } from "./localCreateDocument.js";
9
8
  /**
10
9
  * Implementation of document service factory for local use.
11
10
  * @alpha
@@ -13,7 +12,6 @@ import { createDocument } from "./localCreateDocument.mjs";
13
12
  export class LocalDocumentServiceFactory {
14
13
  /**
15
14
  * @param localDeltaConnectionServer - delta connection server for ops
16
- * @alpha
17
15
  */
18
16
  constructor(localDeltaConnectionServer, policies, innerDocumentService) {
19
17
  this.localDeltaConnectionServer = localDeltaConnectionServer;
@@ -37,8 +35,8 @@ export class LocalDocumentServiceFactory {
37
35
  * @param resolvedUrl - resolved URL of document
38
36
  */
39
37
  async createDocumentService(resolvedUrl, logger, clientIsSummarizer) {
40
- const parsedUrl = parse(resolvedUrl.url);
41
- const [, tenantId, documentId] = parsedUrl.path ? parsedUrl.path.split("/") : [];
38
+ const parsedUrl = new URL(resolvedUrl.url);
39
+ const [, tenantId, documentId] = parsedUrl.pathname ? parsedUrl.pathname.split("/") : [];
42
40
  if (!documentId || !tenantId) {
43
41
  throw new Error(`Couldn't parse resolved url. [documentId:${documentId}][tenantId:${tenantId}]`);
44
42
  }
@@ -77,4 +75,4 @@ export class LocalDocumentServiceFactory {
77
75
  documentDeltaConnection.nackClient(code, type, message);
78
76
  }
79
77
  }
80
- //# sourceMappingURL=localDocumentServiceFactory.mjs.map
78
+ //# sourceMappingURL=localDocumentServiceFactory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDocumentServiceFactory.js","sourceRoot":"","sources":["../src/localDocumentServiceFactory.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport {\n\tIDocumentService,\n\tIDocumentServiceFactory,\n\tIDocumentServicePolicies,\n\tIResolvedUrl,\n} from \"@fluidframework/driver-definitions\";\nimport { ITelemetryBaseLogger } from \"@fluidframework/core-interfaces\";\nimport { DefaultTokenProvider } from \"@fluidframework/routerlicious-driver\";\nimport { ILocalDeltaConnectionServer } from \"@fluidframework/server-local-server\";\nimport { ISummaryTree, NackErrorType } from \"@fluidframework/protocol-definitions\";\nimport { LocalDocumentDeltaConnection } from \"./localDocumentDeltaConnection.js\";\nimport { createLocalDocumentService } from \"./localDocumentService.js\";\nimport { createDocument } from \"./localCreateDocument.js\";\n\n/**\n * Implementation of document service factory for local use.\n * @alpha\n */\nexport class LocalDocumentServiceFactory implements IDocumentServiceFactory {\n\t// A map of clientId to LocalDocumentService.\n\tprivate readonly documentDeltaConnectionsMap: Map<string, LocalDocumentDeltaConnection> =\n\t\tnew Map();\n\n\t/**\n\t * @param localDeltaConnectionServer - delta connection server for ops\n\t */\n\tconstructor(\n\t\tprivate readonly localDeltaConnectionServer: ILocalDeltaConnectionServer,\n\t\tprivate readonly policies?: IDocumentServicePolicies,\n\t\tprivate readonly innerDocumentService?: IDocumentService,\n\t) {}\n\n\tpublic async createContainer(\n\t\tcreateNewSummary: ISummaryTree | undefined,\n\t\tresolvedUrl: IResolvedUrl,\n\t\tlogger?: ITelemetryBaseLogger,\n\t\tclientIsSummarizer?: boolean,\n\t): Promise<IDocumentService> {\n\t\tif (!this.localDeltaConnectionServer) {\n\t\t\tthrow new Error(\"Provide the localDeltaConnectionServer!!\");\n\t\t}\n\t\tif (createNewSummary !== undefined) {\n\t\t\tawait createDocument(this.localDeltaConnectionServer, resolvedUrl, createNewSummary);\n\t\t}\n\t\treturn this.createDocumentService(resolvedUrl, logger, clientIsSummarizer);\n\t}\n\n\t/**\n\t * Creates and returns a document service for testing using the given resolved\n\t * URL for the tenant ID, document ID, and token.\n\t * @param resolvedUrl - resolved URL of document\n\t */\n\tpublic async createDocumentService(\n\t\tresolvedUrl: IResolvedUrl,\n\t\tlogger?: ITelemetryBaseLogger,\n\t\tclientIsSummarizer?: boolean,\n\t): Promise<IDocumentService> {\n\t\tconst parsedUrl = new URL(resolvedUrl.url);\n\t\tconst [, tenantId, documentId] = parsedUrl.pathname ? parsedUrl.pathname.split(\"/\") : [];\n\t\tif (!documentId || !tenantId) {\n\t\t\tthrow new Error(\n\t\t\t\t`Couldn't parse resolved url. [documentId:${documentId}][tenantId:${tenantId}]`,\n\t\t\t);\n\t\t}\n\n\t\tconst fluidResolvedUrl = resolvedUrl;\n\t\tconst jwtToken = fluidResolvedUrl.tokens.jwt;\n\t\tif (!jwtToken) {\n\t\t\tthrow new Error(`Token was not provided.`);\n\t\t}\n\n\t\tconst tokenProvider = new DefaultTokenProvider(jwtToken);\n\n\t\treturn createLocalDocumentService(\n\t\t\tresolvedUrl,\n\t\t\tthis.localDeltaConnectionServer,\n\t\t\ttokenProvider,\n\t\t\ttenantId,\n\t\t\tdocumentId,\n\t\t\tthis.documentDeltaConnectionsMap,\n\t\t\tthis.policies,\n\t\t\tthis.innerDocumentService,\n\t\t\tlogger,\n\t\t);\n\t}\n\n\t/**\n\t * Gets the document delta connection for the clientId and asks it to disconnect the client.\n\t * @param clientId - The ID of the client to be disconnected.\n\t * @param disconnectReason - The reason of the disconnection.\n\t */\n\tpublic disconnectClient(clientId: string, disconnectReason: string) {\n\t\tconst documentDeltaConnection = this.documentDeltaConnectionsMap.get(clientId);\n\t\tif (documentDeltaConnection === undefined) {\n\t\t\tthrow new Error(`No client with the id: ${clientId}`);\n\t\t}\n\t\tdocumentDeltaConnection.disconnectClient(disconnectReason);\n\t}\n\n\t/**\n\t * Gets the document delta connection for the clientId and asks it to nack the client.\n\t * @param clientId - The ID of the client to be Nack'd.\n\t * @param code - An error code number that represents the error. It will be a valid HTTP error code.\n\t * @param type - Type of the Nack.\n\t * @param message - A message about the nack for debugging/logging/telemetry purposes.\n\t */\n\tpublic nackClient(clientId: string, code?: number, type?: NackErrorType, message?: any) {\n\t\tconst documentDeltaConnection = this.documentDeltaConnectionsMap.get(clientId);\n\t\tif (documentDeltaConnection === undefined) {\n\t\t\tthrow new Error(`No client with the id: ${clientId}`);\n\t\t}\n\t\tdocumentDeltaConnection.nackClient(code, type, message);\n\t}\n}\n"]}
@@ -2,7 +2,7 @@
2
2
  * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
3
  * Licensed under the MIT License.
4
4
  */
5
- import { IDocumentStorageService, IDocumentStorageServicePolicies, IResolvedUrl, ISummaryContext } from "@fluidframework/driver-definitions";
5
+ import { IDocumentStorageService, IDocumentStorageServicePolicies, IResolvedUrl, ISummaryContext, type ISnapshotFetchOptions, type ISnapshot } from "@fluidframework/driver-definitions";
6
6
  import { ICreateBlobResponse, ISnapshotTreeEx, ISummaryHandle, ISummaryTree, IVersion } from "@fluidframework/protocol-definitions";
7
7
  import { GitManager } from "@fluidframework/server-services-client";
8
8
  import { ILocalDeltaConnectionServer } from "@fluidframework/server-local-server";
@@ -17,14 +17,39 @@ export declare class LocalDocumentStorageService implements IDocumentStorageServ
17
17
  private readonly resolvedUrl?;
18
18
  protected readonly blobsShaCache: Map<string, string>;
19
19
  private readonly summaryTreeUploadManager;
20
- readonly repositoryUrl: string;
21
20
  constructor(id: string, manager: GitManager, policies: IDocumentStorageServicePolicies, localDeltaConnectionServer?: ILocalDeltaConnectionServer | undefined, resolvedUrl?: IResolvedUrl | undefined);
22
21
  getVersions(versionId: string | null, count: number): Promise<IVersion[]>;
23
22
  getSnapshotTree(version?: IVersion): Promise<ISnapshotTreeEx | null>;
23
+ getSnapshot(snapshotFetchOptions?: ISnapshotFetchOptions): Promise<ISnapshot>;
24
+ /**
25
+ * Strips the tree or any subtree of data if it has a groupId.
26
+ *
27
+ * @param tree - The tree to strip of loading groupIds
28
+ * @returns a tree that has trees with groupIds that are empty
29
+ */
30
+ private stripTreeOfLoadingGroupIds;
31
+ /**
32
+ * Named differently as the algorithm is a little more involved.
33
+ *
34
+ * We want to strip the tree if it has a groupId that is not in the loadingGroupIds or if it doesn't have a descendent or ancestor
35
+ * that has a groupId that is in the loadingGroupIds.
36
+ *
37
+ * We keep the tree in the opposite case.
38
+ *
39
+ * @param tree - the tree to strip of any data that is not in the loadingGroupIds
40
+ * @param loadingGroupIds - the set of groupIds that are being loaded
41
+ * @param ancestorGroupIdInLoadingGroup - whether the ancestor of the tree has a groupId that is in the loadingGroupIds
42
+ * @returns whether or not it or descendant has a groupId that is in the loadingGroupIds
43
+ */
44
+ private filterTreeByLoadingGroupIds;
45
+ private populateBlobContents;
46
+ private populateGroupId;
47
+ private stripTree;
48
+ private readGroupId;
24
49
  readBlob(blobId: string): Promise<ArrayBufferLike>;
25
50
  uploadSummaryWithContext(summary: ISummaryTree, context: ISummaryContext): Promise<string>;
26
51
  createBlob(file: ArrayBufferLike): Promise<ICreateBlobResponse>;
27
52
  downloadSummary(handle: ISummaryHandle): Promise<ISummaryTree>;
28
53
  private getPreviousFullSnapshot;
29
54
  }
30
- //# sourceMappingURL=localDocumentStorageService.d.mts.map
55
+ //# sourceMappingURL=localDocumentStorageService.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"localDocumentStorageService.d.ts","sourceRoot":"","sources":["../src/localDocumentStorageService.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAQH,OAAO,EACN,uBAAuB,EACvB,+BAA+B,EAC/B,YAAY,EACZ,eAAe,EACf,KAAK,qBAAqB,EAC1B,KAAK,SAAS,EACd,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EACN,mBAAmB,EACnB,eAAe,EACf,cAAc,EACd,YAAY,EACZ,QAAQ,EACR,MAAM,sCAAsC,CAAC;AAE9C,OAAO,EACN,UAAU,EAGV,MAAM,wCAAwC,CAAC;AAChD,OAAO,EAAE,2BAA2B,EAAE,MAAM,qCAAqC,CAAC;AAKlF;;GAEG;AACH,qBAAa,2BAA4B,YAAW,uBAAuB;IAOzE,OAAO,CAAC,QAAQ,CAAC,EAAE;IACnB,OAAO,CAAC,QAAQ,CAAC,OAAO;aACR,QAAQ,EAAE,+BAA+B;IACzD,OAAO,CAAC,QAAQ,CAAC,0BAA0B,CAAC;IAC5C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC;IAR9B,SAAS,CAAC,QAAQ,CAAC,aAAa,sBAA6B;IAC7D,OAAO,CAAC,QAAQ,CAAC,wBAAwB,CAAwB;gBAG/C,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,UAAU,EACpB,QAAQ,EAAE,+BAA+B,EACxC,0BAA0B,CAAC,yCAA6B,EACxD,WAAW,CAAC,0BAAc;IAS/B,WAAW,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAUzE,eAAe,CAAC,OAAO,CAAC,EAAE,QAAQ,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;IAiBpE,WAAW,CAAC,oBAAoB,CAAC,EAAE,qBAAqB,GAAG,OAAO,CAAC,SAAS,CAAC;IAwC1F;;;;;OAKG;YACW,0BAA0B;IAcxC;;;;;;;;;;;;OAYG;YACW,2BAA2B;YAkD3B,oBAAoB;YAiBpB,eAAe;IAS7B,OAAO,CAAC,SAAS;YAOH,WAAW;IAaZ,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC;IAOlD,wBAAwB,CACpC,OAAO,EAAE,YAAY,EACrB,OAAO,EAAE,eAAe,GACtB,OAAO,CAAC,MAAM,CAAC;IAkBL,UAAU,CAAC,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,mBAAmB,CAAC;IAO/D,eAAe,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,YAAY,CAAC;YAI7D,uBAAuB;CAWrC"}