@fluidframework/routerlicious-driver 2.0.0-dev.2.3.0.115467 → 2.0.0-dev.3.1.0.125672

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 (147) hide show
  1. package/.eslintrc.js +10 -12
  2. package/.mocharc.js +2 -2
  3. package/README.md +1 -1
  4. package/api-extractor.json +2 -2
  5. package/dist/cache.d.ts +3 -0
  6. package/dist/cache.d.ts.map +1 -1
  7. package/dist/cache.js +6 -4
  8. package/dist/cache.js.map +1 -1
  9. package/dist/createNewUtils.d.ts.map +1 -1
  10. package/dist/createNewUtils.js +4 -2
  11. package/dist/createNewUtils.js.map +1 -1
  12. package/dist/defaultTokenProvider.d.ts.map +1 -1
  13. package/dist/defaultTokenProvider.js.map +1 -1
  14. package/dist/definitions.d.ts.map +1 -1
  15. package/dist/definitions.js.map +1 -1
  16. package/dist/deltaStorageService.d.ts.map +1 -1
  17. package/dist/deltaStorageService.js +4 -1
  18. package/dist/deltaStorageService.js.map +1 -1
  19. package/dist/documentDeltaConnection.d.ts.map +1 -1
  20. package/dist/documentDeltaConnection.js.map +1 -1
  21. package/dist/documentService.d.ts +4 -2
  22. package/dist/documentService.d.ts.map +1 -1
  23. package/dist/documentService.js +22 -41
  24. package/dist/documentService.js.map +1 -1
  25. package/dist/documentServiceFactory.d.ts.map +1 -1
  26. package/dist/documentServiceFactory.js +23 -9
  27. package/dist/documentServiceFactory.js.map +1 -1
  28. package/dist/documentStorageService.d.ts +1 -1
  29. package/dist/documentStorageService.d.ts.map +1 -1
  30. package/dist/documentStorageService.js +8 -6
  31. package/dist/documentStorageService.js.map +1 -1
  32. package/dist/errorUtils.d.ts +2 -1
  33. package/dist/errorUtils.d.ts.map +1 -1
  34. package/dist/errorUtils.js +6 -0
  35. package/dist/errorUtils.js.map +1 -1
  36. package/dist/index.d.ts +1 -1
  37. package/dist/index.d.ts.map +1 -1
  38. package/dist/index.js.map +1 -1
  39. package/dist/nullBlobStorageService.d.ts.map +1 -1
  40. package/dist/nullBlobStorageService.js.map +1 -1
  41. package/dist/packageVersion.d.ts +1 -1
  42. package/dist/packageVersion.js +1 -1
  43. package/dist/packageVersion.js.map +1 -1
  44. package/dist/policies.d.ts.map +1 -1
  45. package/dist/policies.js.map +1 -1
  46. package/dist/restWrapper.d.ts +8 -5
  47. package/dist/restWrapper.d.ts.map +1 -1
  48. package/dist/restWrapper.js +38 -44
  49. package/dist/restWrapper.js.map +1 -1
  50. package/dist/retriableGitManager.d.ts.map +1 -1
  51. package/dist/retriableGitManager.js.map +1 -1
  52. package/dist/shreddedSummaryDocumentStorageService.d.ts +1 -1
  53. package/dist/shreddedSummaryDocumentStorageService.d.ts.map +1 -1
  54. package/dist/shreddedSummaryDocumentStorageService.js +9 -5
  55. package/dist/shreddedSummaryDocumentStorageService.js.map +1 -1
  56. package/dist/tokens.d.ts.map +1 -1
  57. package/dist/tokens.js.map +1 -1
  58. package/dist/urlUtils.d.ts.map +1 -1
  59. package/dist/urlUtils.js.map +1 -1
  60. package/dist/wholeSummaryDocumentStorageService.d.ts +1 -1
  61. package/dist/wholeSummaryDocumentStorageService.d.ts.map +1 -1
  62. package/dist/wholeSummaryDocumentStorageService.js +25 -11
  63. package/dist/wholeSummaryDocumentStorageService.js.map +1 -1
  64. package/lib/cache.d.ts +3 -0
  65. package/lib/cache.d.ts.map +1 -1
  66. package/lib/cache.js +6 -4
  67. package/lib/cache.js.map +1 -1
  68. package/lib/createNewUtils.d.ts.map +1 -1
  69. package/lib/createNewUtils.js +4 -2
  70. package/lib/createNewUtils.js.map +1 -1
  71. package/lib/defaultTokenProvider.d.ts.map +1 -1
  72. package/lib/defaultTokenProvider.js.map +1 -1
  73. package/lib/definitions.d.ts.map +1 -1
  74. package/lib/definitions.js.map +1 -1
  75. package/lib/deltaStorageService.d.ts.map +1 -1
  76. package/lib/deltaStorageService.js +4 -1
  77. package/lib/deltaStorageService.js.map +1 -1
  78. package/lib/documentDeltaConnection.d.ts.map +1 -1
  79. package/lib/documentDeltaConnection.js.map +1 -1
  80. package/lib/documentService.d.ts +4 -2
  81. package/lib/documentService.d.ts.map +1 -1
  82. package/lib/documentService.js +22 -22
  83. package/lib/documentService.js.map +1 -1
  84. package/lib/documentServiceFactory.d.ts.map +1 -1
  85. package/lib/documentServiceFactory.js +23 -9
  86. package/lib/documentServiceFactory.js.map +1 -1
  87. package/lib/documentStorageService.d.ts +1 -1
  88. package/lib/documentStorageService.d.ts.map +1 -1
  89. package/lib/documentStorageService.js +9 -7
  90. package/lib/documentStorageService.js.map +1 -1
  91. package/lib/errorUtils.d.ts +2 -1
  92. package/lib/errorUtils.d.ts.map +1 -1
  93. package/lib/errorUtils.js +6 -0
  94. package/lib/errorUtils.js.map +1 -1
  95. package/lib/index.d.ts +1 -1
  96. package/lib/index.d.ts.map +1 -1
  97. package/lib/index.js +1 -1
  98. package/lib/index.js.map +1 -1
  99. package/lib/nullBlobStorageService.d.ts.map +1 -1
  100. package/lib/nullBlobStorageService.js.map +1 -1
  101. package/lib/packageVersion.d.ts +1 -1
  102. package/lib/packageVersion.js +1 -1
  103. package/lib/packageVersion.js.map +1 -1
  104. package/lib/policies.d.ts.map +1 -1
  105. package/lib/policies.js.map +1 -1
  106. package/lib/restWrapper.d.ts +8 -5
  107. package/lib/restWrapper.d.ts.map +1 -1
  108. package/lib/restWrapper.js +38 -44
  109. package/lib/restWrapper.js.map +1 -1
  110. package/lib/retriableGitManager.d.ts.map +1 -1
  111. package/lib/retriableGitManager.js.map +1 -1
  112. package/lib/shreddedSummaryDocumentStorageService.d.ts +1 -1
  113. package/lib/shreddedSummaryDocumentStorageService.d.ts.map +1 -1
  114. package/lib/shreddedSummaryDocumentStorageService.js +10 -6
  115. package/lib/shreddedSummaryDocumentStorageService.js.map +1 -1
  116. package/lib/tokens.d.ts.map +1 -1
  117. package/lib/tokens.js.map +1 -1
  118. package/lib/urlUtils.d.ts.map +1 -1
  119. package/lib/urlUtils.js.map +1 -1
  120. package/lib/wholeSummaryDocumentStorageService.d.ts +1 -1
  121. package/lib/wholeSummaryDocumentStorageService.d.ts.map +1 -1
  122. package/lib/wholeSummaryDocumentStorageService.js +27 -13
  123. package/lib/wholeSummaryDocumentStorageService.js.map +1 -1
  124. package/package.json +19 -15
  125. package/prettier.config.cjs +1 -1
  126. package/src/cache.ts +21 -14
  127. package/src/createNewUtils.ts +24 -22
  128. package/src/defaultTokenProvider.ts +13 -15
  129. package/src/definitions.ts +2 -2
  130. package/src/deltaStorageService.ts +99 -95
  131. package/src/documentDeltaConnection.ts +53 -47
  132. package/src/documentService.ts +243 -239
  133. package/src/documentServiceFactory.ts +267 -237
  134. package/src/documentStorageService.ts +87 -83
  135. package/src/errorUtils.ts +78 -75
  136. package/src/index.ts +4 -1
  137. package/src/nullBlobStorageService.ts +24 -21
  138. package/src/packageVersion.ts +1 -1
  139. package/src/policies.ts +44 -44
  140. package/src/restWrapper.ts +270 -208
  141. package/src/retriableGitManager.ts +152 -151
  142. package/src/shreddedSummaryDocumentStorageService.ts +202 -194
  143. package/src/tokens.ts +51 -43
  144. package/src/urlUtils.ts +26 -23
  145. package/src/wholeSummaryDocumentStorageService.ts +246 -228
  146. package/tsconfig.esnext.json +6 -6
  147. package/tsconfig.json +9 -13
