@fluidframework/container-runtime 2.0.0-internal.3.0.2 → 2.0.0-internal.3.2.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 (474) hide show
  1. package/.eslintrc.js +19 -19
  2. package/.mocharc.js +2 -2
  3. package/api-extractor.json +2 -2
  4. package/dist/batchTracker.d.ts.map +1 -1
  5. package/dist/batchTracker.js +2 -1
  6. package/dist/batchTracker.js.map +1 -1
  7. package/dist/blobManager.d.ts +15 -2
  8. package/dist/blobManager.d.ts.map +1 -1
  9. package/dist/blobManager.js +109 -37
  10. package/dist/blobManager.js.map +1 -1
  11. package/dist/connectionTelemetry.d.ts.map +1 -1
  12. package/dist/connectionTelemetry.js +11 -9
  13. package/dist/connectionTelemetry.js.map +1 -1
  14. package/dist/containerHandleContext.d.ts.map +1 -1
  15. package/dist/containerHandleContext.js +3 -1
  16. package/dist/containerHandleContext.js.map +1 -1
  17. package/dist/containerRuntime.d.ts +23 -11
  18. package/dist/containerRuntime.d.ts.map +1 -1
  19. package/dist/containerRuntime.js +225 -132
  20. package/dist/containerRuntime.js.map +1 -1
  21. package/dist/dataStore.d.ts.map +1 -1
  22. package/dist/dataStore.js +11 -9
  23. package/dist/dataStore.js.map +1 -1
  24. package/dist/dataStoreContext.d.ts +27 -13
  25. package/dist/dataStoreContext.d.ts.map +1 -1
  26. package/dist/dataStoreContext.js +95 -56
  27. package/dist/dataStoreContext.js.map +1 -1
  28. package/dist/dataStoreContexts.d.ts.map +1 -1
  29. package/dist/dataStoreContexts.js +7 -3
  30. package/dist/dataStoreContexts.js.map +1 -1
  31. package/dist/dataStoreRegistry.d.ts.map +1 -1
  32. package/dist/dataStoreRegistry.js +3 -1
  33. package/dist/dataStoreRegistry.js.map +1 -1
  34. package/dist/dataStores.d.ts +28 -4
  35. package/dist/dataStores.d.ts.map +1 -1
  36. package/dist/dataStores.js +122 -44
  37. package/dist/dataStores.js.map +1 -1
  38. package/dist/deltaScheduler.d.ts.map +1 -1
  39. package/dist/deltaScheduler.js +8 -3
  40. package/dist/deltaScheduler.js.map +1 -1
  41. package/dist/{garbageCollection.d.ts → gc/garbageCollection.d.ts} +27 -203
  42. package/dist/gc/garbageCollection.d.ts.map +1 -0
  43. package/dist/{garbageCollection.js → gc/garbageCollection.js} +210 -400
  44. package/dist/gc/garbageCollection.js.map +1 -0
  45. package/dist/gc/gcDefinitions.d.ts +189 -0
  46. package/dist/gc/gcDefinitions.d.ts.map +1 -0
  47. package/dist/{garbageCollectionConstants.js → gc/gcDefinitions.js} +27 -2
  48. package/dist/gc/gcDefinitions.js.map +1 -0
  49. package/dist/gc/gcHelpers.d.ts +30 -0
  50. package/dist/gc/gcHelpers.d.ts.map +1 -0
  51. package/dist/gc/gcHelpers.js +65 -0
  52. package/dist/gc/gcHelpers.js.map +1 -0
  53. package/dist/gc/gcSummaryStateTracker.d.ts +86 -0
  54. package/dist/gc/gcSummaryStateTracker.d.ts.map +1 -0
  55. package/dist/gc/gcSummaryStateTracker.js +246 -0
  56. package/dist/gc/gcSummaryStateTracker.js.map +1 -0
  57. package/{lib → dist/gc}/gcSweepReadyUsageDetection.d.ts +5 -5
  58. package/dist/gc/gcSweepReadyUsageDetection.d.ts.map +1 -0
  59. package/dist/{gcSweepReadyUsageDetection.js → gc/gcSweepReadyUsageDetection.js} +15 -11
  60. package/dist/gc/gcSweepReadyUsageDetection.js.map +1 -0
  61. package/dist/gc/gcUnreferencedStateTracker.d.ts +34 -0
  62. package/dist/gc/gcUnreferencedStateTracker.d.ts.map +1 -0
  63. package/dist/gc/gcUnreferencedStateTracker.js +94 -0
  64. package/dist/gc/gcUnreferencedStateTracker.js.map +1 -0
  65. package/dist/gc/index.d.ts +11 -0
  66. package/dist/gc/index.d.ts.map +1 -0
  67. package/dist/gc/index.js +40 -0
  68. package/dist/gc/index.js.map +1 -0
  69. package/dist/index.d.ts +2 -5
  70. package/dist/index.d.ts.map +1 -1
  71. package/dist/index.js +6 -9
  72. package/dist/index.js.map +1 -1
  73. package/dist/opLifecycle/batchManager.d.ts +2 -13
  74. package/dist/opLifecycle/batchManager.d.ts.map +1 -1
  75. package/dist/opLifecycle/batchManager.js +19 -41
  76. package/dist/opLifecycle/batchManager.js.map +1 -1
  77. package/dist/opLifecycle/definitions.d.ts +4 -0
  78. package/dist/opLifecycle/definitions.d.ts.map +1 -1
  79. package/dist/opLifecycle/definitions.js.map +1 -1
  80. package/dist/opLifecycle/index.d.ts.map +1 -1
  81. package/dist/opLifecycle/index.js.map +1 -1
  82. package/dist/opLifecycle/opCompressor.d.ts.map +1 -1
  83. package/dist/opLifecycle/opCompressor.js +1 -0
  84. package/dist/opLifecycle/opCompressor.js.map +1 -1
  85. package/dist/opLifecycle/opDecompressor.d.ts.map +1 -1
  86. package/dist/opLifecycle/opDecompressor.js +5 -2
  87. package/dist/opLifecycle/opDecompressor.js.map +1 -1
  88. package/dist/opLifecycle/opSplitter.d.ts +1 -1
  89. package/dist/opLifecycle/opSplitter.d.ts.map +1 -1
  90. package/dist/opLifecycle/opSplitter.js +24 -13
  91. package/dist/opLifecycle/opSplitter.js.map +1 -1
  92. package/dist/opLifecycle/outbox.d.ts +19 -3
  93. package/dist/opLifecycle/outbox.d.ts.map +1 -1
  94. package/dist/opLifecycle/outbox.js +78 -45
  95. package/dist/opLifecycle/outbox.js.map +1 -1
  96. package/dist/opLifecycle/remoteMessageProcessor.d.ts.map +1 -1
  97. package/dist/opLifecycle/remoteMessageProcessor.js.map +1 -1
  98. package/dist/opProperties.d.ts.map +1 -1
  99. package/dist/opProperties.js +1 -3
  100. package/dist/opProperties.js.map +1 -1
  101. package/dist/packageVersion.d.ts +1 -1
  102. package/dist/packageVersion.js +1 -1
  103. package/dist/packageVersion.js.map +1 -1
  104. package/dist/pendingStateManager.d.ts +8 -2
  105. package/dist/pendingStateManager.d.ts.map +1 -1
  106. package/dist/pendingStateManager.js +21 -13
  107. package/dist/pendingStateManager.js.map +1 -1
  108. package/dist/scheduleManager.d.ts.map +1 -1
  109. package/dist/scheduleManager.js +3 -2
  110. package/dist/scheduleManager.js.map +1 -1
  111. package/dist/serializedSnapshotStorage.d.ts +2 -2
  112. package/dist/serializedSnapshotStorage.d.ts.map +1 -1
  113. package/dist/serializedSnapshotStorage.js +5 -3
  114. package/dist/serializedSnapshotStorage.js.map +1 -1
  115. package/dist/summary/index.d.ts +17 -0
  116. package/dist/summary/index.d.ts.map +1 -0
  117. package/dist/summary/index.js +47 -0
  118. package/dist/summary/index.js.map +1 -0
  119. package/dist/summary/orderedClientElection.d.ts.map +1 -0
  120. package/dist/{orderedClientElection.js → summary/orderedClientElection.js} +10 -4
  121. package/dist/summary/orderedClientElection.js.map +1 -0
  122. package/dist/summary/runWhileConnectedCoordinator.d.ts.map +1 -0
  123. package/dist/summary/runWhileConnectedCoordinator.js.map +1 -0
  124. package/{lib → dist/summary}/runningSummarizer.d.ts +19 -18
  125. package/dist/summary/runningSummarizer.d.ts.map +1 -0
  126. package/dist/{runningSummarizer.js → summary/runningSummarizer.js} +191 -76
  127. package/dist/summary/runningSummarizer.js.map +1 -0
  128. package/dist/{summarizer.d.ts → summary/summarizer.d.ts} +4 -6
  129. package/dist/summary/summarizer.d.ts.map +1 -0
  130. package/dist/{summarizer.js → summary/summarizer.js} +31 -71
  131. package/dist/summary/summarizer.js.map +1 -0
  132. package/dist/summary/summarizerClientElection.d.ts.map +1 -0
  133. package/dist/summary/summarizerClientElection.js.map +1 -0
  134. package/dist/summary/summarizerHandle.d.ts.map +1 -0
  135. package/dist/summary/summarizerHandle.js.map +1 -0
  136. package/{lib → dist/summary}/summarizerHeuristics.d.ts +1 -1
  137. package/dist/summary/summarizerHeuristics.d.ts.map +1 -0
  138. package/dist/{summarizerHeuristics.js → summary/summarizerHeuristics.js} +6 -9
  139. package/dist/summary/summarizerHeuristics.js.map +1 -0
  140. package/{lib → dist/summary}/summarizerTypes.d.ts +22 -22
  141. package/dist/summary/summarizerTypes.d.ts.map +1 -0
  142. package/dist/summary/summarizerTypes.js.map +1 -0
  143. package/dist/summary/summaryCollection.d.ts.map +1 -0
  144. package/dist/{summaryCollection.js → summary/summaryCollection.js} +18 -8
  145. package/dist/summary/summaryCollection.js.map +1 -0
  146. package/{lib → dist/summary}/summaryFormat.d.ts +1 -40
  147. package/dist/summary/summaryFormat.d.ts.map +1 -0
  148. package/dist/{summaryFormat.js → summary/summaryFormat.js} +19 -20
  149. package/dist/summary/summaryFormat.js.map +1 -0
  150. package/dist/summary/summaryGenerator.d.ts.map +1 -0
  151. package/dist/{summaryGenerator.js → summary/summaryGenerator.js} +33 -15
  152. package/dist/summary/summaryGenerator.js.map +1 -0
  153. package/dist/{summaryManager.d.ts → summary/summaryManager.d.ts} +1 -1
  154. package/dist/summary/summaryManager.d.ts.map +1 -0
  155. package/dist/{summaryManager.js → summary/summaryManager.js} +21 -9
  156. package/dist/summary/summaryManager.js.map +1 -0
  157. package/dist/throttler.d.ts +2 -2
  158. package/dist/throttler.d.ts.map +1 -1
  159. package/dist/throttler.js +4 -4
  160. package/dist/throttler.js.map +1 -1
  161. package/lib/batchTracker.d.ts.map +1 -1
  162. package/lib/batchTracker.js +2 -1
  163. package/lib/batchTracker.js.map +1 -1
  164. package/lib/blobManager.d.ts +15 -2
  165. package/lib/blobManager.d.ts.map +1 -1
  166. package/lib/blobManager.js +109 -37
  167. package/lib/blobManager.js.map +1 -1
  168. package/lib/connectionTelemetry.d.ts.map +1 -1
  169. package/lib/connectionTelemetry.js +11 -9
  170. package/lib/connectionTelemetry.js.map +1 -1
  171. package/lib/containerHandleContext.d.ts.map +1 -1
  172. package/lib/containerHandleContext.js +3 -1
  173. package/lib/containerHandleContext.js.map +1 -1
  174. package/lib/containerRuntime.d.ts +23 -11
  175. package/lib/containerRuntime.d.ts.map +1 -1
  176. package/lib/containerRuntime.js +201 -108
  177. package/lib/containerRuntime.js.map +1 -1
  178. package/lib/dataStore.d.ts.map +1 -1
  179. package/lib/dataStore.js +11 -9
  180. package/lib/dataStore.js.map +1 -1
  181. package/lib/dataStoreContext.d.ts +27 -13
  182. package/lib/dataStoreContext.d.ts.map +1 -1
  183. package/lib/dataStoreContext.js +84 -45
  184. package/lib/dataStoreContext.js.map +1 -1
  185. package/lib/dataStoreContexts.d.ts.map +1 -1
  186. package/lib/dataStoreContexts.js +7 -3
  187. package/lib/dataStoreContexts.js.map +1 -1
  188. package/lib/dataStoreRegistry.d.ts.map +1 -1
  189. package/lib/dataStoreRegistry.js +3 -1
  190. package/lib/dataStoreRegistry.js.map +1 -1
  191. package/lib/dataStores.d.ts +28 -4
  192. package/lib/dataStores.d.ts.map +1 -1
  193. package/lib/dataStores.js +120 -42
  194. package/lib/dataStores.js.map +1 -1
  195. package/lib/deltaScheduler.d.ts.map +1 -1
  196. package/lib/deltaScheduler.js +9 -4
  197. package/lib/deltaScheduler.js.map +1 -1
  198. package/lib/{garbageCollection.d.ts → gc/garbageCollection.d.ts} +27 -203
  199. package/lib/gc/garbageCollection.d.ts.map +1 -0
  200. package/lib/{garbageCollection.js → gc/garbageCollection.js} +190 -379
  201. package/lib/gc/garbageCollection.js.map +1 -0
  202. package/lib/gc/gcDefinitions.d.ts +189 -0
  203. package/lib/gc/gcDefinitions.d.ts.map +1 -0
  204. package/lib/{garbageCollectionConstants.js → gc/gcDefinitions.js} +26 -1
  205. package/lib/gc/gcDefinitions.js.map +1 -0
  206. package/lib/gc/gcHelpers.d.ts +30 -0
  207. package/lib/gc/gcHelpers.d.ts.map +1 -0
  208. package/lib/gc/gcHelpers.js +58 -0
  209. package/lib/gc/gcHelpers.js.map +1 -0
  210. package/lib/gc/gcSummaryStateTracker.d.ts +86 -0
  211. package/lib/gc/gcSummaryStateTracker.d.ts.map +1 -0
  212. package/lib/gc/gcSummaryStateTracker.js +242 -0
  213. package/lib/gc/gcSummaryStateTracker.js.map +1 -0
  214. package/{dist → lib/gc}/gcSweepReadyUsageDetection.d.ts +5 -5
  215. package/lib/gc/gcSweepReadyUsageDetection.d.ts.map +1 -0
  216. package/lib/{gcSweepReadyUsageDetection.js → gc/gcSweepReadyUsageDetection.js} +15 -11
  217. package/lib/gc/gcSweepReadyUsageDetection.js.map +1 -0
  218. package/lib/gc/gcUnreferencedStateTracker.d.ts +34 -0
  219. package/lib/gc/gcUnreferencedStateTracker.d.ts.map +1 -0
  220. package/lib/gc/gcUnreferencedStateTracker.js +90 -0
  221. package/lib/gc/gcUnreferencedStateTracker.js.map +1 -0
  222. package/lib/gc/index.d.ts +11 -0
  223. package/lib/gc/index.d.ts.map +1 -0
  224. package/lib/gc/index.js +11 -0
  225. package/lib/gc/index.js.map +1 -0
  226. package/lib/index.d.ts +2 -5
  227. package/lib/index.d.ts.map +1 -1
  228. package/lib/index.js +1 -4
  229. package/lib/index.js.map +1 -1
  230. package/lib/opLifecycle/batchManager.d.ts +2 -13
  231. package/lib/opLifecycle/batchManager.d.ts.map +1 -1
  232. package/lib/opLifecycle/batchManager.js +19 -41
  233. package/lib/opLifecycle/batchManager.js.map +1 -1
  234. package/lib/opLifecycle/definitions.d.ts +4 -0
  235. package/lib/opLifecycle/definitions.d.ts.map +1 -1
  236. package/lib/opLifecycle/definitions.js.map +1 -1
  237. package/lib/opLifecycle/index.d.ts.map +1 -1
  238. package/lib/opLifecycle/index.js.map +1 -1
  239. package/lib/opLifecycle/opCompressor.d.ts.map +1 -1
  240. package/lib/opLifecycle/opCompressor.js +1 -0
  241. package/lib/opLifecycle/opCompressor.js.map +1 -1
  242. package/lib/opLifecycle/opDecompressor.d.ts.map +1 -1
  243. package/lib/opLifecycle/opDecompressor.js +5 -2
  244. package/lib/opLifecycle/opDecompressor.js.map +1 -1
  245. package/lib/opLifecycle/opSplitter.d.ts +1 -1
  246. package/lib/opLifecycle/opSplitter.d.ts.map +1 -1
  247. package/lib/opLifecycle/opSplitter.js +25 -14
  248. package/lib/opLifecycle/opSplitter.js.map +1 -1
  249. package/lib/opLifecycle/outbox.d.ts +19 -3
  250. package/lib/opLifecycle/outbox.d.ts.map +1 -1
  251. package/lib/opLifecycle/outbox.js +79 -46
  252. package/lib/opLifecycle/outbox.js.map +1 -1
  253. package/lib/opLifecycle/remoteMessageProcessor.d.ts.map +1 -1
  254. package/lib/opLifecycle/remoteMessageProcessor.js.map +1 -1
  255. package/lib/opProperties.d.ts.map +1 -1
  256. package/lib/opProperties.js +1 -3
  257. package/lib/opProperties.js.map +1 -1
  258. package/lib/packageVersion.d.ts +1 -1
  259. package/lib/packageVersion.js +1 -1
  260. package/lib/packageVersion.js.map +1 -1
  261. package/lib/pendingStateManager.d.ts +8 -2
  262. package/lib/pendingStateManager.d.ts.map +1 -1
  263. package/lib/pendingStateManager.js +21 -13
  264. package/lib/pendingStateManager.js.map +1 -1
  265. package/lib/scheduleManager.d.ts.map +1 -1
  266. package/lib/scheduleManager.js +3 -2
  267. package/lib/scheduleManager.js.map +1 -1
  268. package/lib/serializedSnapshotStorage.d.ts +2 -2
  269. package/lib/serializedSnapshotStorage.d.ts.map +1 -1
  270. package/lib/serializedSnapshotStorage.js +5 -3
  271. package/lib/serializedSnapshotStorage.js.map +1 -1
  272. package/lib/summary/index.d.ts +17 -0
  273. package/lib/summary/index.d.ts.map +1 -0
  274. package/lib/summary/index.js +16 -0
  275. package/lib/summary/index.js.map +1 -0
  276. package/lib/summary/orderedClientElection.d.ts.map +1 -0
  277. package/lib/{orderedClientElection.js → summary/orderedClientElection.js} +10 -4
  278. package/lib/summary/orderedClientElection.js.map +1 -0
  279. package/lib/summary/runWhileConnectedCoordinator.d.ts.map +1 -0
  280. package/lib/summary/runWhileConnectedCoordinator.js.map +1 -0
  281. package/{dist → lib/summary}/runningSummarizer.d.ts +19 -18
  282. package/lib/summary/runningSummarizer.d.ts.map +1 -0
  283. package/lib/{runningSummarizer.js → summary/runningSummarizer.js} +193 -78
  284. package/lib/summary/runningSummarizer.js.map +1 -0
  285. package/lib/{summarizer.d.ts → summary/summarizer.d.ts} +4 -6
  286. package/lib/summary/summarizer.d.ts.map +1 -0
  287. package/lib/{summarizer.js → summary/summarizer.js} +33 -73
  288. package/lib/summary/summarizer.js.map +1 -0
  289. package/lib/summary/summarizerClientElection.d.ts.map +1 -0
  290. package/lib/summary/summarizerClientElection.js.map +1 -0
  291. package/lib/summary/summarizerHandle.d.ts.map +1 -0
  292. package/lib/summary/summarizerHandle.js.map +1 -0
  293. package/{dist → lib/summary}/summarizerHeuristics.d.ts +1 -1
  294. package/lib/summary/summarizerHeuristics.d.ts.map +1 -0
  295. package/lib/{summarizerHeuristics.js → summary/summarizerHeuristics.js} +6 -9
  296. package/lib/summary/summarizerHeuristics.js.map +1 -0
  297. package/{dist → lib/summary}/summarizerTypes.d.ts +22 -22
  298. package/lib/summary/summarizerTypes.d.ts.map +1 -0
  299. package/lib/summary/summarizerTypes.js.map +1 -0
  300. package/lib/summary/summaryCollection.d.ts.map +1 -0
  301. package/lib/{summaryCollection.js → summary/summaryCollection.js} +18 -8
  302. package/lib/summary/summaryCollection.js.map +1 -0
  303. package/{dist → lib/summary}/summaryFormat.d.ts +1 -40
  304. package/lib/summary/summaryFormat.d.ts.map +1 -0
  305. package/lib/{summaryFormat.js → summary/summaryFormat.js} +20 -20
  306. package/lib/summary/summaryFormat.js.map +1 -0
  307. package/lib/summary/summaryGenerator.d.ts.map +1 -0
  308. package/lib/{summaryGenerator.js → summary/summaryGenerator.js} +33 -15
  309. package/lib/summary/summaryGenerator.js.map +1 -0
  310. package/lib/{summaryManager.d.ts → summary/summaryManager.d.ts} +1 -1
  311. package/lib/summary/summaryManager.d.ts.map +1 -0
  312. package/lib/{summaryManager.js → summary/summaryManager.js} +21 -9
  313. package/lib/summary/summaryManager.js.map +1 -0
  314. package/lib/throttler.d.ts +2 -2
  315. package/lib/throttler.d.ts.map +1 -1
  316. package/lib/throttler.js +4 -4
  317. package/lib/throttler.js.map +1 -1
  318. package/package.json +60 -51
  319. package/prettier.config.cjs +1 -1
  320. package/src/batchTracker.ts +54 -49
  321. package/src/blobManager.ts +825 -674
  322. package/src/connectionTelemetry.ts +280 -249
  323. package/src/containerHandleContext.ts +27 -29
  324. package/src/containerRuntime.ts +3249 -2978
  325. package/src/dataStore.ts +172 -159
  326. package/src/dataStoreContext.ts +1141 -1057
  327. package/src/dataStoreContexts.ts +178 -161
  328. package/src/dataStoreRegistry.ts +25 -20
  329. package/src/dataStores.ts +880 -731
  330. package/src/deltaScheduler.ts +158 -150
  331. package/{garbageCollection.md → src/gc/garbageCollection.md} +16 -3
  332. package/src/gc/garbageCollection.ts +1506 -0
  333. package/src/gc/gcDefinitions.ts +244 -0
  334. package/src/gc/gcHelpers.ts +86 -0
  335. package/src/gc/gcSummaryStateTracker.ts +339 -0
  336. package/src/gc/gcSweepReadyUsageDetection.ts +145 -0
  337. package/src/gc/gcUnreferencedStateTracker.ts +114 -0
  338. package/src/gc/index.ts +40 -0
  339. package/src/index.ts +67 -70
  340. package/src/opLifecycle/README.md +152 -0
  341. package/src/opLifecycle/batchManager.ts +101 -144
  342. package/src/opLifecycle/definitions.ts +33 -29
  343. package/src/opLifecycle/index.ts +5 -5
  344. package/src/opLifecycle/opCompressor.ts +55 -53
  345. package/src/opLifecycle/opDecompressor.ts +100 -81
  346. package/src/opLifecycle/opSplitter.ts +233 -188
  347. package/src/opLifecycle/outbox.ts +251 -195
  348. package/src/opLifecycle/remoteMessageProcessor.ts +62 -62
  349. package/src/opProperties.ts +11 -9
  350. package/src/packageVersion.ts +1 -1
  351. package/src/pendingStateManager.ts +396 -338
  352. package/src/scheduleManager.ts +299 -269
  353. package/src/serializedSnapshotStorage.ts +126 -112
  354. package/src/summary/index.ts +99 -0
  355. package/src/summary/orderedClientElection.ts +564 -0
  356. package/src/summary/runWhileConnectedCoordinator.ts +113 -0
  357. package/src/summary/runningSummarizer.ts +788 -0
  358. package/src/summary/summarizer.ts +386 -0
  359. package/src/summary/summarizerClientElection.ts +139 -0
  360. package/src/{summarizerHandle.ts → summary/summarizerHandle.ts} +11 -9
  361. package/src/summary/summarizerHeuristics.ts +219 -0
  362. package/src/summary/summarizerTypes.ts +521 -0
  363. package/src/summary/summaryCollection.ts +450 -0
  364. package/src/summary/summaryFormat.ts +226 -0
  365. package/src/summary/summaryGenerator.ts +505 -0
  366. package/src/summary/summaryManager.ts +423 -0
  367. package/src/throttler.ts +131 -122
  368. package/tsconfig.esnext.json +6 -6
  369. package/tsconfig.json +9 -13
  370. package/dist/garbageCollection.d.ts.map +0 -1
  371. package/dist/garbageCollection.js.map +0 -1
  372. package/dist/garbageCollectionConstants.d.ts +0 -25
  373. package/dist/garbageCollectionConstants.d.ts.map +0 -1
  374. package/dist/garbageCollectionConstants.js.map +0 -1
  375. package/dist/garbageCollectionTombstoneUtils.d.ts +0 -14
  376. package/dist/garbageCollectionTombstoneUtils.d.ts.map +0 -1
  377. package/dist/garbageCollectionTombstoneUtils.js +0 -23
  378. package/dist/garbageCollectionTombstoneUtils.js.map +0 -1
  379. package/dist/gcSweepReadyUsageDetection.d.ts.map +0 -1
  380. package/dist/gcSweepReadyUsageDetection.js.map +0 -1
  381. package/dist/orderedClientElection.d.ts.map +0 -1
  382. package/dist/orderedClientElection.js.map +0 -1
  383. package/dist/runWhileConnectedCoordinator.d.ts.map +0 -1
  384. package/dist/runWhileConnectedCoordinator.js.map +0 -1
  385. package/dist/runningSummarizer.d.ts.map +0 -1
  386. package/dist/runningSummarizer.js.map +0 -1
  387. package/dist/summarizer.d.ts.map +0 -1
  388. package/dist/summarizer.js.map +0 -1
  389. package/dist/summarizerClientElection.d.ts.map +0 -1
  390. package/dist/summarizerClientElection.js.map +0 -1
  391. package/dist/summarizerHandle.d.ts.map +0 -1
  392. package/dist/summarizerHandle.js.map +0 -1
  393. package/dist/summarizerHeuristics.d.ts.map +0 -1
  394. package/dist/summarizerHeuristics.js.map +0 -1
  395. package/dist/summarizerTypes.d.ts.map +0 -1
  396. package/dist/summarizerTypes.js.map +0 -1
  397. package/dist/summaryCollection.d.ts.map +0 -1
  398. package/dist/summaryCollection.js.map +0 -1
  399. package/dist/summaryFormat.d.ts.map +0 -1
  400. package/dist/summaryFormat.js.map +0 -1
  401. package/dist/summaryGenerator.d.ts.map +0 -1
  402. package/dist/summaryGenerator.js.map +0 -1
  403. package/dist/summaryManager.d.ts.map +0 -1
  404. package/dist/summaryManager.js.map +0 -1
  405. package/lib/garbageCollection.d.ts.map +0 -1
  406. package/lib/garbageCollection.js.map +0 -1
  407. package/lib/garbageCollectionConstants.d.ts +0 -25
  408. package/lib/garbageCollectionConstants.d.ts.map +0 -1
  409. package/lib/garbageCollectionConstants.js.map +0 -1
  410. package/lib/garbageCollectionTombstoneUtils.d.ts +0 -14
  411. package/lib/garbageCollectionTombstoneUtils.d.ts.map +0 -1
  412. package/lib/garbageCollectionTombstoneUtils.js +0 -19
  413. package/lib/garbageCollectionTombstoneUtils.js.map +0 -1
  414. package/lib/gcSweepReadyUsageDetection.d.ts.map +0 -1
  415. package/lib/gcSweepReadyUsageDetection.js.map +0 -1
  416. package/lib/orderedClientElection.d.ts.map +0 -1
  417. package/lib/orderedClientElection.js.map +0 -1
  418. package/lib/runWhileConnectedCoordinator.d.ts.map +0 -1
  419. package/lib/runWhileConnectedCoordinator.js.map +0 -1
  420. package/lib/runningSummarizer.d.ts.map +0 -1
  421. package/lib/runningSummarizer.js.map +0 -1
  422. package/lib/summarizer.d.ts.map +0 -1
  423. package/lib/summarizer.js.map +0 -1
  424. package/lib/summarizerClientElection.d.ts.map +0 -1
  425. package/lib/summarizerClientElection.js.map +0 -1
  426. package/lib/summarizerHandle.d.ts.map +0 -1
  427. package/lib/summarizerHandle.js.map +0 -1
  428. package/lib/summarizerHeuristics.d.ts.map +0 -1
  429. package/lib/summarizerHeuristics.js.map +0 -1
  430. package/lib/summarizerTypes.d.ts.map +0 -1
  431. package/lib/summarizerTypes.js.map +0 -1
  432. package/lib/summaryCollection.d.ts.map +0 -1
  433. package/lib/summaryCollection.js.map +0 -1
  434. package/lib/summaryFormat.d.ts.map +0 -1
  435. package/lib/summaryFormat.js.map +0 -1
  436. package/lib/summaryGenerator.d.ts.map +0 -1
  437. package/lib/summaryGenerator.js.map +0 -1
  438. package/lib/summaryManager.d.ts.map +0 -1
  439. package/lib/summaryManager.js.map +0 -1
  440. package/src/garbageCollection.ts +0 -1800
  441. package/src/garbageCollectionConstants.ts +0 -41
  442. package/src/garbageCollectionTombstoneUtils.ts +0 -28
  443. package/src/gcSweepReadyUsageDetection.ts +0 -139
  444. package/src/orderedClientElection.ts +0 -532
  445. package/src/runWhileConnectedCoordinator.ts +0 -106
  446. package/src/runningSummarizer.ts +0 -610
  447. package/src/summarizer.ts +0 -421
  448. package/src/summarizerClientElection.ts +0 -132
  449. package/src/summarizerHeuristics.ts +0 -222
  450. package/src/summarizerTypes.ts +0 -507
  451. package/src/summaryCollection.ts +0 -421
  452. package/src/summaryFormat.ts +0 -256
  453. package/src/summaryGenerator.ts +0 -450
  454. package/src/summaryManager.ts +0 -394
  455. /package/dist/{orderedClientElection.d.ts → summary/orderedClientElection.d.ts} +0 -0
  456. /package/dist/{runWhileConnectedCoordinator.d.ts → summary/runWhileConnectedCoordinator.d.ts} +0 -0
  457. /package/dist/{runWhileConnectedCoordinator.js → summary/runWhileConnectedCoordinator.js} +0 -0
  458. /package/dist/{summarizerClientElection.d.ts → summary/summarizerClientElection.d.ts} +0 -0
  459. /package/dist/{summarizerClientElection.js → summary/summarizerClientElection.js} +0 -0
  460. /package/dist/{summarizerHandle.d.ts → summary/summarizerHandle.d.ts} +0 -0
  461. /package/dist/{summarizerHandle.js → summary/summarizerHandle.js} +0 -0
  462. /package/dist/{summarizerTypes.js → summary/summarizerTypes.js} +0 -0
  463. /package/dist/{summaryCollection.d.ts → summary/summaryCollection.d.ts} +0 -0
  464. /package/dist/{summaryGenerator.d.ts → summary/summaryGenerator.d.ts} +0 -0
  465. /package/lib/{orderedClientElection.d.ts → summary/orderedClientElection.d.ts} +0 -0
  466. /package/lib/{runWhileConnectedCoordinator.d.ts → summary/runWhileConnectedCoordinator.d.ts} +0 -0
  467. /package/lib/{runWhileConnectedCoordinator.js → summary/runWhileConnectedCoordinator.js} +0 -0
  468. /package/lib/{summarizerClientElection.d.ts → summary/summarizerClientElection.d.ts} +0 -0
  469. /package/lib/{summarizerClientElection.js → summary/summarizerClientElection.js} +0 -0
  470. /package/lib/{summarizerHandle.d.ts → summary/summarizerHandle.d.ts} +0 -0
  471. /package/lib/{summarizerHandle.js → summary/summarizerHandle.js} +0 -0
  472. /package/lib/{summarizerTypes.js → summary/summarizerTypes.js} +0 -0
  473. /package/lib/{summaryCollection.d.ts → summary/summaryCollection.d.ts} +0 -0
  474. /package/lib/{summaryGenerator.d.ts → summary/summaryGenerator.d.ts} +0 -0
