@fluidframework/container-loader 2.0.0-rc.2.0.1 → 2.0.0-rc.3.0.0

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 (246) hide show
  1. package/CHANGELOG.md +33 -0
  2. package/api-report/container-loader.api.md +13 -13
  3. package/dist/attachment.d.ts +6 -9
  4. package/dist/attachment.d.ts.map +1 -1
  5. package/dist/attachment.js +5 -5
  6. package/dist/attachment.js.map +1 -1
  7. package/dist/audience.d.ts +1 -1
  8. package/dist/audience.d.ts.map +1 -1
  9. package/dist/audience.js +4 -4
  10. package/dist/audience.js.map +1 -1
  11. package/dist/catchUpMonitor.d.ts +1 -1
  12. package/dist/catchUpMonitor.d.ts.map +1 -1
  13. package/dist/catchUpMonitor.js +2 -2
  14. package/dist/catchUpMonitor.js.map +1 -1
  15. package/dist/connectionManager.d.ts +4 -4
  16. package/dist/connectionManager.d.ts.map +1 -1
  17. package/dist/connectionManager.js +48 -43
  18. package/dist/connectionManager.js.map +1 -1
  19. package/dist/connectionStateHandler.d.ts +3 -3
  20. package/dist/connectionStateHandler.d.ts.map +1 -1
  21. package/dist/connectionStateHandler.js +27 -27
  22. package/dist/connectionStateHandler.js.map +1 -1
  23. package/dist/container.d.ts +9 -46
  24. package/dist/container.d.ts.map +1 -1
  25. package/dist/container.js +105 -116
  26. package/dist/container.js.map +1 -1
  27. package/dist/containerContext.d.ts +19 -7
  28. package/dist/containerContext.d.ts.map +1 -1
  29. package/dist/containerContext.js +7 -2
  30. package/dist/containerContext.js.map +1 -1
  31. package/dist/containerStorageAdapter.d.ts +3 -3
  32. package/dist/containerStorageAdapter.d.ts.map +1 -1
  33. package/dist/containerStorageAdapter.js +6 -6
  34. package/dist/containerStorageAdapter.js.map +1 -1
  35. package/dist/contracts.d.ts +4 -3
  36. package/dist/contracts.d.ts.map +1 -1
  37. package/dist/contracts.js +2 -2
  38. package/dist/contracts.js.map +1 -1
  39. package/dist/debugLogger.d.ts +2 -1
  40. package/dist/debugLogger.d.ts.map +1 -1
  41. package/dist/debugLogger.js +4 -4
  42. package/dist/debugLogger.js.map +1 -1
  43. package/dist/deltaManager.d.ts +11 -7
  44. package/dist/deltaManager.d.ts.map +1 -1
  45. package/dist/deltaManager.js +53 -50
  46. package/dist/deltaManager.js.map +1 -1
  47. package/dist/deltaQueue.d.ts +1 -1
  48. package/dist/deltaQueue.d.ts.map +1 -1
  49. package/dist/deltaQueue.js +5 -5
  50. package/dist/deltaQueue.js.map +1 -1
  51. package/dist/error.d.ts +3 -2
  52. package/dist/error.d.ts.map +1 -1
  53. package/dist/error.js +5 -5
  54. package/dist/error.js.map +1 -1
  55. package/dist/legacy.d.ts +29 -0
  56. package/dist/loader.d.ts +4 -4
  57. package/dist/loader.d.ts.map +1 -1
  58. package/dist/loader.js +23 -23
  59. package/dist/loader.js.map +1 -1
  60. package/dist/location-redirection-utilities/resolveWithLocationRedirection.d.ts +2 -2
  61. package/dist/location-redirection-utilities/resolveWithLocationRedirection.d.ts.map +1 -1
  62. package/dist/location-redirection-utilities/resolveWithLocationRedirection.js +2 -2
  63. package/dist/location-redirection-utilities/resolveWithLocationRedirection.js.map +1 -1
  64. package/dist/noopHeuristic.d.ts +1 -1
  65. package/dist/noopHeuristic.d.ts.map +1 -1
  66. package/dist/noopHeuristic.js +6 -6
  67. package/dist/noopHeuristic.js.map +1 -1
  68. package/dist/packageVersion.d.ts +1 -1
  69. package/dist/packageVersion.js +1 -1
  70. package/dist/packageVersion.js.map +1 -1
  71. package/dist/protocol.d.ts +1 -1
  72. package/dist/protocol.d.ts.map +1 -1
  73. package/dist/protocol.js +2 -2
  74. package/dist/protocol.js.map +1 -1
  75. package/dist/protocolTreeDocumentStorageService.d.ts +4 -4
  76. package/dist/protocolTreeDocumentStorageService.d.ts.map +1 -1
  77. package/dist/protocolTreeDocumentStorageService.js.map +1 -1
  78. package/dist/public.d.ts +14 -0
  79. package/dist/quorum.d.ts +1 -1
  80. package/dist/quorum.d.ts.map +1 -1
  81. package/dist/quorum.js +4 -0
  82. package/dist/quorum.js.map +1 -1
  83. package/dist/retriableDocumentStorageService.d.ts +2 -2
  84. package/dist/retriableDocumentStorageService.d.ts.map +1 -1
  85. package/dist/retriableDocumentStorageService.js +7 -7
  86. package/dist/retriableDocumentStorageService.js.map +1 -1
  87. package/dist/serializedStateManager.d.ts +86 -16
  88. package/dist/serializedStateManager.d.ts.map +1 -1
  89. package/dist/serializedStateManager.js +182 -82
  90. package/dist/serializedStateManager.js.map +1 -1
  91. package/dist/utils.d.ts +24 -9
  92. package/dist/utils.d.ts.map +1 -1
  93. package/dist/utils.js +82 -25
  94. package/dist/utils.js.map +1 -1
  95. package/internal.d.ts +11 -0
  96. package/legacy.d.ts +11 -0
  97. package/lib/attachment.d.ts +6 -9
  98. package/lib/attachment.d.ts.map +1 -1
  99. package/lib/attachment.js +1 -1
  100. package/lib/attachment.js.map +1 -1
  101. package/lib/audience.d.ts +1 -1
  102. package/lib/audience.d.ts.map +1 -1
  103. package/lib/audience.js +1 -1
  104. package/lib/audience.js.map +1 -1
  105. package/lib/catchUpMonitor.d.ts +1 -1
  106. package/lib/catchUpMonitor.d.ts.map +1 -1
  107. package/lib/catchUpMonitor.js +1 -1
  108. package/lib/catchUpMonitor.js.map +1 -1
  109. package/lib/connectionManager.d.ts +4 -4
  110. package/lib/connectionManager.d.ts.map +1 -1
  111. package/lib/connectionManager.js +11 -6
  112. package/lib/connectionManager.js.map +1 -1
  113. package/lib/connectionStateHandler.d.ts +3 -3
  114. package/lib/connectionStateHandler.d.ts.map +1 -1
  115. package/lib/connectionStateHandler.js +2 -2
  116. package/lib/connectionStateHandler.js.map +1 -1
  117. package/lib/container.d.ts +9 -46
  118. package/lib/container.d.ts.map +1 -1
  119. package/lib/container.js +37 -48
  120. package/lib/container.js.map +1 -1
  121. package/lib/containerContext.d.ts +19 -7
  122. package/lib/containerContext.d.ts.map +1 -1
  123. package/lib/containerContext.js +7 -2
  124. package/lib/containerContext.js.map +1 -1
  125. package/lib/containerStorageAdapter.d.ts +3 -3
  126. package/lib/containerStorageAdapter.d.ts.map +1 -1
  127. package/lib/containerStorageAdapter.js +2 -2
  128. package/lib/containerStorageAdapter.js.map +1 -1
  129. package/lib/contracts.d.ts +4 -3
  130. package/lib/contracts.d.ts.map +1 -1
  131. package/lib/contracts.js +1 -1
  132. package/lib/contracts.js.map +1 -1
  133. package/lib/debugLogger.d.ts +2 -1
  134. package/lib/debugLogger.d.ts.map +1 -1
  135. package/lib/debugLogger.js +1 -1
  136. package/lib/debugLogger.js.map +1 -1
  137. package/lib/deltaManager.d.ts +11 -7
  138. package/lib/deltaManager.d.ts.map +1 -1
  139. package/lib/deltaManager.js +13 -10
  140. package/lib/deltaManager.js.map +1 -1
  141. package/lib/deltaQueue.d.ts +1 -1
  142. package/lib/deltaQueue.d.ts.map +1 -1
  143. package/lib/deltaQueue.js +2 -2
  144. package/lib/deltaQueue.js.map +1 -1
  145. package/lib/error.d.ts +3 -2
  146. package/lib/error.d.ts.map +1 -1
  147. package/lib/error.js +2 -2
  148. package/lib/error.js.map +1 -1
  149. package/lib/legacy.d.ts +29 -0
  150. package/lib/loader.d.ts +4 -4
  151. package/lib/loader.d.ts.map +1 -1
  152. package/lib/loader.js +4 -4
  153. package/lib/loader.js.map +1 -1
  154. package/lib/location-redirection-utilities/resolveWithLocationRedirection.d.ts +2 -2
  155. package/lib/location-redirection-utilities/resolveWithLocationRedirection.d.ts.map +1 -1
  156. package/lib/location-redirection-utilities/resolveWithLocationRedirection.js +2 -2
  157. package/lib/location-redirection-utilities/resolveWithLocationRedirection.js.map +1 -1
  158. package/lib/noopHeuristic.d.ts +1 -1
  159. package/lib/noopHeuristic.d.ts.map +1 -1
  160. package/lib/noopHeuristic.js +2 -2
  161. package/lib/noopHeuristic.js.map +1 -1
  162. package/lib/packageVersion.d.ts +1 -1
  163. package/lib/packageVersion.js +1 -1
  164. package/lib/packageVersion.js.map +1 -1
  165. package/lib/protocol.d.ts +1 -1
  166. package/lib/protocol.d.ts.map +1 -1
  167. package/lib/protocol.js +1 -1
  168. package/lib/protocol.js.map +1 -1
  169. package/lib/protocolTreeDocumentStorageService.d.ts +4 -4
  170. package/lib/protocolTreeDocumentStorageService.d.ts.map +1 -1
  171. package/lib/protocolTreeDocumentStorageService.js.map +1 -1
  172. package/lib/public.d.ts +14 -0
  173. package/lib/quorum.d.ts +1 -1
  174. package/lib/quorum.d.ts.map +1 -1
  175. package/lib/quorum.js +4 -0
  176. package/lib/quorum.js.map +1 -1
  177. package/lib/retriableDocumentStorageService.d.ts +2 -2
  178. package/lib/retriableDocumentStorageService.d.ts.map +1 -1
  179. package/lib/retriableDocumentStorageService.js +3 -3
  180. package/lib/retriableDocumentStorageService.js.map +1 -1
  181. package/lib/serializedStateManager.d.ts +86 -16
  182. package/lib/serializedStateManager.d.ts.map +1 -1
  183. package/lib/serializedStateManager.js +174 -77
  184. package/lib/serializedStateManager.js.map +1 -1
  185. package/lib/utils.d.ts +24 -9
  186. package/lib/utils.d.ts.map +1 -1
  187. package/lib/utils.js +69 -15
  188. package/lib/utils.js.map +1 -1
  189. package/package.json +37 -58
  190. package/src/attachment.ts +10 -8
  191. package/src/audience.ts +3 -2
  192. package/src/catchUpMonitor.ts +2 -2
  193. package/src/connectionManager.ts +27 -20
  194. package/src/connectionStateHandler.ts +7 -7
  195. package/src/container.ts +90 -143
  196. package/src/containerContext.ts +22 -12
  197. package/src/containerStorageAdapter.ts +7 -6
  198. package/src/contracts.ts +4 -5
  199. package/src/debugLogger.ts +3 -4
  200. package/src/deltaManager.ts +40 -30
  201. package/src/deltaQueue.ts +2 -2
  202. package/src/error.ts +5 -4
  203. package/src/loader.ts +25 -23
  204. package/src/location-redirection-utilities/resolveWithLocationRedirection.ts +4 -4
  205. package/src/noopHeuristic.ts +3 -3
  206. package/src/packageVersion.ts +1 -1
  207. package/src/protocol.ts +2 -2
  208. package/src/protocolTreeDocumentStorageService.ts +4 -1
  209. package/src/quorum.ts +2 -1
  210. package/src/retriableDocumentStorageService.ts +6 -5
  211. package/src/serializedStateManager.ts +299 -111
  212. package/src/utils.ts +103 -24
  213. package/api-extractor-cjs.json +0 -8
  214. package/dist/container-loader-alpha.d.ts +0 -275
  215. package/dist/container-loader-beta.d.ts +0 -101
  216. package/dist/container-loader-public.d.ts +0 -101
  217. package/dist/container-loader-untrimmed.d.ts +0 -331
  218. package/lib/container-loader-alpha.d.ts +0 -275
  219. package/lib/container-loader-beta.d.ts +0 -101
  220. package/lib/container-loader-public.d.ts +0 -101
  221. package/lib/container-loader-untrimmed.d.ts +0 -331
  222. package/lib/test/attachment.spec.js +0 -380
  223. package/lib/test/attachment.spec.js.map +0 -1
  224. package/lib/test/catchUpMonitor.spec.js +0 -88
  225. package/lib/test/catchUpMonitor.spec.js.map +0 -1
  226. package/lib/test/connectionManager.spec.js +0 -201
  227. package/lib/test/connectionManager.spec.js.map +0 -1
  228. package/lib/test/connectionStateHandler.spec.js +0 -555
  229. package/lib/test/connectionStateHandler.spec.js.map +0 -1
  230. package/lib/test/container.spec.js +0 -64
  231. package/lib/test/container.spec.js.map +0 -1
  232. package/lib/test/deltaManager.spec.js +0 -405
  233. package/lib/test/deltaManager.spec.js.map +0 -1
  234. package/lib/test/loader.spec.js +0 -212
  235. package/lib/test/loader.spec.js.map +0 -1
  236. package/lib/test/locationRedirectionTests.spec.js +0 -44
  237. package/lib/test/locationRedirectionTests.spec.js.map +0 -1
  238. package/lib/test/serializedStateManager.spec.js +0 -148
  239. package/lib/test/serializedStateManager.spec.js.map +0 -1
  240. package/lib/test/snapshotConversionTest.spec.js +0 -79
  241. package/lib/test/snapshotConversionTest.spec.js.map +0 -1
  242. package/lib/test/types/validateContainerLoaderPrevious.generated.js +0 -38
  243. package/lib/test/types/validateContainerLoaderPrevious.generated.js.map +0 -1
  244. package/lib/test/utils.spec.js +0 -31
  245. package/lib/test/utils.spec.js.map +0 -1
  246. /package/{dist → lib}/tsdoc-metadata.json +0 -0