@@ -5,18 +5,16 @@
5
5
 
6
6
  import type { ITelemetryLogger } from "@fluidframework/common-definitions";
7
7
  import {
8
- IDocumentStorageService,
9
- IDocumentStorageServicePolicies,
10
- LoaderCachingPolicy,
8
+ IDocumentStorageService,
9
+ IDocumentStorageServicePolicies,
10
+ LoaderCachingPolicy,
11
11
  } from "@fluidframework/driver-definitions";
12
+ import { ISnapshotTree, IVersion } from "@fluidframework/protocol-definitions";
13
+ import { GitManager } from "@fluidframework/server-services-client";
12
14
  import {
13
- ISnapshotTree,
14
- IVersion,
15
- } from "@fluidframework/protocol-definitions";
16
- import {
17
- GitManager,
18
- } from "@fluidframework/server-services-client";
19
- import { DocumentStorageServiceProxy, PrefetchDocumentStorageService } from "@fluidframework/driver-utils";
15
+ DocumentStorageServiceProxy,
16
+ PrefetchDocumentStorageService,
17
+ } from "@fluidframework/driver-utils";
20
18
  import { IRouterliciousDriverPolicies } from "./policies";
21
19
  import { ICache } from "./cache";
22
20
  import { WholeSummaryDocumentStorageService } from "./wholeSummaryDocumentStorageService";