@@ -6,8 +6,13 @@
6
6
  import { ITelemetryLogger } from "@fluidframework/common-definitions";
7
7
  import { assert } from "@fluidframework/common-utils";
8
8
  import { IContainerContext } from "@fluidframework/container-definitions";
9
- import { GenericError } from "@fluidframework/container-utils";
9
+ import { GenericError, UsageError } from "@fluidframework/container-utils";
10
10
  import { MessageType } from "@fluidframework/protocol-definitions";
11
+ import {
12
+ ChildLogger,
13
+ loggerToMonitoringContext,
14
+ MonitoringContext,
15
+ } from "@fluidframework/telemetry-utils";
11
16
  import { ICompressionRuntimeOptions } from "../containerRuntime";
12
17
  import { PendingStateManager } from "../pendingStateManager";
13
18
  import { BatchManager } from "./batchManager";
@@ -16,203 +21,254 @@ import { OpCompressor } from "./opCompressor";
16
21
  import { OpSplitter } from "./opSplitter";
17
22
 
18
23
  export interface IOutboxConfig {
19
- readonly compressionOptions: ICompressionRuntimeOptions;
20
- // The maximum size of a batch that we can send over the wire.
21
- readonly maxBatchSizeInBytes: number;
22
- readonly enableOpReentryCheck?: boolean;
23
- };
24
+ readonly compressionOptions: ICompressionRuntimeOptions;
25
+ // The maximum size of a batch that we can send over the wire.
26
+ readonly maxBatchSizeInBytes: number;
27
+ readonly disablePartialFlush: boolean;
28
+ }
24
29
 