@@ -5,13 +5,13 @@
5
5
  */
6
6
  Object.defineProperty(exports, "__esModule", { value: true });
7
7
  exports.ConnectionManager = void 0;
8
- const core_interfaces_1 = require("@fluidframework/core-interfaces");
9
- const core_utils_1 = require("@fluidframework/core-utils");
10
8
  const client_utils_1 = require("@fluid-internal/client-utils");
9
+ const core_interfaces_1 = require("@fluidframework/core-interfaces");
10
+ const internal_1 = require("@fluidframework/core-utils/internal");
11
11
  const driver_definitions_1 = require("@fluidframework/driver-definitions");
12
- const driver_utils_1 = require("@fluidframework/driver-utils");
12
+ const internal_2 = require("@fluidframework/driver-utils/internal");
13
13
  const protocol_definitions_1 = require("@fluidframework/protocol-definitions");
14
- const telemetry_utils_1 = require("@fluidframework/telemetry-utils");
14
+ const internal_3 = require("@fluidframework/telemetry-utils/internal");
15
15
  const contracts_js_1 = require("./contracts.js");
16
16
  const deltaQueue_js_1 = require("./deltaQueue.js");
17
17
  const protocol_js_1 = require("./protocol.js");
@@ -24,7 +24,7 @@ function getNackReconnectInfo(nackContent) {
24
24
  const message = `Nack (${nackContent.type}): ${nackContent.message}`;
25
25
  const canRetry = nackContent.code !== 403;
26
26
  const retryAfterMs = nackContent.retryAfter !== undefined ? nackContent.retryAfter * 1000 : undefined;
27
- return (0, driver_utils_1.createGenericNetworkError)(message, { canRetry, retryAfterMs }, { statusCode: nackContent.code, driverVersion: undefined });
27
+ return (0, internal_2.createGenericNetworkError)(message, { canRetry, retryAfterMs }, { statusCode: nackContent.code, driverVersion: undefined });
28
28
  }