@@ -24,81 +22,87 @@ import { ShreddedSummaryDocumentStorageService } from "./shreddedSummaryDocument
24
22
  import { ISnapshotTreeVersion } from "./definitions";
25
23
 
26
24
  export class DocumentStorageService extends DocumentStorageServiceProxy {
27
- private _logTailSha: string | undefined = undefined;
25
+ private _logTailSha: string | undefined = undefined;
28
26
 
29
- public get logTailSha(): string | undefined {
30
- return this._logTailSha;
31
- }
27
+ public get logTailSha(): string | undefined {
28
+ return this._logTailSha;
29
+ }
32
30
 
33
- private static loadInternalDocumentStorageService(
34
- id: string,
35
- manager: GitManager,
36
- logger: ITelemetryLogger,
37
- policies: IDocumentStorageServicePolicies,
38
- driverPolicies?: IRouterliciousDriverPolicies,
39
- blobCache?: ICache<ArrayBufferLike>,
40
- snapshotTreeCache?: ICache<ISnapshotTreeVersion>,
41
- noCacheGitManager?: GitManager,
42
- getStorageManager?: (disableCache?: boolean) => Promise<GitManager>,
43
- ): IDocumentStorageService {
44
- const storageService = driverPolicies?.enableWholeSummaryUpload ?
45
- new WholeSummaryDocumentStorageService(
46
- id,
47
- manager,
48
- logger,
49
- policies,
50
- driverPolicies,
51
- blobCache,
52
- snapshotTreeCache,
53
- noCacheGitManager,
54
- getStorageManager,
55
- ) :
56
- new ShreddedSummaryDocumentStorageService(
57
- id,
58
- manager,
59
- logger,
60
- policies,
61
- driverPolicies,
62
- blobCache,
63
- snapshotTreeCache,
64
- getStorageManager,
65
- );
66
- // TODO: worth prefetching latest summary making version + snapshot call with WholeSummary storage?
67
- if (!driverPolicies?.enableWholeSummaryUpload && policies.caching === LoaderCachingPolicy.Prefetch) {
68
- return new PrefetchDocumentStorageService(storageService);
69
- }
70
- return storageService;
71
- }
31
+ private static loadInternalDocumentStorageService(
32
+ id: string,
33
+ manager: GitManager,
34
+ logger: ITelemetryLogger,
35
+ policies: IDocumentStorageServicePolicies,
36
+ driverPolicies?: IRouterliciousDriverPolicies,
37
+ blobCache?: ICache<ArrayBufferLike>,
38
+ snapshotTreeCache?: ICache<ISnapshotTreeVersion>,
39
+ noCacheGitManager?: GitManager,
40
+ getStorageManager?: (disableCache?: boolean) => Promise<GitManager>,
41
+ ): IDocumentStorageService {
42
+ const storageService = driverPolicies?.enableWholeSummaryUpload
43
+ ? new WholeSummaryDocumentStorageService(
44
+ id,
45
+ manager,
46
+ logger,
47
+ policies,
48
+ driverPolicies,
49
+ blobCache,
50
+ snapshotTreeCache,
51
+ noCacheGitManager,
52
+ getStorageManager,
53
+ )
54
+ : new ShreddedSummaryDocumentStorageService(
55
+ id,
56
+ manager,
57
+ logger,
58
+ policies,
59
+ driverPolicies,
60
+ blobCache,
61
+ snapshotTreeCache,
62
+ getStorageManager,
63
+ );
64
+ // TODO: worth prefetching latest summary making version + snapshot call with WholeSummary storage?
65
+ if (
66
+ !driverPolicies?.enableWholeSummaryUpload &&
67
+ policies.caching === LoaderCachingPolicy.Prefetch
68
+ ) {
69
+ return new PrefetchDocumentStorageService(storageService);
70
+ }
71
+ return storageService;
72
+ }
72
73
 
73
- constructor(
74
- public readonly id: string,
75
- public manager: GitManager,
76
- logger: ITelemetryLogger,
77
- policies: IDocumentStorageServicePolicies = {},
78
- driverPolicies?: IRouterliciousDriverPolicies,
79
- blobCache?: ICache<ArrayBufferLike>,
80
- snapshotTreeCache?: ICache<ISnapshotTreeVersion>,
81
- public noCacheGitManager?: GitManager,
82
- getStorageManager?: (disableCache?: boolean) => Promise<GitManager>,
83
- ) {
84
- super(DocumentStorageService.loadInternalDocumentStorageService(
85
- id,
86
- manager,
87
- logger,
88
- policies,
89
- driverPolicies,
90
- blobCache,
91
- snapshotTreeCache,
92
- noCacheGitManager,
93
- getStorageManager,
94
- ));
95
- }
74
+ constructor(
75
+ public readonly id: string,
76
+ public manager: GitManager,
77
+ logger: ITelemetryLogger,
78
+ policies: IDocumentStorageServicePolicies,
79
+ driverPolicies?: IRouterliciousDriverPolicies,
80
+ blobCache?: ICache<ArrayBufferLike>,
81
+ snapshotTreeCache?: ICache<ISnapshotTreeVersion>,
82
+ public noCacheGitManager?: GitManager,
83
+ getStorageManager?: (disableCache?: boolean) => Promise<GitManager>,
84
+ ) {
85
+ super(
86
+ DocumentStorageService.loadInternalDocumentStorageService(
87
+ id,
88
+ manager,
89
+ logger,
90
+ policies,
91
+ driverPolicies,
92
+ blobCache,
93
+ snapshotTreeCache,
94
+ noCacheGitManager,
95
+ getStorageManager,
96
+ ),
97
+ );
98
+ }
96
99
 
97
- public async getSnapshotTree(version?: IVersion): Promise<ISnapshotTree | null> {
98
- const tree = await this.internalStorageService.getSnapshotTree(version);
99
- if (tree !== null) {
100
- this._logTailSha = ".logTail" in tree.trees ? tree.trees[".logTail"].blobs.logTail : undefined;
101
- }
102
- return tree;
103
- }
100
+ public async getSnapshotTree(version?: IVersion): Promise<ISnapshotTree | null> {
101
+ const tree = await this.internalStorageService.getSnapshotTree(version);
102
+ if (tree !== null) {
103
+ this._logTailSha =
104
+ ".logTail" in tree.trees ? tree.trees[".logTail"].blobs.logTail : undefined;
105
+ }
106
+ return tree;
107
+ }
104
108
  }