25
30
  export interface IOutboxParameters {
26
- readonly shouldSend: () => boolean,
27
- readonly pendingStateManager: PendingStateManager,
28
- readonly containerContext: IContainerContext,
29
- readonly config: IOutboxConfig,
30
- readonly compressor: OpCompressor;
31
- readonly splitter: OpSplitter;
32
- readonly logger: ITelemetryLogger;
31
+ readonly shouldSend: () => boolean;
32
+ readonly pendingStateManager: PendingStateManager;
33
+ readonly containerContext: IContainerContext;
34
+ readonly config: IOutboxConfig;
35
+ readonly compressor: OpCompressor;
36
+ readonly splitter: OpSplitter;
37
+ readonly logger: ITelemetryLogger;
33
38
  }
34
39
 
35
40
  export class Outbox {
36
- private readonly attachFlowBatch: BatchManager;
37
- private readonly mainBatch: BatchManager;
38
- private readonly defaultAttachFlowSoftLimitInBytes = 64 * 1024;
39
-
40
- constructor(private readonly params: IOutboxParameters) {
41
- const isCompressionEnabled = this.params.config.compressionOptions.minimumBatchSizeInBytes !== Number.POSITIVE_INFINITY;
42
- // We need to allow infinite size batches if we enable compression
43
- const hardLimit = isCompressionEnabled ? Infinity : this.params.config.maxBatchSizeInBytes;
44
- const softLimit = isCompressionEnabled ? Infinity : this.defaultAttachFlowSoftLimitInBytes;
45
-
46
- this.attachFlowBatch = new BatchManager({
47
- hardLimit,
48
- softLimit,
49
- enableOpReentryCheck: params.config.enableOpReentryCheck,
50
- }, params.logger);
51
- this.mainBatch = new BatchManager({
52
- hardLimit,
53
- enableOpReentryCheck: params.config.enableOpReentryCheck,
54
- }, params.logger);
55
- }
56
-
57
- public get isEmpty(): boolean {
58
- return this.attachFlowBatch.length === 0 && this.mainBatch.length === 0;
59
- }
60
-
61
- public submit(message: BatchMessage) {
62
- if (!this.mainBatch.push(message)) {
63
- throw new GenericError(
64
- "BatchTooLarge",
65
- /* error */ undefined,
66
- {
67
- opSize: (message.contents?.length) ?? 0,
68
- count: this.mainBatch.length,
69
- limit: this.mainBatch.options.hardLimit,
70
- });
71
- }
72
- }
73
-
74
- public submitAttach(message: BatchMessage) {
75
- if (!this.attachFlowBatch.push(message)) {
76
- // BatchManager has two limits - soft limit & hard limit. Soft limit is only engaged
77
- // when queue is not empty.
78
- // Flush queue & retry. Failure on retry would mean - single message is bigger than hard limit
79
- this.flushInternal(this.attachFlowBatch.popBatch());
80
- if (!this.attachFlowBatch.push(message)) {
81
- throw new GenericError(
82
- "BatchTooLarge",
83
- /* error */ undefined,
84
- {
85
- opSize: (message.contents?.length) ?? 0,
86
- count: this.attachFlowBatch.length,
87
- limit: this.attachFlowBatch.options.hardLimit,
88
- });
89
- }
90
- }
91
-
92
- // If compression is enabled, we will always successfully receive
93
- // attach ops and compress then send them at the next JS turn, regardless
94
- // of the overall size of the accumulated ops in the batch.
95
- // However, it is more efficient to flush these ops faster, preferably
96
- // after they reach a size which would benefit from compression.
97
- if (this.attachFlowBatch.contentSizeInBytes >= this.params.config.compressionOptions.minimumBatchSizeInBytes) {
98
- this.flushInternal(this.attachFlowBatch.popBatch());
99
- }
100
- }
101
-
102
- public flush() {
103
- this.flushInternal(this.attachFlowBatch.popBatch());
104
- this.flushInternal(this.mainBatch.popBatch());
105
- }
106
-
107
- private flushInternal(rawBatch: IBatch) {
108
- const processedBatch = this.compressBatch(rawBatch);
109
- const clientSequenceNumber = this.sendBatch(processedBatch);
110
-
111
- this.persistBatch(clientSequenceNumber, rawBatch.content);
112
- }
113
-
114
- private compressBatch(batch: IBatch): IBatch {
115
- if (batch.content.length === 0
116
- || this.params.config.compressionOptions === undefined
117
- || this.params.config.compressionOptions.minimumBatchSizeInBytes > batch.contentSizeInBytes) {
118
- // Nothing to do if the batch is empty or if compression is disabled or if we don't need to compress
119
- return batch;
120
- }
121
-
122
- const compressedBatch = this.params.compressor.compressBatch(batch);
123
- if (compressedBatch.contentSizeInBytes <= this.params.config.maxBatchSizeInBytes) {
124
- // If we don't reach the maximum supported size of a batch, it can safely be sent as is
125
- return compressedBatch;
126
- }
127
-
128
- if (this.params.splitter.isBatchChunkingEnabled) {
129
- return this.params.splitter.splitCompressedBatch(compressedBatch);
130
- }
131
-
132
- // If we've reached this point, the runtime would attempt to send a batch larger than the allowed size
133
- throw new GenericError(
134
- "BatchTooLarge",
135
- /* error */ undefined,
136
- {
137
- opSize: batch.contentSizeInBytes,
138
- count: batch.content.length,
139
- limit: this.params.config.maxBatchSizeInBytes,
140
- compressed: true,
141
- });
142
- }
143
-
144
- /**
145
- * Sends the batch object to the container context to be sent over the wire.
146
- *
147
- * @param batch - batch to be sent
148
- * @returns the client sequence number of the last batched op which was sent and
149
- * -1 if there are no ops or the container cannot send ops.
150
- */
151
- private sendBatch(batch: IBatch): number {
152
- let clientSequenceNumber: number = -1;
153
- const length = batch.content.length;
154
-
155
- // Did we disconnect in the middle of turn-based batch?
156
- // If so, do nothing, as pending state manager will resubmit it correctly on reconnect.
157
- if (length === 0 || !this.params.shouldSend()) {
158
- return clientSequenceNumber;
159
- }
160
-
161
- if (this.params.containerContext.submitBatchFn === undefined) {
162
- // Legacy path - supporting old loader versions. Can be removed only when LTS moves above
163
- // version that has support for batches (submitBatchFn)
164
- for (const message of batch.content) {
165
- // Legacy path doesn't support compressed payloads and will submit uncompressed payload anyways
166
- if (message.metadata?.compressed) {
167
- delete message.metadata.compressed;
168
- }
169
-
170
- clientSequenceNumber = this.params.containerContext.submitFn(
171
- MessageType.Operation,
172
- message.deserializedContent,
173
- true, // batch
174
- message.metadata);
175
- }
176
-
177
- this.params.containerContext.deltaManager.flush();
178
- } else {
179
- // returns clientSequenceNumber of last message in a batch
180
- clientSequenceNumber = this.params.containerContext.submitBatchFn(
181
- batch.content.map((message) => ({
182
- contents: message.contents,
183
- metadata: message.metadata,
184
- compression: message.compression,
185
- })));
186
- }
187
-
188
- // Convert from clientSequenceNumber of last message in the batch to clientSequenceNumber of first message.
189
- clientSequenceNumber -= length - 1;
190
- assert(clientSequenceNumber >= 0, 0x3d0 /* clientSequenceNumber can't be negative */);
191
- return clientSequenceNumber;
192
- }
193
-
194
- private persistBatch(initialClientSequenceNumber: number, batch: BatchMessage[]) {
195
- let clientSequenceNumber = initialClientSequenceNumber;
196
- // Let the PendingStateManager know that a message was submitted.
197
- // In future, need to shift toward keeping batch as a whole!
198
- for (const message of batch) {
199
- this.params.pendingStateManager.onSubmitMessage(
200
- message.deserializedContent.type,
201
- clientSequenceNumber,
202
- message.referenceSequenceNumber,
203
- message.deserializedContent.contents,
204
- message.localOpMetadata,
205
- message.metadata,
206
- );
207
-
208
- clientSequenceNumber++;
209
- }
210
- }
211
-
212
- public checkpoint() {
213
- return {
214
- mainBatch: this.mainBatch.checkpoint(),
215
- attachFlowBatch: this.attachFlowBatch.checkpoint(),
216
- };
217
- }
41
+ private readonly mc: MonitoringContext;
42
+ private readonly attachFlowBatch: BatchManager;
43
+ private readonly mainBatch: BatchManager;
44
+ private readonly defaultAttachFlowSoftLimitInBytes = 320 * 1024;
45
+
46
+ /**
47
+ * Track the number of ops which were detected to have a mismatched
48
+ * reference sequence number, in order to self-throttle the telemetry events.
49
+ *
50
+ * This should be removed as part of ADO:2322
51
+ */
52
+ private readonly maxMismatchedOpsToReport = 3;
53
+ private mismatchedOpsReported = 0;
54
+
55
+ constructor(private readonly params: IOutboxParameters) {
56
+ this.mc = loggerToMonitoringContext(ChildLogger.create(params.logger, "Outbox"));
57
+ const isCompressionEnabled =
58
+ this.params.config.compressionOptions.minimumBatchSizeInBytes !==
59
+ Number.POSITIVE_INFINITY;
60
+ // We need to allow infinite size batches if we enable compression
61
+ const hardLimit = isCompressionEnabled ? Infinity : this.params.config.maxBatchSizeInBytes;
62
+ const softLimit = isCompressionEnabled ? Infinity : this.defaultAttachFlowSoftLimitInBytes;
63
+
64
+ this.attachFlowBatch = new BatchManager({ hardLimit, softLimit });
65
+ this.mainBatch = new BatchManager({ hardLimit });
66
+ }
67
+
68
+ public get isEmpty(): boolean {
69
+ return this.attachFlowBatch.length === 0 && this.mainBatch.length === 0;
70
+ }
71
+
72
+ /**
73
+ * If we detect that the reference sequence number of the incoming message does not match
74
+ * what was already in the batch managers, this means that batching has been interrupted so
75
+ * we will flush the accumulated messages to account for that and create a new batch with the new
76
+ * message as the first message.
77
+ *
78
+ * @param message - the incoming message
79
+ */
80
+ private maybeFlushPartialBatch(message: BatchMessage) {
81
+ const mainBatchReference = this.mainBatch.referenceSequenceNumber;
82
+ const attachFlowBatchReference = this.attachFlowBatch.referenceSequenceNumber;
83
+ assert(
84
+ this.params.config.disablePartialFlush ||
85
+ mainBatchReference === undefined ||
86
+ attachFlowBatchReference === undefined ||
87
+ mainBatchReference === attachFlowBatchReference,
88
+ 0x58d /* Reference sequence numbers from both batches must be in sync */,
89
+ );
90
+
91
+ if (
92
+ (mainBatchReference === undefined ||
93
+ mainBatchReference === message.referenceSequenceNumber) &&
94
+ (attachFlowBatchReference === undefined ||
95
+ attachFlowBatchReference === message.referenceSequenceNumber)
96
+ ) {
97
+ // The reference sequence numbers are stable, there is nothing to do
98
+ return;
99
+ }
100
+
101
+ if (++this.mismatchedOpsReported <= this.maxMismatchedOpsToReport) {
102
+ this.mc.logger.sendErrorEvent(
103
+ {
104
+ eventName: "ReferenceSequenceNumberMismatch",
105
+ mainReferenceSequenceNumber: mainBatchReference,
106
+ attachReferenceSequenceNumber: attachFlowBatchReference,
107
+ messageReferenceSequenceNumber: message.referenceSequenceNumber,
108
+ },
109
+ new UsageError("Submission of an out of order message"),
110
+ );
111
+ }
112
+
113
+ if (!this.params.config.disablePartialFlush) {
114
+ this.flush();
115
+ }
116
+ }
117
+
118
+ public submit(message: BatchMessage) {
119
+ this.maybeFlushPartialBatch(message);
120
+
121
+ if (!this.mainBatch.push(message)) {
122
+ throw new GenericError("BatchTooLarge", /* error */ undefined, {
123
+ opSize: message.contents?.length ?? 0,
124
+ batchSize: this.mainBatch.contentSizeInBytes,
125
+ count: this.mainBatch.length,
126
+ limit: this.mainBatch.options.hardLimit,
127
+ });
128
+ }
129
+ }
130
+
131
+ public submitAttach(message: BatchMessage) {
132
+ this.maybeFlushPartialBatch(message);
133
+
134
+ if (!this.attachFlowBatch.push(message)) {
135
+ // BatchManager has two limits - soft limit & hard limit. Soft limit is only engaged
136
+ // when queue is not empty.
137
+ // Flush queue & retry. Failure on retry would mean - single message is bigger than hard limit
138
+ this.flushInternal(this.attachFlowBatch.popBatch());
139
+ if (!this.attachFlowBatch.push(message)) {
140
+ throw new GenericError("BatchTooLarge", /* error */ undefined, {
141
+ opSize: message.contents?.length ?? 0,
142
+ batchSize: this.attachFlowBatch.contentSizeInBytes,
143
+ count: this.attachFlowBatch.length,
144
+ limit: this.attachFlowBatch.options.hardLimit,
145
+ });
146
+ }
147
+ }
148
+
149
+ // If compression is enabled, we will always successfully receive
150
+ // attach ops and compress then send them at the next JS turn, regardless
151
+ // of the overall size of the accumulated ops in the batch.
152
+ // However, it is more efficient to flush these ops faster, preferably
153
+ // after they reach a size which would benefit from compression.
154
+ if (
155
+ this.attachFlowBatch.contentSizeInBytes >=
156
+ this.params.config.compressionOptions.minimumBatchSizeInBytes
157
+ ) {
158
+ this.flushInternal(this.attachFlowBatch.popBatch());
159
+ }
160
+ }
161
+
162
+ public flush() {
163
+ this.flushInternal(this.attachFlowBatch.popBatch());
164
+ this.flushInternal(this.mainBatch.popBatch());
165
+ }
166
+
167
+ private flushInternal(rawBatch: IBatch) {
168
+ const processedBatch = this.compressBatch(rawBatch);
169
+ this.sendBatch(processedBatch);
170
+
171
+ this.persistBatch(rawBatch.content);
172
+ }
173
+
174
+ private compressBatch(batch: IBatch): IBatch {
175
+ if (
176
+ batch.content.length === 0 ||
177
+ this.params.config.compressionOptions === undefined ||
178
+ this.params.config.compressionOptions.minimumBatchSizeInBytes > batch.contentSizeInBytes
179
+ ) {
180
+ // Nothing to do if the batch is empty or if compression is disabled or if we don't need to compress
181
+ return batch;
182
+ }
183
+
184
+ const compressedBatch = this.params.compressor.compressBatch(batch);
185
+ if (compressedBatch.contentSizeInBytes <= this.params.config.maxBatchSizeInBytes) {
186
+ // If we don't reach the maximum supported size of a batch, it can safely be sent as is
187
+ return compressedBatch;
188
+ }
189
+
190
+ if (this.params.splitter.isBatchChunkingEnabled) {
191
+ return this.params.splitter.splitCompressedBatch(compressedBatch);
192
+ }
193
+
194
+ // If we've reached this point, the runtime would attempt to send a batch larger than the allowed size
195
+ throw new GenericError("BatchTooLarge", /* error */ undefined, {
196
+ batchSize: batch.contentSizeInBytes,
197
+ compressedBatchSize: compressedBatch.contentSizeInBytes,
198
+ count: compressedBatch.content.length,
199
+ limit: this.params.config.maxBatchSizeInBytes,
200
+ chunkingEnabled: this.params.splitter.isBatchChunkingEnabled,
201
+ compressionOptions: JSON.stringify(this.params.config.compressionOptions),
202
+ });
203
+ }
204
+
205
+ /**
206
+ * Sends the batch object to the container context to be sent over the wire.
207
+ *
208
+ * @param batch - batch to be sent
209
+ */
210
+ private sendBatch(batch: IBatch) {
211
+ const length = batch.content.length;
212
+
213
+ // Did we disconnect in the middle of turn-based batch?
214
+ // If so, do nothing, as pending state manager will resubmit it correctly on reconnect.
215
+ if (length === 0 || !this.params.shouldSend()) {
216
+ return;
217
+ }
218
+
219
+ if (this.params.containerContext.submitBatchFn === undefined) {
220
+ // Legacy path - supporting old loader versions. Can be removed only when LTS moves above
221
+ // version that has support for batches (submitBatchFn)
222
+ for (const message of batch.content) {
223
+ // Legacy path doesn't support compressed payloads and will submit uncompressed payload anyways
224
+ if (message.metadata?.compressed) {
225
+ delete message.metadata.compressed;
226
+ }
227
+
228
+ this.params.containerContext.submitFn(
229
+ MessageType.Operation,
230
+ message.deserializedContent,
231
+ true, // batch
232
+ message.metadata,
233
+ );
234
+ }
235
+
236
+ this.params.containerContext.deltaManager.flush();
237
+ } else {
238
+ assert(
239
+ batch.referenceSequenceNumber !== undefined,
240
+ 0x58e /* Batch must not be empty */,
241
+ );
242
+ this.params.containerContext.submitBatchFn(
243
+ batch.content.map((message) => ({
244
+ contents: message.contents,
245
+ metadata: message.metadata,
246
+ compression: message.compression,
247
+ referenceSequenceNumber: message.referenceSequenceNumber,
248
+ })),
249
+ batch.referenceSequenceNumber,
250
+ );
251
+ }
252
+ }
253
+
254
+ private persistBatch(batch: BatchMessage[]) {
255
+ // Let the PendingStateManager know that a message was submitted.
256
+ // In future, need to shift toward keeping batch as a whole!
257
+ for (const message of batch) {
258
+ this.params.pendingStateManager.onSubmitMessage(
259
+ message.deserializedContent.type,
260
+ message.referenceSequenceNumber,
261
+ message.deserializedContent.contents,
262
+ message.localOpMetadata,
263
+ message.metadata,
264
+ );
265
+ }
266
+ }
267
+
268
+ public checkpoint() {
269
+ return {
270
+ mainBatch: this.mainBatch.checkpoint(),
271
+ attachFlowBatch: this.attachFlowBatch.checkpoint(),
272
+ };
273
+ }
218
274
  }