29
29
  /**
30
30
  * Implementation of IDocumentDeltaConnection that does not support submitting
@@ -253,7 +253,7 @@ class ConnectionManager {
253
253
  this.nackHandler = (documentId, messages) => {
254
254
  const message = messages[0];
255
255
  if (this._readonlyPermissions === true) {
256
- this.props.closeHandler((0, driver_utils_1.createWriteError)("writeOnReadOnlyDocument", { driverVersion: undefined }));
256
+ this.props.closeHandler((0, internal_2.createWriteError)("writeOnReadOnlyDocument", { driverVersion: undefined }));
257
257
  return;
258
258
  }
259
259
  const reconnectInfo = getNackReconnectInfo(message.content);
@@ -285,7 +285,7 @@ class ConnectionManager {
285
285
  this.connection.submit(messages);
286
286
  });
287
287
  this._outbound.on("error", (error) => {
288
- this.props.closeHandler((0, telemetry_utils_1.normalizeError)(error));
288
+ this.props.closeHandler((0, internal_3.normalizeError)(error));
289
289
  });
290
290
  }
291
291
  dispose(error, switchToReadonly = true) {
@@ -315,7 +315,7 @@ class ConnectionManager {
315
315
  * Will throw an error if reconnectMode set to Never.
316
316
  */