package/src/errorUtils.ts CHANGED
@@ -5,15 +5,16 @@
5
5
 
6
6
  import { DriverError } from "@fluidframework/driver-definitions";
7
7
  import {
8
- NonRetryableError,
9
- GenericNetworkError,
10
- createGenericNetworkError,
11
- AuthorizationError,
8
+ NonRetryableError,
9
+ GenericNetworkError,
10
+ createGenericNetworkError,
11
+ AuthorizationError,
12
12
  } from "@fluidframework/driver-utils";
13
13
  import { pkgVersion as driverVersion } from "./packageVersion";
14
14
 
15
15
  export enum R11sErrorType {
16
- fileNotFoundOrAccessDeniedError = "fileNotFoundOrAccessDeniedError",
16
+ fileNotFoundOrAccessDeniedError = "fileNotFoundOrAccessDeniedError",
17
+ sslCertError = "sslCertError",
17
18
  }
18
19
 
19
20
  /**
@@ -21,96 +22,98 @@ export enum R11sErrorType {
21
22
  * Intended to be compatible with output from {@link NetworkError.toJSON}
22
23
  */
23
24
  export interface IR11sSocketError {
24
- /**
25
- * An error code number for the error that occurred.
26
- * It will be a valid HTTP status code.
27
- */
28
- code: number;
25
+ /**
26
+ * An error code number for the error that occurred.
27
+ * It will be a valid HTTP status code.
28
+ */
29
+ code: number;
29
30
 
30
- /**
31
- * A message about the error that occurred for debugging / logging purposes.
32
- * This should not be displayed to the user directly.
33
- */
34
- message: string;
31
+ /**
32
+ * A message about the error that occurred for debugging / logging purposes.
33
+ * This should not be displayed to the user directly.
34
+ */
35
+ message: string;
35
36
 
36
- /**
37
- * Optional Retry-After time in seconds.
38
- * The client should wait this many seconds before retrying its request.
39
- */
40
- retryAfter?: number;
37
+ /**
38
+ * Optional Retry-After time in seconds.
39
+ * The client should wait this many seconds before retrying its request.
40
+ */
41
+ retryAfter?: number;
41
42
 
42
- /**
43
- * Optional Retry-After time in milliseconds.
44
- * The client should wait this many milliseconds before retrying its request.
45
- */
46
- retryAfterMs?: number;
43
+ /**
44
+ * Optional Retry-After time in milliseconds.
45
+ * The client should wait this many milliseconds before retrying its request.
46
+ */
47
+ retryAfterMs?: number;
47
48
  }