@@ -9,61 +9,61 @@ import { OpDecompressor } from "./opDecompressor";
9
9
  import { OpSplitter } from "./opSplitter";
10
10
 
11
11
  export class RemoteMessageProcessor {
12
- constructor(
13
- private readonly opSplitter: OpSplitter,
14
- private readonly opDecompressor: OpDecompressor,
15
- ) { }
12
+ constructor(
13
+ private readonly opSplitter: OpSplitter,
14
+ private readonly opDecompressor: OpDecompressor,
15
+ ) {}
16
16
 
17
- public get partialMessages(): ReadonlyMap<string, string[]> {
18
- return this.opSplitter.chunks;
19
- }
17
+ public get partialMessages(): ReadonlyMap<string, string[]> {
18
+ return this.opSplitter.chunks;
19
+ }
20
20
 
21
- public clearPartialMessagesFor(clientId: string) {
22
- this.opSplitter.clearPartialChunks(clientId);
23
- }
21
+ public clearPartialMessagesFor(clientId: string) {
22
+ this.opSplitter.clearPartialChunks(clientId);
23
+ }
24
24
 
25
- public process(remoteMessage: ISequencedDocumentMessage): ISequencedDocumentMessage {
26
- let message = copy(remoteMessage);
27
- message = this.opDecompressor.processMessage(message).message;
28
- unpackRuntimeMessage(message);
25
+ public process(remoteMessage: ISequencedDocumentMessage): ISequencedDocumentMessage {
26
+ let message = copy(remoteMessage);
27
+ message = this.opDecompressor.processMessage(message).message;
28
+ unpackRuntimeMessage(message);
29
29
 
30
- const chunkProcessingResult = this.opSplitter.processRemoteMessage(message);
31
- message = chunkProcessingResult.message;
32
- if (chunkProcessingResult.state !== "Processed") {
33
- // If the message is not chunked or if the splitter is still rebuilding the original message,
34
- // there is no need to continue processing
35
- return message;
36
- }
30
+ const chunkProcessingResult = this.opSplitter.processRemoteMessage(message);
31
+ message = chunkProcessingResult.message;
32
+ if (chunkProcessingResult.state !== "Processed") {
33
+ // If the message is not chunked or if the splitter is still rebuilding the original message,
34
+ // there is no need to continue processing
35
+ return message;
36
+ }
37
37
 
38
- const decompressionAfterChunking = this.opDecompressor.processMessage(message);
39
- message = decompressionAfterChunking.message;
40
- if (decompressionAfterChunking.state === "Skipped") {
41
- // After chunking, if the original message was not compressed,
42
- // there is no need to continue processing
43
- return message;
44
- }
38
+ const decompressionAfterChunking = this.opDecompressor.processMessage(message);
39
+ message = decompressionAfterChunking.message;
40
+ if (decompressionAfterChunking.state === "Skipped") {
41
+ // After chunking, if the original message was not compressed,
42
+ // there is no need to continue processing
43
+ return message;
44
+ }
45
45
 
46
- // The message needs to be unpacked after chunking + decompression
47
- unpack(message);
48
- return message;
49
- }
46
+ // The message needs to be unpacked after chunking + decompression
47
+ unpack(message);
48
+ return message;
49
+ }
50
50
  }