317
317
  setAutoReconnect(mode, reason) {
318
- (0, core_utils_1.assert)(mode !== contracts_js_1.ReconnectMode.Never && this._reconnectMode !== contracts_js_1.ReconnectMode.Never, 0x278 /* "API is not supported for non-connecting or closed container" */);
318
+ (0, internal_1.assert)(mode !== contracts_js_1.ReconnectMode.Never && this._reconnectMode !== contracts_js_1.ReconnectMode.Never, 0x278 /* "API is not supported for non-connecting or closed container" */);
319
319
  this._reconnectMode = mode;
320
320
  if (mode !== contracts_js_1.ReconnectMode.Enabled) {
321
321
  // immediately disconnect - do not rely on service eventually dropping connection.
@@ -336,7 +336,7 @@ class ConnectionManager {
336
336
  this._forceReadonly = readonly;
337
337
  if (oldValue !== this.readonly) {
338
338
  if (this._reconnectMode === contracts_js_1.ReconnectMode.Never) {
339
- throw new telemetry_utils_1.UsageError("API is not supported for non-connecting or closed container");
339
+ throw new internal_3.UsageError("API is not supported for non-connecting or closed container");
340
340
  }
341
341
  let reconnect = false;
342
342
  if (this.readonly === true) {
@@ -365,12 +365,12 @@ class ConnectionManager {
365
365
  }
366
366
  connect(reason, connectionMode) {
367
367
  this.connectCore(reason, connectionMode).catch((e) => {
368
- const normalizedError = (0, telemetry_utils_1.normalizeError)(e, { props: fatalConnectErrorProp });
368
+ const normalizedError = (0, internal_3.normalizeError)(e, { props: fatalConnectErrorProp });
369
369
  this.props.closeHandler(normalizedError);
370
370
  });
371
371
  }
372
372
  async connectCore(reason, connectionMode) {
373
- (0, core_utils_1.assert)(!this._disposed, 0x26a /* "not closed" */);
373
+ (0, internal_1.assert)(!this._disposed, 0x26a /* "not closed" */);
374
374
  if (this.connection !== undefined) {
375
375
  return; // Connection attempt already completed successfully
376
376
  }
@@ -378,7 +378,7 @@ class ConnectionManager {
378
378
  if (this.pendingConnection !== undefined) {
379
379
  pendingConnectionMode = this.pendingConnection.connectionMode;
380
380
  this.cancelConnection(reason); // Throw out in-progress connection attempt in favor of new attempt
381
- (0, core_utils_1.assert)(this.pendingConnection === undefined, 0x344 /* this.pendingConnection should be undefined */);
381
+ (0, internal_1.assert)(this.pendingConnection === undefined, 0x344 /* this.pendingConnection should be undefined */);
382
382
  }
383
383
  // If there is no specified ConnectionMode, try the previous mode, if there is no previous mode use default
384
384
  let requestedMode = connectionMode ?? pendingConnectionMode ?? this.defaultReconnectionMode;
@@ -391,12 +391,13 @@ class ConnectionManager {
391
391
  requestedMode = "write";
392
392
  }
393
393
  const docService = this.serviceProvider();
394
- (0, core_utils_1.assert)(docService !== undefined, 0x2a7 /* "Container is not attached" */);
394
+ (0, internal_1.assert)(docService !== undefined, 0x2a7 /* "Container is not attached" */);
395
+ this.props.establishConnectionHandler(reason);
395
396
  let connection;
396
397
  if (docService.policies?.storageOnly === true) {
397
398
  connection = new NoDeltaStream();
398
399
  this.setupNewSuccessfulConnection(connection, "read", reason);
399
- (0, core_utils_1.assert)(this.pendingConnection === undefined, 0x2b3 /* "logic error" */);
400
+ (0, internal_1.assert)(this.pendingConnection === undefined, 0x2b3 /* "logic error" */);
400
401
  return;
401
402
  }
402
403
  let delayMs = InitialReconnectDelayInMs;
@@ -411,7 +412,6 @@ class ConnectionManager {
411
412
  },
412
413
  connectionMode: requestedMode,
413
414
  };
414
- this.props.establishConnectionHandler(reason);
415
415
  // This loop will keep trying to connect until successful, with a delay between each iteration.
416
416
  while (connection === undefined) {
417
417
  if (this._disposed) {
@@ -421,7 +421,7 @@ class ConnectionManager {
421
421
  this.logger.sendTelemetryEvent({
422
422
  eventName: "ConnectionAttemptCancelled",
423
423
  attempts: connectRepeatCount,
424
- duration: (0, telemetry_utils_1.formatTick)(client_utils_1.performance.now() - connectStartTime),
424
+ duration: (0, internal_3.formatTick)(client_utils_1.performance.now() - connectStartTime),
425
425
  connectionEstablished: false,
426
426
  });
427
427
  return;
@@ -456,7 +456,7 @@ class ConnectionManager {
456
456
  requestedMode = "read";
457
457
  break;
458
458
  }
459
- else if ((0, telemetry_utils_1.isFluidError)(origError) &&
459
+ else if ((0, internal_3.isFluidError)(origError) &&
460
460
  origError.errorType === driver_definitions_1.DriverErrorTypes.outOfStorageError) {
461
461
  // If we get out of storage error from calling joinsession, then use the NoDeltaStream object so
462
462
  // that user can at least load the container.
@@ -468,28 +468,33 @@ class ConnectionManager {
468
468
  break;
469
469
  }
470
470
  // Socket.io error when we connect to wrong socket, or hit some multiplexing bug
471
- if (!(0, driver_utils_1.canRetryOnError)(origError)) {
472
- const error = (0, telemetry_utils_1.normalizeError)(origError, { props: fatalConnectErrorProp });
471
+ if (!(0, internal_2.canRetryOnError)(origError)) {
472
+ const error = (0, internal_3.normalizeError)(origError, { props: fatalConnectErrorProp });
473
473
  this.props.closeHandler(error);
474
474
  throw error;
475
475
  }
476
476
  // Since the error is retryable this will not log to the error table
477
- (0, driver_utils_1.logNetworkFailure)(this.logger, {
477
+ (0, internal_2.logNetworkFailure)(this.logger, {
478
478
  attempts: connectRepeatCount,
479
479
  delay: delayMs,
480
480
  eventName: "DeltaConnectionFailureToConnect",
481
- duration: (0, telemetry_utils_1.formatTick)(client_utils_1.performance.now() - connectStartTime),
481
+ duration: (0, internal_3.formatTick)(client_utils_1.performance.now() - connectStartTime),
482
482
  }, origError);
483
483
  lastError = origError;
484
+ // We will not perform retries if the container disconnected and the ReconnectMode is set to Disabled or Never
485
+ // so break out of the re-connecting while-loop after first attempt
486
+ if (this.reconnectMode !== contracts_js_1.ReconnectMode.Enabled) {
487
+ return;
488
+ }
484
489
  const waitStartTime = client_utils_1.performance.now();
485
- const retryDelayFromError = (0, driver_utils_1.getRetryDelayFromError)(origError);
490
+ const retryDelayFromError = (0, internal_2.getRetryDelayFromError)(origError);
486
491
  // If the error told us to wait or browser signals us that we are offline, then calculate the time we
487
492
  // want to wait for before retrying. then we wait for that time. If the error didn't tell us to wait,
488
493
  // let's still wait a little bit before retrying. We can skip this delay if we're confident we're offline,
489
494
  // because we probably just need to wait to come back online. But we never have strong signal of being
490
495
  // offline, so we at least wait for sometime.
491
496
  if (retryDelayFromError !== undefined || globalThis.navigator?.onLine !== false) {
492
- delayMs = (0, driver_utils_1.calculateMaxWaitTime)(delayMs, origError);
497
+ delayMs = (0, internal_2.calculateMaxWaitTime)(delayMs, origError);
493
498
  }
494
499
  // Raise event in case the delay was there from the error.
495
500
  if (retryDelayFromError !== undefined) {
@@ -514,10 +519,10 @@ class ConnectionManager {
514
519
  }
515
520
  // If we retried more than once, log an event about how long it took (this will not log to error table)
516
521
  if (connectRepeatCount > 1) {
517
- (0, driver_utils_1.logNetworkFailure)(this.logger, {
522
+ (0, internal_2.logNetworkFailure)(this.logger, {
518
523
  eventName: "MultipleDeltaConnectionFailures",
519
524
  attempts: connectRepeatCount,
520
- duration: (0, telemetry_utils_1.formatTick)(client_utils_1.performance.now() - connectStartTime),
525
+ duration: (0, internal_3.formatTick)(client_utils_1.performance.now() - connectStartTime),
521
526
  }, lastError);
522
527
  }
523
528
  // Check for abort signal after while loop as well or we've been disposed
@@ -526,7 +531,7 @@ class ConnectionManager {
526
531
  this.logger.sendTelemetryEvent({
527
532
  eventName: "ConnectionAttemptCancelled",
528
533
  attempts: connectRepeatCount,
529
- duration: (0, telemetry_utils_1.formatTick)(client_utils_1.performance.now() - connectStartTime),
534
+ duration: (0, internal_3.formatTick)(client_utils_1.performance.now() - connectStartTime),
530
535
  connectionEstablished: true,
531
536
  });
532
537
  return;
@@ -565,7 +570,7 @@ class ConnectionManager {
565
570
  }
566
571
  return false;
567
572
  }
568
- (0, core_utils_1.assert)(this.pendingConnection === undefined, 0x27b /* "reentrancy may result in incorrect behavior" */);
573
+ (0, internal_1.assert)(this.pendingConnection === undefined, 0x27b /* "reentrancy may result in incorrect behavior" */);
569
574
  const connection = this.connection;
570
575
  // Avoid any re-entrancy - clear object reference
571
576
  this.connection = undefined;
@@ -588,7 +593,7 @@ class ConnectionManager {
588
593
  * Cancel in-progress connection attempt.
589
594
  */
590
595
  cancelConnection(reason) {
591
- (0, core_utils_1.assert)(this.pendingConnection !== undefined, 0x345 /* this.pendingConnection is undefined when trying to cancel */);
596
+ (0, internal_1.assert)(this.pendingConnection !== undefined, 0x345 /* this.pendingConnection is undefined when trying to cancel */);
592
597
  this.pendingConnection.abort();
593
598
  this.pendingConnection = undefined;
594
599
  this.logger.sendTelemetryEvent({ eventName: "ConnectionCancelReceived" });
@@ -604,8 +609,8 @@ class ConnectionManager {
604
609
  */
605
610
  setupNewSuccessfulConnection(connection, requestedMode, reason) {
606
611
  // Old connection should have been cleaned up before establishing a new one
607
- (0, core_utils_1.assert)(this.connection === undefined, 0x0e6 /* "old connection exists on new connection setup" */);
608
- (0, core_utils_1.assert)(!connection.disposed, 0x28a /* "can't be disposed - Callers need to ensure that!" */);
612
+ (0, internal_1.assert)(this.connection === undefined, 0x0e6 /* "old connection exists on new connection setup" */);
613
+ (0, internal_1.assert)(!connection.disposed, 0x28a /* "can't be disposed - Callers need to ensure that!" */);
609
614
  this.pendingConnection = undefined;
610
615
  const oldReadonlyValue = this.readonly;
611
616
  this.connection = connection;
@@ -622,8 +627,8 @@ class ConnectionManager {
622
627
  }
623
628
  // This connection mode validation logic is moving to the driver layer in 0.44. These two asserts can be
624
629
  // removed after those packages have released and become ubiquitous.
625
- (0, core_utils_1.assert)(requestedMode === "read" || readonly === (this.connectionMode === "read"), 0x0e7 /* "claims/connectionMode mismatch" */);
626
- (0, core_utils_1.assert)(!readonly || this.connectionMode === "read", 0x0e8 /* "readonly perf with write connection" */);
630
+ (0, internal_1.assert)(requestedMode === "read" || readonly === (this.connectionMode === "read"), 0x0e7 /* "claims/connectionMode mismatch" */);
631
+ (0, internal_1.assert)(!readonly || this.connectionMode === "read", 0x0e8 /* "readonly perf with write connection" */);
627
632
  this.set_readonlyPermissions(readonly, oldReadonlyValue, isNoDeltaStreamConnection(connection) ? connection.readonlyConnectionReason : undefined);
628
633
  if (this._disposed) {
629
634
  // Raise proper events, Log telemetry event and close connection.
@@ -725,7 +730,7 @@ class ConnectionManager {
725
730
  // We quite often get protocol errors before / after observing nack/disconnect
726
731
  // we do not want to run through same sequence twice.
727
732
  // If we're already disconnected/disconnecting it's not appropriate to call this again.
728
- (0, core_utils_1.assert)(this.connection !== undefined, 0x0eb /* "Missing connection for reconnect" */);
733
+ (0, internal_1.assert)(this.connection !== undefined, 0x0eb /* "Missing connection for reconnect" */);
729
734
  this.disconnectFromDeltaStream(reason);
730
735
  // We will always trigger reconnect, even if canRetry is false.
731
736
  // Any truly fatal error state will result in container close upon attempted reconnect,
@@ -747,7 +752,7 @@ class ConnectionManager {
747
752
  return;
748
753
  }
749
754
  // If the error tells us to wait before retrying, then do so.
750
- const delayMs = (0, driver_utils_1.getRetryDelayFromError)(reason.error);
755
+ const delayMs = (0, internal_2.getRetryDelayFromError)(reason.error);
751
756
  if (reason.error !== undefined && delayMs !== undefined) {
752
757
  this.props.reconnectionDelayHandler(delayMs, reason.error);
753
758
  await new Promise((resolve) => {
@@ -767,8 +772,8 @@ class ConnectionManager {
767
772
  }
768
773
  prepareMessageToSend(message) {
769
774
  if (this.readonly === true) {
770
- (0, core_utils_1.assert)(this.readOnlyInfo.readonly === true, 0x1f0 /* "Unexpected mismatch in readonly" */);
771
- const error = new telemetry_utils_1.GenericError("deltaManagerReadonlySubmit", undefined /* error */, {
775
+ (0, internal_1.assert)(this.readOnlyInfo.readonly === true, 0x1f0 /* "Unexpected mismatch in readonly" */);
776
+ const error = new internal_3.GenericError("deltaManagerReadonlySubmit", undefined /* error */, {
772
777
  readonly: this.readOnlyInfo.readonly,
773
778
  forcedReadonly: this.readOnlyInfo.forced,
774
779
  readonlyPermissions: this.readOnlyInfo.permissions,
@@ -781,13 +786,13 @@ class ConnectionManager {
781
786
  // reset clientSequenceNumber if we are using new clientId.
782
787
  // we keep info about old connection as long as possible to be able to account for all non-acked ops
783
788
  // that we pick up on next connection.
784
- (0, core_utils_1.assert)(!!this.connection, 0x0e4 /* "Lost old connection!" */);
789
+ (0, internal_1.assert)(!!this.connection, 0x0e4 /* "Lost old connection!" */);
785
790
  if (this.lastSubmittedClientId !== this.connection?.clientId) {
786
791
  this.lastSubmittedClientId = this.connection?.clientId;
787
792
  this.clientSequenceNumber = 0;
788
793
  this.clientSequenceNumberObserved = 0;
789
794
  }
790
- if (!(0, driver_utils_1.isRuntimeMessage)(message)) {
795
+ if (!(0, internal_2.isRuntimeMessage)(message)) {
791
796
  this.localOpsToIgnore++;
792
797
  }
793
798
  else {
@@ -807,7 +812,7 @@ class ConnectionManager {
807
812
  }
808
813
  }
809
814
  sendMessages(messages) {
810
- (0, core_utils_1.assert)(this.connected, 0x2b4 /* "not connected on sending ops!" */);
815
+ (0, internal_1.assert)(this.connected, 0x2b4 /* "not connected on sending ops!" */);
811
816
  // If connection is "read" or implicit "read" (got leave op for "write" connection),
812
817
  // then op can't make it through - we will get a nack if op is sent.
813
818
  // We can short-circuit this process.
@@ -829,17 +834,17 @@ class ConnectionManager {
829
834
  }
830
835
  return;
831
836
  }
832
- (0, core_utils_1.assert)(!this.pendingReconnect, 0x2b5 /* "logic error" */);
837
+ (0, internal_1.assert)(!this.pendingReconnect, 0x2b5 /* "logic error" */);
833
838
  this._outbound.push(messages);
834
839
  }
835
840
  beforeProcessingIncomingOp(message) {
836
841
  // if we have connection, and message is local, then we better treat is as local!
837
- (0, core_utils_1.assert)(this.clientId !== message.clientId || this.lastSubmittedClientId === message.clientId, 0x0ee /* "Not accounting local messages correctly" */);
842
+ (0, internal_1.assert)(this.clientId !== message.clientId || this.lastSubmittedClientId === message.clientId, 0x0ee /* "Not accounting local messages correctly" */);
838
843
  if (this.lastSubmittedClientId !== undefined &&
839
844
  this.lastSubmittedClientId === message.clientId) {
840
845
  const clientSequenceNumber = message.clientSequenceNumber;
841
- (0, core_utils_1.assert)(this.clientSequenceNumberObserved < clientSequenceNumber, 0x0ef /* "client seq# not growing" */);
842
- (0, core_utils_1.assert)(clientSequenceNumber <= this.clientSequenceNumber, 0x0f0 /* "Incoming local client seq# > generated by this client" */);
846
+ (0, internal_1.assert)(this.clientSequenceNumberObserved < clientSequenceNumber, 0x0ef /* "client seq# not growing" */);
847
+ (0, internal_1.assert)(clientSequenceNumber <= this.clientSequenceNumber, 0x0f0 /* "Incoming local client seq# > generated by this client" */);
843
848
  this.clientSequenceNumberObserved = clientSequenceNumber;
844
849
  }
845
850
  if (message.type === protocol_definitions_1.MessageType.ClientLeave) {