48
49
 
49
50
  export interface IR11sError {
50
- readonly errorType: R11sErrorType;
51
- readonly message: string;
52
- canRetry: boolean;
51
+ readonly errorType: R11sErrorType;
52
+ readonly message: string;
53
+ canRetry: boolean;
53
54
  }
54
55
 
55
56
  export type R11sError = DriverError | IR11sError;
56
57
 
57
58
  export function createR11sNetworkError(
58
- errorMessage: string,
59
- statusCode?: number,
60
- retryAfterMs?: number,
59
+ errorMessage: string,
60
+ statusCode?: number,
61
+ retryAfterMs?: number,
61
62
  ): R11sError {
62
- const props = { statusCode, driverVersion };
63
- switch (statusCode) {
64
- case undefined:
65
- // If a service is temporarily down or a browser resource limit is reached, RestWrapper will throw
66
- // a network error with no status code (e.g. err:ERR_CONN_REFUSED or err:ERR_FAILED) and
67
- // the error message will start with NetworkError as defined in restWrapper.ts
68
- return new GenericNetworkError(
69
- errorMessage, errorMessage.startsWith("NetworkError"), props);
70
- case 401:
71
- // The first 401 is manually retried in RouterliciousRestWrapper with a refreshed token,
72
- // so we treat repeat 401s the same as 403.
73
- case 403:
74
- return new AuthorizationError(
75
- errorMessage, undefined, undefined, props);
76
- case 404:
77
- const errorType = R11sErrorType.fileNotFoundOrAccessDeniedError;
78
- return new NonRetryableError(errorMessage, errorType, props);
79
- case 429:
80
- return createGenericNetworkError(
81
- errorMessage, { canRetry: true, retryAfterMs }, props);
82
- case 500:
83
- case 502:
84
- return new GenericNetworkError(errorMessage, true, props);
85
- default:
86
- const retryInfo = { canRetry: retryAfterMs !== undefined, retryAfterMs };
87
- return createGenericNetworkError(errorMessage, retryInfo, props);
88
- }
63
+ const props = { statusCode, driverVersion };
64
+ switch (statusCode) {
65
+ case undefined:
66
+ // If a service is temporarily down or a browser resource limit is reached, RestWrapper will throw
67
+ // a network error with no status code (e.g. err:ERR_CONN_REFUSED or err:ERR_FAILED) and
68
+ // the error message will start with NetworkError as defined in restWrapper.ts
69
+ // If there exists a self-signed SSL certificates error, throw a NonRetryableError
70
+ // TODO: instead of relying on string matching, filter error based on the error code like we do for websocket connections
71
+ if (errorMessage.includes("failed, reason: self signed certificate")) {
72
+ return new NonRetryableError(errorMessage, R11sErrorType.sslCertError, props);
73
+ }
74
+ return new GenericNetworkError(
75
+ errorMessage,
76
+ errorMessage.startsWith("NetworkError"),
77
+ props,
78
+ );
79
+ case 401:
80
+ // The first 401 is manually retried in RouterliciousRestWrapper with a refreshed token,
81
+ // so we treat repeat 401s the same as 403.
82
+ case 403:
83
+ return new AuthorizationError(errorMessage, undefined, undefined, props);
84
+ case 404:
85
+ const errorType = R11sErrorType.fileNotFoundOrAccessDeniedError;
86
+ return new NonRetryableError(errorMessage, errorType, props);
87
+ case 429:
88
+ return createGenericNetworkError(errorMessage, { canRetry: true, retryAfterMs }, props);
89
+ case 500:
90
+ case 502:
91
+ return new GenericNetworkError(errorMessage, true, props);
92
+ default:
93
+ const retryInfo = { canRetry: retryAfterMs !== undefined, retryAfterMs };
94
+ return createGenericNetworkError(errorMessage, retryInfo, props);
95
+ }
89
96
  }