51
51
 
52
52
  const copy = (remoteMessage: ISequencedDocumentMessage): ISequencedDocumentMessage => {
53
- // Do shallow copy of message, as the processing flow will modify it.
54
- // There might be multiple container instances receiving same message
55
- // We do not need to make deep copy, as each layer will just replace message.content itself,
56
- // but would not modify contents details
57
- const message = { ...remoteMessage };
53
+ // Do shallow copy of message, as the processing flow will modify it.
54
+ // There might be multiple container instances receiving same message
55
+ // We do not need to make deep copy, as each layer will just replace message.content itself,
56
+ // but would not modify contents details
57
+ const message = { ...remoteMessage };
58
58
 
59
- // back-compat: ADO #1385: eventually should become unconditional, but only for runtime messages!
60
- // System message may have no contents, or in some cases (mostly for back-compat) they may have actual objects.
61
- // Old ops may contain empty string (I assume noops).
62
- if (typeof message.contents === "string" && message.contents !== "") {
63
- message.contents = JSON.parse(message.contents);
64
- }
59
+ // back-compat: ADO #1385: eventually should become unconditional, but only for runtime messages!
60
+ // System message may have no contents, or in some cases (mostly for back-compat) they may have actual objects.
61
+ // Old ops may contain empty string (I assume noops).
62
+ if (typeof message.contents === "string" && message.contents !== "") {
63
+ message.contents = JSON.parse(message.contents);
64
+ }
65
65
 
66
- return message;
66
+ return message;
67
67
  };