90
97
 
91
98
  export function throwR11sNetworkError(
92
- errorMessage: string,
93
- statusCode?: number,
94
- retryAfterMs?: number,
99
+ errorMessage: string,
100
+ statusCode?: number,
101
+ retryAfterMs?: number,
95
102
  ): never {
96
- const networkError = createR11sNetworkError(
97
- errorMessage,
98
- statusCode,
99
- retryAfterMs);
103
+ const networkError = createR11sNetworkError(errorMessage, statusCode, retryAfterMs);
100
104
 
101
- // eslint-disable-next-line @typescript-eslint/no-throw-literal
102
- throw networkError;
105
+ // eslint-disable-next-line @typescript-eslint/no-throw-literal
106
+ throw networkError;
103
107
  }
104
108
 
105
109
  /**
106
110
  * Returns network error based on error object from R11s socket (IR11sSocketError)
107
111
  */
108
- export function errorObjectFromSocketError(socketError: IR11sSocketError, handler: string): R11sError {
109
- // pre-0.58 error message prefix: R11sSocketError
110
- const message = `R11s socket error (${handler}): ${socketError.message}`;
111
- return createR11sNetworkError(
112
- message,
113
- socketError.code,
114
- socketError.retryAfterMs,
115
- );
112
+ export function errorObjectFromSocketError(
113
+ socketError: IR11sSocketError,
114
+ handler: string,
115
+ ): R11sError {
116
+ // pre-0.58 error message prefix: R11sSocketError
117
+ const message = `R11s socket error (${handler}): ${socketError.message}`;
118
+ return createR11sNetworkError(message, socketError.code, socketError.retryAfterMs);
116
119
  }
package/src/index.ts CHANGED
@@ -8,7 +8,10 @@ export { DefaultTokenProvider } from "./defaultTokenProvider";
8
8
  export { ITokenProvider, ITokenResponse, ITokenService } from "./tokens";
9
9
 
10
10
  // Factory
11
- export { DocumentPostCreateError, RouterliciousDocumentServiceFactory } from "./documentServiceFactory";
11
+ export {
12
+ DocumentPostCreateError,
13
+ RouterliciousDocumentServiceFactory,
14
+ } from "./documentServiceFactory";
12
15
 
13
16
  // Configuration
14
17
  export { IRouterliciousDriverPolicies } from "./policies";
@@ -11,30 +11,33 @@ import * as api from "@fluidframework/protocol-definitions";
11
11
  * Does not read/write anything.
12
12
  */
13
13
  export class NullBlobStorageService implements IDocumentStorageService {
14
- public get repositoryUrl(): string {
15
- throw new Error("Invalid operation");
16
- }
14
+ public get repositoryUrl(): string {
15
+ throw new Error("Invalid operation");
16
+ }
17
17
 
18
- public async getSnapshotTree(version?: api.IVersion): Promise<api.ISnapshotTree | null> {
19
- return version ? Promise.reject(new Error("Invalid operation")) : null;
20
- }
18
+ public async getSnapshotTree(version?: api.IVersion): Promise<api.ISnapshotTree | null> {
19
+ return version ? Promise.reject(new Error("Invalid operation")) : null;
20
+ }
21
21
 
22
- public async getVersions(versionId: string | null, count: number): Promise<api.IVersion[]> {
23
- return [];
24
- }
22
+ public async getVersions(versionId: string | null, count: number): Promise<api.IVersion[]> {
23
+ return [];
24
+ }
25
25
 
26
- public async uploadSummaryWithContext(summary: api.ISummaryTree, context: ISummaryContext): Promise<string> {
27
- return Promise.reject(new Error("Invalid operation"));
28
- }
26
+ public async uploadSummaryWithContext(
27
+ summary: api.ISummaryTree,
28
+ context: ISummaryContext,
29
+ ): Promise<string> {
30
+ return Promise.reject(new Error("Invalid operation"));
31
+ }
29
32
 
30
- public async downloadSummary(handle: api.ISummaryHandle): Promise<api.ISummaryTree> {
31
- return Promise.reject(new Error("Invalid operation"));
32
- }
33
+ public async downloadSummary(handle: api.ISummaryHandle): Promise<api.ISummaryTree> {
34
+ return Promise.reject(new Error("Invalid operation"));
35
+ }
33
36
 
34
- public async createBlob(file: ArrayBufferLike): Promise<api.ICreateBlobResponse> {
35
- return Promise.reject(new Error("Null blob storage can not create blob"));
36
- }
37
- public async readBlob(blobId: string): Promise<ArrayBufferLike> {
38
- return Promise.reject(new Error("Null blob storage can not read blob"));
39
- }
37
+ public async createBlob(file: ArrayBufferLike): Promise<api.ICreateBlobResponse> {
38
+ return Promise.reject(new Error("Null blob storage can not create blob"));
39
+ }
40
+ public async readBlob(blobId: string): Promise<ArrayBufferLike> {
41
+ return Promise.reject(new Error("Null blob storage can not read blob"));
42
+ }
40
43
  }
@@ -6,4 +6,4 @@
6
6
  */
7
7
 
8
8
  export const pkgName = "@fluidframework/routerlicious-driver";
9
- export const pkgVersion = "2.0.0-dev.2.3.0.115467";
9
+ export const pkgVersion = "2.0.0-dev.3.1.0.125672";
package/src/policies.ts CHANGED
@@ -4,48 +4,48 @@
4
4
  */
5
5
 
6
6
  export interface IRouterliciousDriverPolicies {
7
- /**
8
- * Enable prefetching entire snapshot tree into memory before it is loaded by the runtime.
9
- * Default: true
10
- */
11
- enablePrefetch: boolean;
12
- /**
13
- * Rate limit concurrent storage requests.
14
- * Default: 100
15
- */
16
- maxConcurrentStorageRequests: number;
17
- /**
18
- * Rate limit concurrent orderer requests.
19
- * Default: 100
20
- */
21
- maxConcurrentOrdererRequests: number;
22
- /**
23
- * Give hosts the option to change blob aggregation behavior to suit their needs.
24
- * Larger number means fewer blob individual requests, but less blob-deduping.
25
- * Smaller number means more blob individual requests, but more blob-deduping.
26
- * Setting to `undefined` disables blob aggregration.
27
- * Default: undefined
28
- */
29
- aggregateBlobsSmallerThanBytes: number | undefined;
30
- /**
31
- * Enable uploading entire summary tree as a IWholeSummaryPayload to storage.
32
- * Default: false
33
- */
34
- enableWholeSummaryUpload: boolean;
35
- /**
36
- * Enable service endpoint discovery when creating or joining a session.
37
- * Default: false
38
- */
39
- enableDiscovery?: boolean;
40
- /**
41
- * Enable using RestLess which avoids CORS preflight requests.
42
- * Default: true
43
- */
44
- enableRestLess: boolean;
45
- /**
46
- * Enable internal cache of summaries/snapshots.
47
- * Reduces Summarizer boot time and reduces server load in E2E tests.
48
- * Default: true
49
- */
50
- enableInternalSummaryCaching: boolean;
7
+ /**
8
+ * Enable prefetching entire snapshot tree into memory before it is loaded by the runtime.
9
+ * Default: true
10
+ */
11
+ enablePrefetch: boolean;
12
+ /**
13
+ * Rate limit concurrent storage requests.
14
+ * Default: 100
15
+ */
16
+ maxConcurrentStorageRequests: number;
17
+ /**
18
+ * Rate limit concurrent orderer requests.
19
+ * Default: 100
20
+ */
21
+ maxConcurrentOrdererRequests: number;
22
+ /**
23
+ * Give hosts the option to change blob aggregation behavior to suit their needs.
24
+ * Larger number means fewer blob individual requests, but less blob-deduping.
25
+ * Smaller number means more blob individual requests, but more blob-deduping.
26
+ * Setting to `undefined` disables blob aggregration.
27
+ * Default: undefined
28
+ */
29
+ aggregateBlobsSmallerThanBytes: number | undefined;
30
+ /**
31
+ * Enable uploading entire summary tree as a IWholeSummaryPayload to storage.
32
+ * Default: false
33
+ */
34
+ enableWholeSummaryUpload: boolean;
35
+ /**
36
+ * Enable service endpoint discovery when creating or joining a session.
37
+ * Default: false
38
+ */
39
+ enableDiscovery?: boolean;
40
+ /**
41
+ * Enable using RestLess which avoids CORS preflight requests.
42
+ * Default: true
43
+ */
44
+ enableRestLess: boolean;
45
+ /**
46
+ * Enable internal cache of summaries/snapshots.
47
+ * Reduces Summarizer boot time and reduces server load in E2E tests.
48
+ * Default: true
49
+ */
50
+ enableInternalSummaryCaching: boolean;
51
51
  }