68
68
 
69
69
  /**
@@ -71,9 +71,9 @@ const copy = (remoteMessage: ISequencedDocumentMessage): ISequencedDocumentMessa
71
71
  *
72
72
  */
73
73
  const unpack = (message: ISequencedDocumentMessage) => {
74
- const innerContents = message.contents as ContainerRuntimeMessage;
75
- message.type = innerContents.type;
76
- message.contents = innerContents.contents;
74
+ const innerContents = message.contents as ContainerRuntimeMessage;
75
+ message.type = innerContents.type;
76
+ message.contents = innerContents.contents;
77
77
  };
78
78
 
79
79
  /**
@@ -86,21 +86,21 @@ const unpack = (message: ISequencedDocumentMessage) => {
86
86
  * @internal
87
87
  */
88
88
  export function unpackRuntimeMessage(message: ISequencedDocumentMessage): boolean {
89
- if (message.type !== MessageType.Operation) {
90
- // Legacy format, but it's already "unpacked",
91
- // i.e. message.type is actually ContainerMessageType.
92
- // Or it's non-runtime message.
93
- // Nothing to do in such case.
94
- return false;
95
- }
89
+ if (message.type !== MessageType.Operation) {
90
+ // Legacy format, but it's already "unpacked",
91
+ // i.e. message.type is actually ContainerMessageType.
92
+ // Or it's non-runtime message.
93
+ // Nothing to do in such case.
94
+ return false;
95
+ }
96
96
 
97
- // legacy op format?
98
- if (message.contents.address !== undefined && message.contents.type === undefined) {
99
- message.type = ContainerMessageType.FluidDataStoreOp;
100
- } else {
101
- // new format
102
- unpack(message);
103
- }
97
+ // legacy op format?
98
+ if (message.contents.address !== undefined && message.contents.type === undefined) {
99
+ message.type = ContainerMessageType.FluidDataStoreOp;
100
+ } else {
101
+ // new format
102
+ unpack(message);
103
+ }
104
104
 
105
- return true;
105
+ return true;
106
106
  }