@azure/cosmos 4.5.0-alpha.20250717.1 → 4.5.0-alpha.20250729.1

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 (1219) hide show
  1. package/dist/browser/ChangeFeedIterator.js +17 -11
  2. package/dist/browser/ChangeFeedIterator.js.map +1 -1
  3. package/dist/browser/ChangeFeedResponse.js +8 -0
  4. package/dist/browser/ChangeFeedResponse.js.map +1 -1
  5. package/dist/browser/ClientContext.js +122 -29
  6. package/dist/browser/ClientContext.js.map +1 -1
  7. package/dist/browser/CosmosClient.d.ts.map +1 -1
  8. package/dist/browser/CosmosClient.js +37 -3
  9. package/dist/browser/CosmosClient.js.map +1 -1
  10. package/dist/browser/CosmosDiagnostics.js +3 -0
  11. package/dist/browser/CosmosDiagnostics.js.map +1 -1
  12. package/dist/browser/PartitionKeyRangeFailoverInfo.js +8 -5
  13. package/dist/browser/PartitionKeyRangeFailoverInfo.js.map +1 -1
  14. package/dist/browser/bulk/Batcher.js +13 -3
  15. package/dist/browser/bulk/Batcher.js.map +1 -1
  16. package/dist/browser/bulk/BulkHelper.js +26 -11
  17. package/dist/browser/bulk/BulkHelper.js.map +1 -1
  18. package/dist/browser/bulk/BulkResponse.js +22 -20
  19. package/dist/browser/bulk/BulkResponse.js.map +1 -1
  20. package/dist/browser/bulk/CongestionAlgorithm.js +11 -4
  21. package/dist/browser/bulk/CongestionAlgorithm.js.map +1 -1
  22. package/dist/browser/bulk/HelperPerPartition.js +14 -1
  23. package/dist/browser/bulk/HelperPerPartition.js.map +1 -1
  24. package/dist/browser/bulk/ItemOperationContext.js +4 -0
  25. package/dist/browser/bulk/ItemOperationContext.js.map +1 -1
  26. package/dist/browser/bulk/Limiter.js +27 -18
  27. package/dist/browser/bulk/Limiter.js.map +1 -1
  28. package/dist/browser/bulk/PartitionMetric.js +4 -0
  29. package/dist/browser/bulk/PartitionMetric.js.map +1 -1
  30. package/dist/browser/client/ChangeFeed/ChangeFeedForEpkRange.js +26 -15
  31. package/dist/browser/client/ChangeFeed/ChangeFeedForEpkRange.js.map +1 -1
  32. package/dist/browser/client/ChangeFeed/ChangeFeedForPartitionKey.d.ts.map +1 -1
  33. package/dist/browser/client/ChangeFeed/ChangeFeedForPartitionKey.js +20 -8
  34. package/dist/browser/client/ChangeFeed/ChangeFeedForPartitionKey.js.map +1 -1
  35. package/dist/browser/client/ChangeFeed/ChangeFeedIteratorBuilder.js +12 -9
  36. package/dist/browser/client/ChangeFeed/ChangeFeedIteratorBuilder.js.map +1 -1
  37. package/dist/browser/client/ChangeFeed/ChangeFeedIteratorResponse.js +9 -0
  38. package/dist/browser/client/ChangeFeed/ChangeFeedIteratorResponse.js.map +1 -1
  39. package/dist/browser/client/ChangeFeed/ChangeFeedPolicy.js +1 -0
  40. package/dist/browser/client/ChangeFeed/ChangeFeedPolicy.js.map +1 -1
  41. package/dist/browser/client/ChangeFeed/ChangeFeedRange.js +20 -0
  42. package/dist/browser/client/ChangeFeed/ChangeFeedRange.js.map +1 -1
  43. package/dist/browser/client/ChangeFeed/ChangeFeedRetentionTimeSpan.js +1 -0
  44. package/dist/browser/client/ChangeFeed/ChangeFeedRetentionTimeSpan.js.map +1 -1
  45. package/dist/browser/client/ChangeFeed/ChangeFeedStartFromBeginning.js +1 -0
  46. package/dist/browser/client/ChangeFeed/ChangeFeedStartFromBeginning.js.map +1 -1
  47. package/dist/browser/client/ChangeFeed/ChangeFeedStartFromContinuation.js +1 -0
  48. package/dist/browser/client/ChangeFeed/ChangeFeedStartFromContinuation.js.map +1 -1
  49. package/dist/browser/client/ChangeFeed/ChangeFeedStartFromNow.js +1 -0
  50. package/dist/browser/client/ChangeFeed/ChangeFeedStartFromNow.js.map +1 -1
  51. package/dist/browser/client/ChangeFeed/ChangeFeedStartFromTime.js +2 -0
  52. package/dist/browser/client/ChangeFeed/ChangeFeedStartFromTime.js.map +1 -1
  53. package/dist/browser/client/ChangeFeed/CompositeContinuationToken.js +8 -0
  54. package/dist/browser/client/ChangeFeed/CompositeContinuationToken.js.map +1 -1
  55. package/dist/browser/client/ChangeFeed/ContinuationTokenForPartitionKey.js +12 -0
  56. package/dist/browser/client/ChangeFeed/ContinuationTokenForPartitionKey.js.map +1 -1
  57. package/dist/browser/client/ChangeFeed/FeedRange.js +8 -0
  58. package/dist/browser/client/ChangeFeed/FeedRange.js.map +1 -1
  59. package/dist/browser/client/ChangeFeed/FeedRangeQueue.js +1 -0
  60. package/dist/browser/client/ChangeFeed/FeedRangeQueue.js.map +1 -1
  61. package/dist/browser/client/ChangeFeed/changeFeedUtils.js +5 -5
  62. package/dist/browser/client/ChangeFeed/changeFeedUtils.js.map +1 -1
  63. package/dist/browser/client/ClientUtils.js +1 -1
  64. package/dist/browser/client/ClientUtils.js.map +1 -1
  65. package/dist/browser/client/Conflict/Conflict.js +4 -0
  66. package/dist/browser/client/Conflict/Conflict.js.map +1 -1
  67. package/dist/browser/client/Conflict/ConflictResponse.js +2 -0
  68. package/dist/browser/client/Conflict/ConflictResponse.js.map +1 -1
  69. package/dist/browser/client/Conflict/Conflicts.js +2 -0
  70. package/dist/browser/client/Conflict/Conflicts.js.map +1 -1
  71. package/dist/browser/client/Container/Container.js +18 -3
  72. package/dist/browser/client/Container/Container.js.map +1 -1
  73. package/dist/browser/client/Container/ContainerResponse.js +2 -0
  74. package/dist/browser/client/Container/ContainerResponse.js.map +1 -1
  75. package/dist/browser/client/Container/Containers.js +4 -2
  76. package/dist/browser/client/Container/Containers.js.map +1 -1
  77. package/dist/browser/client/Database/Database.js +33 -0
  78. package/dist/browser/client/Database/Database.js.map +1 -1
  79. package/dist/browser/client/Database/DatabaseResponse.js +2 -0
  80. package/dist/browser/client/Database/DatabaseResponse.js.map +1 -1
  81. package/dist/browser/client/Database/Databases.js +3 -0
  82. package/dist/browser/client/Database/Databases.js.map +1 -1
  83. package/dist/browser/client/Item/Item.js +4 -0
  84. package/dist/browser/client/Item/Item.js.map +1 -1
  85. package/dist/browser/client/Item/ItemResponse.js +2 -0
  86. package/dist/browser/client/Item/ItemResponse.js.map +1 -1
  87. package/dist/browser/client/Item/Items.d.ts.map +1 -1
  88. package/dist/browser/client/Item/Items.js +12 -0
  89. package/dist/browser/client/Item/Items.js.map +1 -1
  90. package/dist/browser/client/Offer/Offer.js +3 -0
  91. package/dist/browser/client/Offer/Offer.js.map +1 -1
  92. package/dist/browser/client/Offer/OfferResponse.js +2 -0
  93. package/dist/browser/client/Offer/OfferResponse.js.map +1 -1
  94. package/dist/browser/client/Offer/Offers.js +2 -0
  95. package/dist/browser/client/Offer/Offers.js.map +1 -1
  96. package/dist/browser/client/Permission/Permission.js +3 -0
  97. package/dist/browser/client/Permission/Permission.js.map +1 -1
  98. package/dist/browser/client/Permission/PermissionResponse.js +2 -0
  99. package/dist/browser/client/Permission/PermissionResponse.js.map +1 -1
  100. package/dist/browser/client/Permission/Permissions.js +2 -0
  101. package/dist/browser/client/Permission/Permissions.js.map +1 -1
  102. package/dist/browser/client/SasToken/SasTokenProperties.js +17 -0
  103. package/dist/browser/client/SasToken/SasTokenProperties.js.map +1 -1
  104. package/dist/browser/client/Script/Scripts.js +5 -0
  105. package/dist/browser/client/Script/Scripts.js.map +1 -1
  106. package/dist/browser/client/StoredProcedure/StoredProcedure.js +3 -0
  107. package/dist/browser/client/StoredProcedure/StoredProcedure.js.map +1 -1
  108. package/dist/browser/client/StoredProcedure/StoredProcedureResponse.js +4 -0
  109. package/dist/browser/client/StoredProcedure/StoredProcedureResponse.js.map +1 -1
  110. package/dist/browser/client/StoredProcedure/StoredProcedures.js +2 -0
  111. package/dist/browser/client/StoredProcedure/StoredProcedures.js.map +1 -1
  112. package/dist/browser/client/Trigger/Trigger.js +3 -0
  113. package/dist/browser/client/Trigger/Trigger.js.map +1 -1
  114. package/dist/browser/client/Trigger/TriggerResponse.js +2 -0
  115. package/dist/browser/client/Trigger/TriggerResponse.js.map +1 -1
  116. package/dist/browser/client/Trigger/Triggers.js +2 -0
  117. package/dist/browser/client/Trigger/Triggers.js.map +1 -1
  118. package/dist/browser/client/User/User.js +9 -0
  119. package/dist/browser/client/User/User.js.map +1 -1
  120. package/dist/browser/client/User/UserResponse.js +2 -0
  121. package/dist/browser/client/User/UserResponse.js.map +1 -1
  122. package/dist/browser/client/User/Users.js +2 -0
  123. package/dist/browser/client/User/Users.js.map +1 -1
  124. package/dist/browser/client/UserDefinedFunction/UserDefinedFunction.js +3 -0
  125. package/dist/browser/client/UserDefinedFunction/UserDefinedFunction.js.map +1 -1
  126. package/dist/browser/client/UserDefinedFunction/UserDefinedFunctionResponse.js +2 -0
  127. package/dist/browser/client/UserDefinedFunction/UserDefinedFunctionResponse.js.map +1 -1
  128. package/dist/browser/client/UserDefinedFunction/UserDefinedFunctions.js +2 -0
  129. package/dist/browser/client/UserDefinedFunction/UserDefinedFunctions.js.map +1 -1
  130. package/dist/browser/diagnostics/CosmosDiagnosticsContext.js +8 -7
  131. package/dist/browser/diagnostics/CosmosDiagnosticsContext.js.map +1 -1
  132. package/dist/browser/diagnostics/DiagnosticNodeInternal.js +26 -7
  133. package/dist/browser/diagnostics/DiagnosticNodeInternal.js.map +1 -1
  134. package/dist/browser/diagnostics/DiagnosticWriter.js +1 -3
  135. package/dist/browser/diagnostics/DiagnosticWriter.js.map +1 -1
  136. package/dist/browser/diagnostics/index.js +2 -2
  137. package/dist/browser/diagnostics/index.js.map +1 -1
  138. package/dist/browser/documents/DatabaseAccount.js +20 -4
  139. package/dist/browser/documents/DatabaseAccount.js.map +1 -1
  140. package/dist/browser/documents/PartitionKey.js +1 -3
  141. package/dist/browser/documents/PartitionKey.js.map +1 -1
  142. package/dist/browser/encryption/Cache/ClientEncryptionKeyPropertiesCache.js +2 -0
  143. package/dist/browser/encryption/Cache/ClientEncryptionKeyPropertiesCache.js.map +1 -1
  144. package/dist/browser/encryption/Cache/EncryptionSettingsCache.js +2 -0
  145. package/dist/browser/encryption/Cache/EncryptionSettingsCache.js.map +1 -1
  146. package/dist/browser/encryption/Cache/KeyEncryptionKeyCache.js +2 -0
  147. package/dist/browser/encryption/Cache/KeyEncryptionKeyCache.js.map +1 -1
  148. package/dist/browser/encryption/ClientEncryptionKey/ClientEncryptionKeyResponse.js +2 -0
  149. package/dist/browser/encryption/ClientEncryptionKey/ClientEncryptionKeyResponse.js.map +1 -1
  150. package/dist/browser/encryption/EncryptionItemQueryIterator.js +24 -27
  151. package/dist/browser/encryption/EncryptionItemQueryIterator.js.map +1 -1
  152. package/dist/browser/encryption/EncryptionKey/ProtectedDataEncryptionKey.d.ts +0 -1
  153. package/dist/browser/encryption/EncryptionKey/ProtectedDataEncryptionKey.d.ts.map +1 -1
  154. package/dist/browser/encryption/EncryptionKey/ProtectedDataEncryptionKey.js +2 -0
  155. package/dist/browser/encryption/EncryptionKey/ProtectedDataEncryptionKey.js.map +1 -1
  156. package/dist/browser/encryption/EncryptionKeyResolver/AzureKeyVaultEncryptionKeyResolver.js +6 -5
  157. package/dist/browser/encryption/EncryptionKeyResolver/AzureKeyVaultEncryptionKeyResolver.js.map +1 -1
  158. package/dist/browser/encryption/EncryptionKeyStoreProvider.d.ts.map +1 -1
  159. package/dist/browser/encryption/EncryptionKeyStoreProvider.js +10 -2
  160. package/dist/browser/encryption/EncryptionKeyStoreProvider.js.map +1 -1
  161. package/dist/browser/encryption/EncryptionManager.js +6 -0
  162. package/dist/browser/encryption/EncryptionManager.js.map +1 -1
  163. package/dist/browser/encryption/EncryptionProcessor.js +5 -0
  164. package/dist/browser/encryption/EncryptionProcessor.js.map +1 -1
  165. package/dist/browser/encryption/EncryptionQueryBuilder.js +2 -0
  166. package/dist/browser/encryption/EncryptionQueryBuilder.js.map +1 -1
  167. package/dist/browser/encryption/EncryptionSettingForProperty.js +6 -0
  168. package/dist/browser/encryption/EncryptionSettingForProperty.js.map +1 -1
  169. package/dist/browser/encryption/EncryptionSettings.js +6 -3
  170. package/dist/browser/encryption/EncryptionSettings.js.map +1 -1
  171. package/dist/browser/encryption/KeyEncryptionKey.js +4 -0
  172. package/dist/browser/encryption/KeyEncryptionKey.js.map +1 -1
  173. package/dist/browser/encryption/Serializers/StringSerializer.js +1 -1
  174. package/dist/browser/encryption/Serializers/StringSerializer.js.map +1 -1
  175. package/dist/browser/extractPartitionKey.js +2 -2
  176. package/dist/browser/extractPartitionKey.js.map +1 -1
  177. package/dist/browser/globalEndpointManager.js +21 -4
  178. package/dist/browser/globalEndpointManager.js.map +1 -1
  179. package/dist/browser/globalPartitionEndpointManager.d.ts.map +1 -1
  180. package/dist/browser/globalPartitionEndpointManager.js +16 -9
  181. package/dist/browser/globalPartitionEndpointManager.js.map +1 -1
  182. package/dist/browser/queryExecutionContext/Aggregators/AverageAggregator.js +2 -0
  183. package/dist/browser/queryExecutionContext/Aggregators/AverageAggregator.js.map +1 -1
  184. package/dist/browser/queryExecutionContext/Aggregators/CountAggregator.js +1 -0
  185. package/dist/browser/queryExecutionContext/Aggregators/CountAggregator.js.map +1 -1
  186. package/dist/browser/queryExecutionContext/Aggregators/GlobalStatisticsAggregator.js +1 -0
  187. package/dist/browser/queryExecutionContext/Aggregators/GlobalStatisticsAggregator.js.map +1 -1
  188. package/dist/browser/queryExecutionContext/Aggregators/MakeListAggregator.js +1 -0
  189. package/dist/browser/queryExecutionContext/Aggregators/MakeListAggregator.js.map +1 -1
  190. package/dist/browser/queryExecutionContext/Aggregators/MakeSetAggregator.js +1 -0
  191. package/dist/browser/queryExecutionContext/Aggregators/MakeSetAggregator.js.map +1 -1
  192. package/dist/browser/queryExecutionContext/Aggregators/MaxAggregator.js +2 -0
  193. package/dist/browser/queryExecutionContext/Aggregators/MaxAggregator.js.map +1 -1
  194. package/dist/browser/queryExecutionContext/Aggregators/MinAggregator.js +2 -0
  195. package/dist/browser/queryExecutionContext/Aggregators/MinAggregator.js.map +1 -1
  196. package/dist/browser/queryExecutionContext/Aggregators/StaticValueAggregator.js +1 -0
  197. package/dist/browser/queryExecutionContext/Aggregators/StaticValueAggregator.js.map +1 -1
  198. package/dist/browser/queryExecutionContext/Aggregators/SumAggregator.js +1 -0
  199. package/dist/browser/queryExecutionContext/Aggregators/SumAggregator.js.map +1 -1
  200. package/dist/browser/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.js +5 -3
  201. package/dist/browser/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.js.map +1 -1
  202. package/dist/browser/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.js +6 -3
  203. package/dist/browser/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.js.map +1 -1
  204. package/dist/browser/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.js +23 -7
  205. package/dist/browser/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.js.map +1 -1
  206. package/dist/browser/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.js +14 -6
  207. package/dist/browser/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.js.map +1 -1
  208. package/dist/browser/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.js +3 -0
  209. package/dist/browser/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.js.map +1 -1
  210. package/dist/browser/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.js +2 -0
  211. package/dist/browser/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.js.map +1 -1
  212. package/dist/browser/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.js +2 -0
  213. package/dist/browser/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.js.map +1 -1
  214. package/dist/browser/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.js +2 -0
  215. package/dist/browser/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.js.map +1 -1
  216. package/dist/browser/queryExecutionContext/FetchResult.js +4 -0
  217. package/dist/browser/queryExecutionContext/FetchResult.js.map +1 -1
  218. package/dist/browser/queryExecutionContext/defaultQueryExecutionContext.js +14 -2
  219. package/dist/browser/queryExecutionContext/defaultQueryExecutionContext.js.map +1 -1
  220. package/dist/browser/queryExecutionContext/documentProducer.js +34 -21
  221. package/dist/browser/queryExecutionContext/documentProducer.js.map +1 -1
  222. package/dist/browser/queryExecutionContext/hybridQueryExecutionContext.js +41 -27
  223. package/dist/browser/queryExecutionContext/hybridQueryExecutionContext.js.map +1 -1
  224. package/dist/browser/queryExecutionContext/orderByComparator.js +1 -0
  225. package/dist/browser/queryExecutionContext/orderByComparator.js.map +1 -1
  226. package/dist/browser/queryExecutionContext/orderByDocumentProducerComparator.js +1 -0
  227. package/dist/browser/queryExecutionContext/orderByDocumentProducerComparator.js.map +1 -1
  228. package/dist/browser/queryExecutionContext/orderByQueryExecutionContext.js +1 -0
  229. package/dist/browser/queryExecutionContext/orderByQueryExecutionContext.js.map +1 -1
  230. package/dist/browser/queryExecutionContext/parallelQueryExecutionContextBase.js +20 -2
  231. package/dist/browser/queryExecutionContext/parallelQueryExecutionContextBase.js.map +1 -1
  232. package/dist/browser/queryExecutionContext/pipelinedQueryExecutionContext.js +14 -4
  233. package/dist/browser/queryExecutionContext/pipelinedQueryExecutionContext.js.map +1 -1
  234. package/dist/browser/queryIterator.js +41 -33
  235. package/dist/browser/queryIterator.js.map +1 -1
  236. package/dist/browser/queryMetrics/clientSideMetrics.js +2 -1
  237. package/dist/browser/queryMetrics/clientSideMetrics.js.map +1 -1
  238. package/dist/browser/queryMetrics/queryMetrics.js +14 -1
  239. package/dist/browser/queryMetrics/queryMetrics.js.map +1 -1
  240. package/dist/browser/queryMetrics/queryPreparationTime.js +5 -1
  241. package/dist/browser/queryMetrics/queryPreparationTime.js.map +1 -1
  242. package/dist/browser/queryMetrics/runtimeExecutionTimes.js +4 -1
  243. package/dist/browser/queryMetrics/runtimeExecutionTimes.js.map +1 -1
  244. package/dist/browser/queryMetrics/timeSpan.js +4 -3
  245. package/dist/browser/queryMetrics/timeSpan.js.map +1 -1
  246. package/dist/browser/request/ErrorResponse.js +19 -0
  247. package/dist/browser/request/ErrorResponse.js.map +1 -1
  248. package/dist/browser/request/FeedResponse.js +4 -0
  249. package/dist/browser/request/FeedResponse.js.map +1 -1
  250. package/dist/browser/request/RequestHandler.js +1 -2
  251. package/dist/browser/request/RequestHandler.js.map +1 -1
  252. package/dist/browser/request/ResourceResponse.js +5 -0
  253. package/dist/browser/request/ResourceResponse.js.map +1 -1
  254. package/dist/browser/request/TimeoutError.js +1 -1
  255. package/dist/browser/request/TimeoutError.js.map +1 -1
  256. package/dist/browser/request/hybridSearchQueryResult.js +5 -0
  257. package/dist/browser/request/hybridSearchQueryResult.js.map +1 -1
  258. package/dist/browser/request/request.d.ts.map +1 -1
  259. package/dist/browser/request/request.js +8 -4
  260. package/dist/browser/request/request.js.map +1 -1
  261. package/dist/browser/retry/bulkExecutionRetryPolicy.js +5 -2
  262. package/dist/browser/retry/bulkExecutionRetryPolicy.js.map +1 -1
  263. package/dist/browser/retry/defaultRetryPolicy.js +4 -3
  264. package/dist/browser/retry/defaultRetryPolicy.js.map +1 -1
  265. package/dist/browser/retry/endpointDiscoveryRetryPolicy.js +11 -2
  266. package/dist/browser/retry/endpointDiscoveryRetryPolicy.js.map +1 -1
  267. package/dist/browser/retry/resourceThrottleRetryPolicy.js +20 -10
  268. package/dist/browser/retry/resourceThrottleRetryPolicy.js.map +1 -1
  269. package/dist/browser/retry/retryUtility.js +2 -3
  270. package/dist/browser/retry/retryUtility.js.map +1 -1
  271. package/dist/browser/retry/sessionRetryPolicy.js +8 -4
  272. package/dist/browser/retry/sessionRetryPolicy.js.map +1 -1
  273. package/dist/browser/retry/timeoutFailoverRetryPolicy.d.ts.map +1 -1
  274. package/dist/browser/retry/timeoutFailoverRetryPolicy.js +17 -7
  275. package/dist/browser/retry/timeoutFailoverRetryPolicy.js.map +1 -1
  276. package/dist/browser/routing/QueryRange.js +4 -0
  277. package/dist/browser/routing/QueryRange.js.map +1 -1
  278. package/dist/browser/routing/inMemoryCollectionRoutingMap.js +4 -0
  279. package/dist/browser/routing/inMemoryCollectionRoutingMap.js.map +1 -1
  280. package/dist/browser/routing/partitionKeyRangeCache.js +2 -0
  281. package/dist/browser/routing/partitionKeyRangeCache.js.map +1 -1
  282. package/dist/browser/routing/smartRoutingMapProvider.js +1 -0
  283. package/dist/browser/routing/smartRoutingMapProvider.js.map +1 -1
  284. package/dist/browser/session/VectorSessionToken.js +6 -2
  285. package/dist/browser/session/VectorSessionToken.js.map +1 -1
  286. package/dist/browser/session/sessionContainer.js +5 -3
  287. package/dist/browser/session/sessionContainer.js.map +1 -1
  288. package/dist/browser/utils/batch.js +15 -4
  289. package/dist/browser/utils/batch.js.map +1 -1
  290. package/dist/browser/utils/fixedSizePriorityQueue.js +4 -0
  291. package/dist/browser/utils/fixedSizePriorityQueue.js.map +1 -1
  292. package/dist/browser/utils/hashing/hash.js +1 -1
  293. package/dist/browser/utils/hashing/hash.js.map +1 -1
  294. package/dist/browser/utils/nonStreamingOrderByMap.js +2 -0
  295. package/dist/browser/utils/nonStreamingOrderByMap.js.map +1 -1
  296. package/dist/browser/utils/time.d.ts +8 -0
  297. package/dist/browser/utils/time.d.ts.map +1 -1
  298. package/dist/browser/utils/time.js +19 -0
  299. package/dist/browser/utils/time.js.map +1 -1
  300. package/dist/commonjs/ChangeFeedIterator.js +17 -11
  301. package/dist/commonjs/ChangeFeedIterator.js.map +1 -1
  302. package/dist/commonjs/ChangeFeedResponse.js +8 -0
  303. package/dist/commonjs/ChangeFeedResponse.js.map +1 -1
  304. package/dist/commonjs/ClientContext.js +122 -29
  305. package/dist/commonjs/ClientContext.js.map +1 -1
  306. package/dist/commonjs/CosmosClient.d.ts.map +1 -1
  307. package/dist/commonjs/CosmosClient.js +37 -3
  308. package/dist/commonjs/CosmosClient.js.map +1 -1
  309. package/dist/commonjs/CosmosDiagnostics.js +3 -0
  310. package/dist/commonjs/CosmosDiagnostics.js.map +1 -1
  311. package/dist/commonjs/PartitionKeyRangeFailoverInfo.js +8 -5
  312. package/dist/commonjs/PartitionKeyRangeFailoverInfo.js.map +1 -1
  313. package/dist/commonjs/bulk/Batcher.js +13 -3
  314. package/dist/commonjs/bulk/Batcher.js.map +1 -1
  315. package/dist/commonjs/bulk/BulkHelper.js +26 -11
  316. package/dist/commonjs/bulk/BulkHelper.js.map +1 -1
  317. package/dist/commonjs/bulk/BulkResponse.js +22 -20
  318. package/dist/commonjs/bulk/BulkResponse.js.map +1 -1
  319. package/dist/commonjs/bulk/CongestionAlgorithm.js +11 -4
  320. package/dist/commonjs/bulk/CongestionAlgorithm.js.map +1 -1
  321. package/dist/commonjs/bulk/HelperPerPartition.js +14 -1
  322. package/dist/commonjs/bulk/HelperPerPartition.js.map +1 -1
  323. package/dist/commonjs/bulk/ItemOperationContext.js +4 -0
  324. package/dist/commonjs/bulk/ItemOperationContext.js.map +1 -1
  325. package/dist/commonjs/bulk/Limiter.js +27 -18
  326. package/dist/commonjs/bulk/Limiter.js.map +1 -1
  327. package/dist/commonjs/bulk/PartitionMetric.js +4 -0
  328. package/dist/commonjs/bulk/PartitionMetric.js.map +1 -1
  329. package/dist/commonjs/client/ChangeFeed/ChangeFeedForEpkRange.js +26 -15
  330. package/dist/commonjs/client/ChangeFeed/ChangeFeedForEpkRange.js.map +1 -1
  331. package/dist/commonjs/client/ChangeFeed/ChangeFeedForPartitionKey.d.ts.map +1 -1
  332. package/dist/commonjs/client/ChangeFeed/ChangeFeedForPartitionKey.js +20 -8
  333. package/dist/commonjs/client/ChangeFeed/ChangeFeedForPartitionKey.js.map +1 -1
  334. package/dist/commonjs/client/ChangeFeed/ChangeFeedIteratorBuilder.js +12 -9
  335. package/dist/commonjs/client/ChangeFeed/ChangeFeedIteratorBuilder.js.map +1 -1
  336. package/dist/commonjs/client/ChangeFeed/ChangeFeedIteratorResponse.js +9 -0
  337. package/dist/commonjs/client/ChangeFeed/ChangeFeedIteratorResponse.js.map +1 -1
  338. package/dist/commonjs/client/ChangeFeed/ChangeFeedPolicy.js +1 -0
  339. package/dist/commonjs/client/ChangeFeed/ChangeFeedPolicy.js.map +1 -1
  340. package/dist/commonjs/client/ChangeFeed/ChangeFeedRange.js +20 -0
  341. package/dist/commonjs/client/ChangeFeed/ChangeFeedRange.js.map +1 -1
  342. package/dist/commonjs/client/ChangeFeed/ChangeFeedRetentionTimeSpan.js +1 -0
  343. package/dist/commonjs/client/ChangeFeed/ChangeFeedRetentionTimeSpan.js.map +1 -1
  344. package/dist/commonjs/client/ChangeFeed/ChangeFeedStartFromBeginning.js +1 -0
  345. package/dist/commonjs/client/ChangeFeed/ChangeFeedStartFromBeginning.js.map +1 -1
  346. package/dist/commonjs/client/ChangeFeed/ChangeFeedStartFromContinuation.js +1 -0
  347. package/dist/commonjs/client/ChangeFeed/ChangeFeedStartFromContinuation.js.map +1 -1
  348. package/dist/commonjs/client/ChangeFeed/ChangeFeedStartFromNow.js +1 -0
  349. package/dist/commonjs/client/ChangeFeed/ChangeFeedStartFromNow.js.map +1 -1
  350. package/dist/commonjs/client/ChangeFeed/ChangeFeedStartFromTime.js +2 -0
  351. package/dist/commonjs/client/ChangeFeed/ChangeFeedStartFromTime.js.map +1 -1
  352. package/dist/commonjs/client/ChangeFeed/CompositeContinuationToken.js +8 -0
  353. package/dist/commonjs/client/ChangeFeed/CompositeContinuationToken.js.map +1 -1
  354. package/dist/commonjs/client/ChangeFeed/ContinuationTokenForPartitionKey.js +12 -0
  355. package/dist/commonjs/client/ChangeFeed/ContinuationTokenForPartitionKey.js.map +1 -1
  356. package/dist/commonjs/client/ChangeFeed/FeedRange.js +8 -0
  357. package/dist/commonjs/client/ChangeFeed/FeedRange.js.map +1 -1
  358. package/dist/commonjs/client/ChangeFeed/FeedRangeQueue.js +1 -0
  359. package/dist/commonjs/client/ChangeFeed/FeedRangeQueue.js.map +1 -1
  360. package/dist/commonjs/client/ChangeFeed/changeFeedUtils.js +5 -5
  361. package/dist/commonjs/client/ChangeFeed/changeFeedUtils.js.map +1 -1
  362. package/dist/commonjs/client/ClientUtils.js +1 -1
  363. package/dist/commonjs/client/ClientUtils.js.map +1 -1
  364. package/dist/commonjs/client/Conflict/Conflict.js +4 -0
  365. package/dist/commonjs/client/Conflict/Conflict.js.map +1 -1
  366. package/dist/commonjs/client/Conflict/ConflictResponse.js +2 -0
  367. package/dist/commonjs/client/Conflict/ConflictResponse.js.map +1 -1
  368. package/dist/commonjs/client/Conflict/Conflicts.js +2 -0
  369. package/dist/commonjs/client/Conflict/Conflicts.js.map +1 -1
  370. package/dist/commonjs/client/Container/Container.js +18 -3
  371. package/dist/commonjs/client/Container/Container.js.map +1 -1
  372. package/dist/commonjs/client/Container/ContainerResponse.js +2 -0
  373. package/dist/commonjs/client/Container/ContainerResponse.js.map +1 -1
  374. package/dist/commonjs/client/Container/Containers.js +4 -2
  375. package/dist/commonjs/client/Container/Containers.js.map +1 -1
  376. package/dist/commonjs/client/Database/Database.js +33 -0
  377. package/dist/commonjs/client/Database/Database.js.map +1 -1
  378. package/dist/commonjs/client/Database/DatabaseResponse.js +2 -0
  379. package/dist/commonjs/client/Database/DatabaseResponse.js.map +1 -1
  380. package/dist/commonjs/client/Database/Databases.js +3 -0
  381. package/dist/commonjs/client/Database/Databases.js.map +1 -1
  382. package/dist/commonjs/client/Item/Item.js +4 -0
  383. package/dist/commonjs/client/Item/Item.js.map +1 -1
  384. package/dist/commonjs/client/Item/ItemResponse.js +2 -0
  385. package/dist/commonjs/client/Item/ItemResponse.js.map +1 -1
  386. package/dist/commonjs/client/Item/Items.d.ts.map +1 -1
  387. package/dist/commonjs/client/Item/Items.js +12 -0
  388. package/dist/commonjs/client/Item/Items.js.map +1 -1
  389. package/dist/commonjs/client/Offer/Offer.js +3 -0
  390. package/dist/commonjs/client/Offer/Offer.js.map +1 -1
  391. package/dist/commonjs/client/Offer/OfferResponse.js +2 -0
  392. package/dist/commonjs/client/Offer/OfferResponse.js.map +1 -1
  393. package/dist/commonjs/client/Offer/Offers.js +2 -0
  394. package/dist/commonjs/client/Offer/Offers.js.map +1 -1
  395. package/dist/commonjs/client/Permission/Permission.js +3 -0
  396. package/dist/commonjs/client/Permission/Permission.js.map +1 -1
  397. package/dist/commonjs/client/Permission/PermissionResponse.js +2 -0
  398. package/dist/commonjs/client/Permission/PermissionResponse.js.map +1 -1
  399. package/dist/commonjs/client/Permission/Permissions.js +2 -0
  400. package/dist/commonjs/client/Permission/Permissions.js.map +1 -1
  401. package/dist/commonjs/client/SasToken/SasTokenProperties.js +17 -0
  402. package/dist/commonjs/client/SasToken/SasTokenProperties.js.map +1 -1
  403. package/dist/commonjs/client/Script/Scripts.js +5 -0
  404. package/dist/commonjs/client/Script/Scripts.js.map +1 -1
  405. package/dist/commonjs/client/StoredProcedure/StoredProcedure.js +3 -0
  406. package/dist/commonjs/client/StoredProcedure/StoredProcedure.js.map +1 -1
  407. package/dist/commonjs/client/StoredProcedure/StoredProcedureResponse.js +4 -0
  408. package/dist/commonjs/client/StoredProcedure/StoredProcedureResponse.js.map +1 -1
  409. package/dist/commonjs/client/StoredProcedure/StoredProcedures.js +2 -0
  410. package/dist/commonjs/client/StoredProcedure/StoredProcedures.js.map +1 -1
  411. package/dist/commonjs/client/Trigger/Trigger.js +3 -0
  412. package/dist/commonjs/client/Trigger/Trigger.js.map +1 -1
  413. package/dist/commonjs/client/Trigger/TriggerResponse.js +2 -0
  414. package/dist/commonjs/client/Trigger/TriggerResponse.js.map +1 -1
  415. package/dist/commonjs/client/Trigger/Triggers.js +2 -0
  416. package/dist/commonjs/client/Trigger/Triggers.js.map +1 -1
  417. package/dist/commonjs/client/User/User.js +9 -0
  418. package/dist/commonjs/client/User/User.js.map +1 -1
  419. package/dist/commonjs/client/User/UserResponse.js +2 -0
  420. package/dist/commonjs/client/User/UserResponse.js.map +1 -1
  421. package/dist/commonjs/client/User/Users.js +2 -0
  422. package/dist/commonjs/client/User/Users.js.map +1 -1
  423. package/dist/commonjs/client/UserDefinedFunction/UserDefinedFunction.js +3 -0
  424. package/dist/commonjs/client/UserDefinedFunction/UserDefinedFunction.js.map +1 -1
  425. package/dist/commonjs/client/UserDefinedFunction/UserDefinedFunctionResponse.js +2 -0
  426. package/dist/commonjs/client/UserDefinedFunction/UserDefinedFunctionResponse.js.map +1 -1
  427. package/dist/commonjs/client/UserDefinedFunction/UserDefinedFunctions.js +2 -0
  428. package/dist/commonjs/client/UserDefinedFunction/UserDefinedFunctions.js.map +1 -1
  429. package/dist/commonjs/diagnostics/CosmosDiagnosticsContext.js +8 -7
  430. package/dist/commonjs/diagnostics/CosmosDiagnosticsContext.js.map +1 -1
  431. package/dist/commonjs/diagnostics/DiagnosticNodeInternal.js +26 -7
  432. package/dist/commonjs/diagnostics/DiagnosticNodeInternal.js.map +1 -1
  433. package/dist/commonjs/diagnostics/DiagnosticWriter.js +1 -3
  434. package/dist/commonjs/diagnostics/DiagnosticWriter.js.map +1 -1
  435. package/dist/commonjs/diagnostics/index.js +2 -2
  436. package/dist/commonjs/diagnostics/index.js.map +1 -1
  437. package/dist/commonjs/documents/DatabaseAccount.js +20 -4
  438. package/dist/commonjs/documents/DatabaseAccount.js.map +1 -1
  439. package/dist/commonjs/documents/PartitionKey.js +1 -3
  440. package/dist/commonjs/documents/PartitionKey.js.map +1 -1
  441. package/dist/commonjs/encryption/AeadAes256CbcHmacSha256Algorithm/AeadAes256CbcHmacSha256Algorithm.js +8 -2
  442. package/dist/commonjs/encryption/AeadAes256CbcHmacSha256Algorithm/AeadAes256CbcHmacSha256Algorithm.js.map +1 -1
  443. package/dist/commonjs/encryption/Cache/ClientEncryptionKeyPropertiesCache.js +2 -0
  444. package/dist/commonjs/encryption/Cache/ClientEncryptionKeyPropertiesCache.js.map +1 -1
  445. package/dist/commonjs/encryption/Cache/EncryptionSettingsCache.js +2 -0
  446. package/dist/commonjs/encryption/Cache/EncryptionSettingsCache.js.map +1 -1
  447. package/dist/commonjs/encryption/Cache/KeyEncryptionKeyCache.js +2 -0
  448. package/dist/commonjs/encryption/Cache/KeyEncryptionKeyCache.js.map +1 -1
  449. package/dist/commonjs/encryption/Cache/ProtectedDataEncryptionKeyCache.d.ts.map +1 -1
  450. package/dist/commonjs/encryption/Cache/ProtectedDataEncryptionKeyCache.js +7 -1
  451. package/dist/commonjs/encryption/Cache/ProtectedDataEncryptionKeyCache.js.map +1 -1
  452. package/dist/commonjs/encryption/ClientEncryptionKey/ClientEncryptionKeyResponse.js +2 -0
  453. package/dist/commonjs/encryption/ClientEncryptionKey/ClientEncryptionKeyResponse.js.map +1 -1
  454. package/dist/commonjs/encryption/EncryptionItemQueryIterator.js +24 -27
  455. package/dist/commonjs/encryption/EncryptionItemQueryIterator.js.map +1 -1
  456. package/dist/commonjs/encryption/EncryptionKey/DataEncryptionKey.js +7 -2
  457. package/dist/commonjs/encryption/EncryptionKey/DataEncryptionKey.js.map +1 -1
  458. package/dist/commonjs/encryption/EncryptionKey/ProtectedDataEncryptionKey.d.ts +0 -1
  459. package/dist/commonjs/encryption/EncryptionKey/ProtectedDataEncryptionKey.d.ts.map +1 -1
  460. package/dist/commonjs/encryption/EncryptionKey/ProtectedDataEncryptionKey.js +2 -0
  461. package/dist/commonjs/encryption/EncryptionKey/ProtectedDataEncryptionKey.js.map +1 -1
  462. package/dist/commonjs/encryption/EncryptionKeyResolver/AzureKeyVaultEncryptionKeyResolver.js +6 -5
  463. package/dist/commonjs/encryption/EncryptionKeyResolver/AzureKeyVaultEncryptionKeyResolver.js.map +1 -1
  464. package/dist/commonjs/encryption/EncryptionKeyStoreProvider.d.ts.map +1 -1
  465. package/dist/commonjs/encryption/EncryptionKeyStoreProvider.js +10 -2
  466. package/dist/commonjs/encryption/EncryptionKeyStoreProvider.js.map +1 -1
  467. package/dist/commonjs/encryption/EncryptionManager.js +6 -0
  468. package/dist/commonjs/encryption/EncryptionManager.js.map +1 -1
  469. package/dist/commonjs/encryption/EncryptionProcessor.js +5 -0
  470. package/dist/commonjs/encryption/EncryptionProcessor.js.map +1 -1
  471. package/dist/commonjs/encryption/EncryptionQueryBuilder.js +2 -0
  472. package/dist/commonjs/encryption/EncryptionQueryBuilder.js.map +1 -1
  473. package/dist/commonjs/encryption/EncryptionSettingForProperty.js +6 -0
  474. package/dist/commonjs/encryption/EncryptionSettingForProperty.js.map +1 -1
  475. package/dist/commonjs/encryption/EncryptionSettings.js +6 -3
  476. package/dist/commonjs/encryption/EncryptionSettings.js.map +1 -1
  477. package/dist/commonjs/encryption/KeyEncryptionKey.js +4 -0
  478. package/dist/commonjs/encryption/KeyEncryptionKey.js.map +1 -1
  479. package/dist/commonjs/encryption/Serializers/StringSerializer.js +1 -1
  480. package/dist/commonjs/encryption/Serializers/StringSerializer.js.map +1 -1
  481. package/dist/commonjs/extractPartitionKey.js +2 -2
  482. package/dist/commonjs/extractPartitionKey.js.map +1 -1
  483. package/dist/commonjs/globalEndpointManager.js +21 -4
  484. package/dist/commonjs/globalEndpointManager.js.map +1 -1
  485. package/dist/commonjs/globalPartitionEndpointManager.d.ts.map +1 -1
  486. package/dist/commonjs/globalPartitionEndpointManager.js +16 -9
  487. package/dist/commonjs/globalPartitionEndpointManager.js.map +1 -1
  488. package/dist/commonjs/queryExecutionContext/Aggregators/AverageAggregator.js +2 -0
  489. package/dist/commonjs/queryExecutionContext/Aggregators/AverageAggregator.js.map +1 -1
  490. package/dist/commonjs/queryExecutionContext/Aggregators/CountAggregator.js +1 -0
  491. package/dist/commonjs/queryExecutionContext/Aggregators/CountAggregator.js.map +1 -1
  492. package/dist/commonjs/queryExecutionContext/Aggregators/GlobalStatisticsAggregator.js +1 -0
  493. package/dist/commonjs/queryExecutionContext/Aggregators/GlobalStatisticsAggregator.js.map +1 -1
  494. package/dist/commonjs/queryExecutionContext/Aggregators/MakeListAggregator.js +1 -0
  495. package/dist/commonjs/queryExecutionContext/Aggregators/MakeListAggregator.js.map +1 -1
  496. package/dist/commonjs/queryExecutionContext/Aggregators/MakeSetAggregator.js +1 -0
  497. package/dist/commonjs/queryExecutionContext/Aggregators/MakeSetAggregator.js.map +1 -1
  498. package/dist/commonjs/queryExecutionContext/Aggregators/MaxAggregator.js +2 -0
  499. package/dist/commonjs/queryExecutionContext/Aggregators/MaxAggregator.js.map +1 -1
  500. package/dist/commonjs/queryExecutionContext/Aggregators/MinAggregator.js +2 -0
  501. package/dist/commonjs/queryExecutionContext/Aggregators/MinAggregator.js.map +1 -1
  502. package/dist/commonjs/queryExecutionContext/Aggregators/StaticValueAggregator.js +1 -0
  503. package/dist/commonjs/queryExecutionContext/Aggregators/StaticValueAggregator.js.map +1 -1
  504. package/dist/commonjs/queryExecutionContext/Aggregators/SumAggregator.js +1 -0
  505. package/dist/commonjs/queryExecutionContext/Aggregators/SumAggregator.js.map +1 -1
  506. package/dist/commonjs/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.js +5 -3
  507. package/dist/commonjs/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.js.map +1 -1
  508. package/dist/commonjs/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.js +6 -3
  509. package/dist/commonjs/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.js.map +1 -1
  510. package/dist/commonjs/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.js +23 -7
  511. package/dist/commonjs/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.js.map +1 -1
  512. package/dist/commonjs/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.js +14 -6
  513. package/dist/commonjs/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.js.map +1 -1
  514. package/dist/commonjs/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.js +3 -0
  515. package/dist/commonjs/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.js.map +1 -1
  516. package/dist/commonjs/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.js +2 -0
  517. package/dist/commonjs/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.js.map +1 -1
  518. package/dist/commonjs/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.js +2 -0
  519. package/dist/commonjs/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.js.map +1 -1
  520. package/dist/commonjs/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.js +2 -0
  521. package/dist/commonjs/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.js.map +1 -1
  522. package/dist/commonjs/queryExecutionContext/FetchResult.js +4 -0
  523. package/dist/commonjs/queryExecutionContext/FetchResult.js.map +1 -1
  524. package/dist/commonjs/queryExecutionContext/defaultQueryExecutionContext.js +14 -2
  525. package/dist/commonjs/queryExecutionContext/defaultQueryExecutionContext.js.map +1 -1
  526. package/dist/commonjs/queryExecutionContext/documentProducer.js +34 -21
  527. package/dist/commonjs/queryExecutionContext/documentProducer.js.map +1 -1
  528. package/dist/commonjs/queryExecutionContext/hybridQueryExecutionContext.js +41 -27
  529. package/dist/commonjs/queryExecutionContext/hybridQueryExecutionContext.js.map +1 -1
  530. package/dist/commonjs/queryExecutionContext/orderByComparator.js +1 -0
  531. package/dist/commonjs/queryExecutionContext/orderByComparator.js.map +1 -1
  532. package/dist/commonjs/queryExecutionContext/orderByDocumentProducerComparator.js +1 -0
  533. package/dist/commonjs/queryExecutionContext/orderByDocumentProducerComparator.js.map +1 -1
  534. package/dist/commonjs/queryExecutionContext/orderByQueryExecutionContext.js +1 -0
  535. package/dist/commonjs/queryExecutionContext/orderByQueryExecutionContext.js.map +1 -1
  536. package/dist/commonjs/queryExecutionContext/parallelQueryExecutionContextBase.js +20 -2
  537. package/dist/commonjs/queryExecutionContext/parallelQueryExecutionContextBase.js.map +1 -1
  538. package/dist/commonjs/queryExecutionContext/pipelinedQueryExecutionContext.js +14 -4
  539. package/dist/commonjs/queryExecutionContext/pipelinedQueryExecutionContext.js.map +1 -1
  540. package/dist/commonjs/queryIterator.js +41 -33
  541. package/dist/commonjs/queryIterator.js.map +1 -1
  542. package/dist/commonjs/queryMetrics/clientSideMetrics.js +2 -1
  543. package/dist/commonjs/queryMetrics/clientSideMetrics.js.map +1 -1
  544. package/dist/commonjs/queryMetrics/queryMetrics.js +14 -1
  545. package/dist/commonjs/queryMetrics/queryMetrics.js.map +1 -1
  546. package/dist/commonjs/queryMetrics/queryPreparationTime.js +5 -1
  547. package/dist/commonjs/queryMetrics/queryPreparationTime.js.map +1 -1
  548. package/dist/commonjs/queryMetrics/runtimeExecutionTimes.js +4 -1
  549. package/dist/commonjs/queryMetrics/runtimeExecutionTimes.js.map +1 -1
  550. package/dist/commonjs/queryMetrics/timeSpan.js +4 -3
  551. package/dist/commonjs/queryMetrics/timeSpan.js.map +1 -1
  552. package/dist/commonjs/request/ErrorResponse.js +19 -0
  553. package/dist/commonjs/request/ErrorResponse.js.map +1 -1
  554. package/dist/commonjs/request/FeedResponse.js +4 -0
  555. package/dist/commonjs/request/FeedResponse.js.map +1 -1
  556. package/dist/commonjs/request/RequestHandler.js +1 -2
  557. package/dist/commonjs/request/RequestHandler.js.map +1 -1
  558. package/dist/commonjs/request/ResourceResponse.js +5 -0
  559. package/dist/commonjs/request/ResourceResponse.js.map +1 -1
  560. package/dist/commonjs/request/TimeoutError.js +1 -1
  561. package/dist/commonjs/request/TimeoutError.js.map +1 -1
  562. package/dist/commonjs/request/hybridSearchQueryResult.js +5 -0
  563. package/dist/commonjs/request/hybridSearchQueryResult.js.map +1 -1
  564. package/dist/commonjs/request/request.d.ts.map +1 -1
  565. package/dist/commonjs/request/request.js +8 -4
  566. package/dist/commonjs/request/request.js.map +1 -1
  567. package/dist/commonjs/retry/bulkExecutionRetryPolicy.js +5 -2
  568. package/dist/commonjs/retry/bulkExecutionRetryPolicy.js.map +1 -1
  569. package/dist/commonjs/retry/defaultRetryPolicy.js +4 -3
  570. package/dist/commonjs/retry/defaultRetryPolicy.js.map +1 -1
  571. package/dist/commonjs/retry/endpointDiscoveryRetryPolicy.js +11 -2
  572. package/dist/commonjs/retry/endpointDiscoveryRetryPolicy.js.map +1 -1
  573. package/dist/commonjs/retry/resourceThrottleRetryPolicy.js +20 -10
  574. package/dist/commonjs/retry/resourceThrottleRetryPolicy.js.map +1 -1
  575. package/dist/commonjs/retry/retryUtility.js +2 -3
  576. package/dist/commonjs/retry/retryUtility.js.map +1 -1
  577. package/dist/commonjs/retry/sessionRetryPolicy.js +8 -4
  578. package/dist/commonjs/retry/sessionRetryPolicy.js.map +1 -1
  579. package/dist/commonjs/retry/timeoutFailoverRetryPolicy.d.ts.map +1 -1
  580. package/dist/commonjs/retry/timeoutFailoverRetryPolicy.js +17 -7
  581. package/dist/commonjs/retry/timeoutFailoverRetryPolicy.js.map +1 -1
  582. package/dist/commonjs/routing/QueryRange.js +4 -0
  583. package/dist/commonjs/routing/QueryRange.js.map +1 -1
  584. package/dist/commonjs/routing/inMemoryCollectionRoutingMap.js +4 -0
  585. package/dist/commonjs/routing/inMemoryCollectionRoutingMap.js.map +1 -1
  586. package/dist/commonjs/routing/partitionKeyRangeCache.js +2 -0
  587. package/dist/commonjs/routing/partitionKeyRangeCache.js.map +1 -1
  588. package/dist/commonjs/routing/smartRoutingMapProvider.js +1 -0
  589. package/dist/commonjs/routing/smartRoutingMapProvider.js.map +1 -1
  590. package/dist/commonjs/session/VectorSessionToken.js +6 -2
  591. package/dist/commonjs/session/VectorSessionToken.js.map +1 -1
  592. package/dist/commonjs/session/sessionContainer.js +5 -3
  593. package/dist/commonjs/session/sessionContainer.js.map +1 -1
  594. package/dist/commonjs/tsdoc-metadata.json +11 -11
  595. package/dist/commonjs/utils/batch.js +15 -4
  596. package/dist/commonjs/utils/batch.js.map +1 -1
  597. package/dist/commonjs/utils/fixedSizePriorityQueue.js +4 -0
  598. package/dist/commonjs/utils/fixedSizePriorityQueue.js.map +1 -1
  599. package/dist/commonjs/utils/hashing/hash.js +1 -1
  600. package/dist/commonjs/utils/hashing/hash.js.map +1 -1
  601. package/dist/commonjs/utils/nonStreamingOrderByMap.js +2 -0
  602. package/dist/commonjs/utils/nonStreamingOrderByMap.js.map +1 -1
  603. package/dist/commonjs/utils/time.d.ts +8 -0
  604. package/dist/commonjs/utils/time.d.ts.map +1 -1
  605. package/dist/commonjs/utils/time.js +20 -0
  606. package/dist/commonjs/utils/time.js.map +1 -1
  607. package/dist/esm/ChangeFeedIterator.js +17 -11
  608. package/dist/esm/ChangeFeedIterator.js.map +1 -1
  609. package/dist/esm/ChangeFeedResponse.js +8 -0
  610. package/dist/esm/ChangeFeedResponse.js.map +1 -1
  611. package/dist/esm/ClientContext.js +122 -29
  612. package/dist/esm/ClientContext.js.map +1 -1
  613. package/dist/esm/CosmosClient.d.ts.map +1 -1
  614. package/dist/esm/CosmosClient.js +37 -3
  615. package/dist/esm/CosmosClient.js.map +1 -1
  616. package/dist/esm/CosmosDiagnostics.js +3 -0
  617. package/dist/esm/CosmosDiagnostics.js.map +1 -1
  618. package/dist/esm/PartitionKeyRangeFailoverInfo.js +8 -5
  619. package/dist/esm/PartitionKeyRangeFailoverInfo.js.map +1 -1
  620. package/dist/esm/bulk/Batcher.js +13 -3
  621. package/dist/esm/bulk/Batcher.js.map +1 -1
  622. package/dist/esm/bulk/BulkHelper.js +26 -11
  623. package/dist/esm/bulk/BulkHelper.js.map +1 -1
  624. package/dist/esm/bulk/BulkResponse.js +22 -20
  625. package/dist/esm/bulk/BulkResponse.js.map +1 -1
  626. package/dist/esm/bulk/CongestionAlgorithm.js +11 -4
  627. package/dist/esm/bulk/CongestionAlgorithm.js.map +1 -1
  628. package/dist/esm/bulk/HelperPerPartition.js +14 -1
  629. package/dist/esm/bulk/HelperPerPartition.js.map +1 -1
  630. package/dist/esm/bulk/ItemOperationContext.js +4 -0
  631. package/dist/esm/bulk/ItemOperationContext.js.map +1 -1
  632. package/dist/esm/bulk/Limiter.js +27 -18
  633. package/dist/esm/bulk/Limiter.js.map +1 -1
  634. package/dist/esm/bulk/PartitionMetric.js +4 -0
  635. package/dist/esm/bulk/PartitionMetric.js.map +1 -1
  636. package/dist/esm/client/ChangeFeed/ChangeFeedForEpkRange.js +26 -15
  637. package/dist/esm/client/ChangeFeed/ChangeFeedForEpkRange.js.map +1 -1
  638. package/dist/esm/client/ChangeFeed/ChangeFeedForPartitionKey.d.ts.map +1 -1
  639. package/dist/esm/client/ChangeFeed/ChangeFeedForPartitionKey.js +20 -8
  640. package/dist/esm/client/ChangeFeed/ChangeFeedForPartitionKey.js.map +1 -1
  641. package/dist/esm/client/ChangeFeed/ChangeFeedIteratorBuilder.js +12 -9
  642. package/dist/esm/client/ChangeFeed/ChangeFeedIteratorBuilder.js.map +1 -1
  643. package/dist/esm/client/ChangeFeed/ChangeFeedIteratorResponse.js +9 -0
  644. package/dist/esm/client/ChangeFeed/ChangeFeedIteratorResponse.js.map +1 -1
  645. package/dist/esm/client/ChangeFeed/ChangeFeedPolicy.js +1 -0
  646. package/dist/esm/client/ChangeFeed/ChangeFeedPolicy.js.map +1 -1
  647. package/dist/esm/client/ChangeFeed/ChangeFeedRange.js +20 -0
  648. package/dist/esm/client/ChangeFeed/ChangeFeedRange.js.map +1 -1
  649. package/dist/esm/client/ChangeFeed/ChangeFeedRetentionTimeSpan.js +1 -0
  650. package/dist/esm/client/ChangeFeed/ChangeFeedRetentionTimeSpan.js.map +1 -1
  651. package/dist/esm/client/ChangeFeed/ChangeFeedStartFromBeginning.js +1 -0
  652. package/dist/esm/client/ChangeFeed/ChangeFeedStartFromBeginning.js.map +1 -1
  653. package/dist/esm/client/ChangeFeed/ChangeFeedStartFromContinuation.js +1 -0
  654. package/dist/esm/client/ChangeFeed/ChangeFeedStartFromContinuation.js.map +1 -1
  655. package/dist/esm/client/ChangeFeed/ChangeFeedStartFromNow.js +1 -0
  656. package/dist/esm/client/ChangeFeed/ChangeFeedStartFromNow.js.map +1 -1
  657. package/dist/esm/client/ChangeFeed/ChangeFeedStartFromTime.js +2 -0
  658. package/dist/esm/client/ChangeFeed/ChangeFeedStartFromTime.js.map +1 -1
  659. package/dist/esm/client/ChangeFeed/CompositeContinuationToken.js +8 -0
  660. package/dist/esm/client/ChangeFeed/CompositeContinuationToken.js.map +1 -1
  661. package/dist/esm/client/ChangeFeed/ContinuationTokenForPartitionKey.js +12 -0
  662. package/dist/esm/client/ChangeFeed/ContinuationTokenForPartitionKey.js.map +1 -1
  663. package/dist/esm/client/ChangeFeed/FeedRange.js +8 -0
  664. package/dist/esm/client/ChangeFeed/FeedRange.js.map +1 -1
  665. package/dist/esm/client/ChangeFeed/FeedRangeQueue.js +1 -0
  666. package/dist/esm/client/ChangeFeed/FeedRangeQueue.js.map +1 -1
  667. package/dist/esm/client/ChangeFeed/changeFeedUtils.js +5 -5
  668. package/dist/esm/client/ChangeFeed/changeFeedUtils.js.map +1 -1
  669. package/dist/esm/client/ClientUtils.js +1 -1
  670. package/dist/esm/client/ClientUtils.js.map +1 -1
  671. package/dist/esm/client/Conflict/Conflict.js +4 -0
  672. package/dist/esm/client/Conflict/Conflict.js.map +1 -1
  673. package/dist/esm/client/Conflict/ConflictResponse.js +2 -0
  674. package/dist/esm/client/Conflict/ConflictResponse.js.map +1 -1
  675. package/dist/esm/client/Conflict/Conflicts.js +2 -0
  676. package/dist/esm/client/Conflict/Conflicts.js.map +1 -1
  677. package/dist/esm/client/Container/Container.js +18 -3
  678. package/dist/esm/client/Container/Container.js.map +1 -1
  679. package/dist/esm/client/Container/ContainerResponse.js +2 -0
  680. package/dist/esm/client/Container/ContainerResponse.js.map +1 -1
  681. package/dist/esm/client/Container/Containers.js +4 -2
  682. package/dist/esm/client/Container/Containers.js.map +1 -1
  683. package/dist/esm/client/Database/Database.js +33 -0
  684. package/dist/esm/client/Database/Database.js.map +1 -1
  685. package/dist/esm/client/Database/DatabaseResponse.js +2 -0
  686. package/dist/esm/client/Database/DatabaseResponse.js.map +1 -1
  687. package/dist/esm/client/Database/Databases.js +3 -0
  688. package/dist/esm/client/Database/Databases.js.map +1 -1
  689. package/dist/esm/client/Item/Item.js +4 -0
  690. package/dist/esm/client/Item/Item.js.map +1 -1
  691. package/dist/esm/client/Item/ItemResponse.js +2 -0
  692. package/dist/esm/client/Item/ItemResponse.js.map +1 -1
  693. package/dist/esm/client/Item/Items.d.ts.map +1 -1
  694. package/dist/esm/client/Item/Items.js +12 -0
  695. package/dist/esm/client/Item/Items.js.map +1 -1
  696. package/dist/esm/client/Offer/Offer.js +3 -0
  697. package/dist/esm/client/Offer/Offer.js.map +1 -1
  698. package/dist/esm/client/Offer/OfferResponse.js +2 -0
  699. package/dist/esm/client/Offer/OfferResponse.js.map +1 -1
  700. package/dist/esm/client/Offer/Offers.js +2 -0
  701. package/dist/esm/client/Offer/Offers.js.map +1 -1
  702. package/dist/esm/client/Permission/Permission.js +3 -0
  703. package/dist/esm/client/Permission/Permission.js.map +1 -1
  704. package/dist/esm/client/Permission/PermissionResponse.js +2 -0
  705. package/dist/esm/client/Permission/PermissionResponse.js.map +1 -1
  706. package/dist/esm/client/Permission/Permissions.js +2 -0
  707. package/dist/esm/client/Permission/Permissions.js.map +1 -1
  708. package/dist/esm/client/SasToken/SasTokenProperties.js +17 -0
  709. package/dist/esm/client/SasToken/SasTokenProperties.js.map +1 -1
  710. package/dist/esm/client/Script/Scripts.js +5 -0
  711. package/dist/esm/client/Script/Scripts.js.map +1 -1
  712. package/dist/esm/client/StoredProcedure/StoredProcedure.js +3 -0
  713. package/dist/esm/client/StoredProcedure/StoredProcedure.js.map +1 -1
  714. package/dist/esm/client/StoredProcedure/StoredProcedureResponse.js +4 -0
  715. package/dist/esm/client/StoredProcedure/StoredProcedureResponse.js.map +1 -1
  716. package/dist/esm/client/StoredProcedure/StoredProcedures.js +2 -0
  717. package/dist/esm/client/StoredProcedure/StoredProcedures.js.map +1 -1
  718. package/dist/esm/client/Trigger/Trigger.js +3 -0
  719. package/dist/esm/client/Trigger/Trigger.js.map +1 -1
  720. package/dist/esm/client/Trigger/TriggerResponse.js +2 -0
  721. package/dist/esm/client/Trigger/TriggerResponse.js.map +1 -1
  722. package/dist/esm/client/Trigger/Triggers.js +2 -0
  723. package/dist/esm/client/Trigger/Triggers.js.map +1 -1
  724. package/dist/esm/client/User/User.js +9 -0
  725. package/dist/esm/client/User/User.js.map +1 -1
  726. package/dist/esm/client/User/UserResponse.js +2 -0
  727. package/dist/esm/client/User/UserResponse.js.map +1 -1
  728. package/dist/esm/client/User/Users.js +2 -0
  729. package/dist/esm/client/User/Users.js.map +1 -1
  730. package/dist/esm/client/UserDefinedFunction/UserDefinedFunction.js +3 -0
  731. package/dist/esm/client/UserDefinedFunction/UserDefinedFunction.js.map +1 -1
  732. package/dist/esm/client/UserDefinedFunction/UserDefinedFunctionResponse.js +2 -0
  733. package/dist/esm/client/UserDefinedFunction/UserDefinedFunctionResponse.js.map +1 -1
  734. package/dist/esm/client/UserDefinedFunction/UserDefinedFunctions.js +2 -0
  735. package/dist/esm/client/UserDefinedFunction/UserDefinedFunctions.js.map +1 -1
  736. package/dist/esm/diagnostics/CosmosDiagnosticsContext.js +8 -7
  737. package/dist/esm/diagnostics/CosmosDiagnosticsContext.js.map +1 -1
  738. package/dist/esm/diagnostics/DiagnosticNodeInternal.js +26 -7
  739. package/dist/esm/diagnostics/DiagnosticNodeInternal.js.map +1 -1
  740. package/dist/esm/diagnostics/DiagnosticWriter.js +1 -3
  741. package/dist/esm/diagnostics/DiagnosticWriter.js.map +1 -1
  742. package/dist/esm/diagnostics/index.js +2 -2
  743. package/dist/esm/diagnostics/index.js.map +1 -1
  744. package/dist/esm/documents/DatabaseAccount.js +20 -4
  745. package/dist/esm/documents/DatabaseAccount.js.map +1 -1
  746. package/dist/esm/documents/PartitionKey.js +1 -3
  747. package/dist/esm/documents/PartitionKey.js.map +1 -1
  748. package/dist/esm/encryption/AeadAes256CbcHmacSha256Algorithm/AeadAes256CbcHmacSha256Algorithm.js +8 -2
  749. package/dist/esm/encryption/AeadAes256CbcHmacSha256Algorithm/AeadAes256CbcHmacSha256Algorithm.js.map +1 -1
  750. package/dist/esm/encryption/Cache/ClientEncryptionKeyPropertiesCache.js +2 -0
  751. package/dist/esm/encryption/Cache/ClientEncryptionKeyPropertiesCache.js.map +1 -1
  752. package/dist/esm/encryption/Cache/EncryptionSettingsCache.js +2 -0
  753. package/dist/esm/encryption/Cache/EncryptionSettingsCache.js.map +1 -1
  754. package/dist/esm/encryption/Cache/KeyEncryptionKeyCache.js +2 -0
  755. package/dist/esm/encryption/Cache/KeyEncryptionKeyCache.js.map +1 -1
  756. package/dist/esm/encryption/Cache/ProtectedDataEncryptionKeyCache.d.ts.map +1 -1
  757. package/dist/esm/encryption/Cache/ProtectedDataEncryptionKeyCache.js +7 -1
  758. package/dist/esm/encryption/Cache/ProtectedDataEncryptionKeyCache.js.map +1 -1
  759. package/dist/esm/encryption/ClientEncryptionKey/ClientEncryptionKeyResponse.js +2 -0
  760. package/dist/esm/encryption/ClientEncryptionKey/ClientEncryptionKeyResponse.js.map +1 -1
  761. package/dist/esm/encryption/EncryptionItemQueryIterator.js +24 -27
  762. package/dist/esm/encryption/EncryptionItemQueryIterator.js.map +1 -1
  763. package/dist/esm/encryption/EncryptionKey/DataEncryptionKey.js +7 -2
  764. package/dist/esm/encryption/EncryptionKey/DataEncryptionKey.js.map +1 -1
  765. package/dist/esm/encryption/EncryptionKey/ProtectedDataEncryptionKey.d.ts +0 -1
  766. package/dist/esm/encryption/EncryptionKey/ProtectedDataEncryptionKey.d.ts.map +1 -1
  767. package/dist/esm/encryption/EncryptionKey/ProtectedDataEncryptionKey.js +2 -0
  768. package/dist/esm/encryption/EncryptionKey/ProtectedDataEncryptionKey.js.map +1 -1
  769. package/dist/esm/encryption/EncryptionKeyResolver/AzureKeyVaultEncryptionKeyResolver.js +6 -5
  770. package/dist/esm/encryption/EncryptionKeyResolver/AzureKeyVaultEncryptionKeyResolver.js.map +1 -1
  771. package/dist/esm/encryption/EncryptionKeyStoreProvider.d.ts.map +1 -1
  772. package/dist/esm/encryption/EncryptionKeyStoreProvider.js +10 -2
  773. package/dist/esm/encryption/EncryptionKeyStoreProvider.js.map +1 -1
  774. package/dist/esm/encryption/EncryptionManager.js +6 -0
  775. package/dist/esm/encryption/EncryptionManager.js.map +1 -1
  776. package/dist/esm/encryption/EncryptionProcessor.js +5 -0
  777. package/dist/esm/encryption/EncryptionProcessor.js.map +1 -1
  778. package/dist/esm/encryption/EncryptionQueryBuilder.js +2 -0
  779. package/dist/esm/encryption/EncryptionQueryBuilder.js.map +1 -1
  780. package/dist/esm/encryption/EncryptionSettingForProperty.js +6 -0
  781. package/dist/esm/encryption/EncryptionSettingForProperty.js.map +1 -1
  782. package/dist/esm/encryption/EncryptionSettings.js +6 -3
  783. package/dist/esm/encryption/EncryptionSettings.js.map +1 -1
  784. package/dist/esm/encryption/KeyEncryptionKey.js +4 -0
  785. package/dist/esm/encryption/KeyEncryptionKey.js.map +1 -1
  786. package/dist/esm/encryption/Serializers/StringSerializer.js +1 -1
  787. package/dist/esm/encryption/Serializers/StringSerializer.js.map +1 -1
  788. package/dist/esm/extractPartitionKey.js +2 -2
  789. package/dist/esm/extractPartitionKey.js.map +1 -1
  790. package/dist/esm/globalEndpointManager.js +21 -4
  791. package/dist/esm/globalEndpointManager.js.map +1 -1
  792. package/dist/esm/globalPartitionEndpointManager.d.ts.map +1 -1
  793. package/dist/esm/globalPartitionEndpointManager.js +16 -9
  794. package/dist/esm/globalPartitionEndpointManager.js.map +1 -1
  795. package/dist/esm/queryExecutionContext/Aggregators/AverageAggregator.js +2 -0
  796. package/dist/esm/queryExecutionContext/Aggregators/AverageAggregator.js.map +1 -1
  797. package/dist/esm/queryExecutionContext/Aggregators/CountAggregator.js +1 -0
  798. package/dist/esm/queryExecutionContext/Aggregators/CountAggregator.js.map +1 -1
  799. package/dist/esm/queryExecutionContext/Aggregators/GlobalStatisticsAggregator.js +1 -0
  800. package/dist/esm/queryExecutionContext/Aggregators/GlobalStatisticsAggregator.js.map +1 -1
  801. package/dist/esm/queryExecutionContext/Aggregators/MakeListAggregator.js +1 -0
  802. package/dist/esm/queryExecutionContext/Aggregators/MakeListAggregator.js.map +1 -1
  803. package/dist/esm/queryExecutionContext/Aggregators/MakeSetAggregator.js +1 -0
  804. package/dist/esm/queryExecutionContext/Aggregators/MakeSetAggregator.js.map +1 -1
  805. package/dist/esm/queryExecutionContext/Aggregators/MaxAggregator.js +2 -0
  806. package/dist/esm/queryExecutionContext/Aggregators/MaxAggregator.js.map +1 -1
  807. package/dist/esm/queryExecutionContext/Aggregators/MinAggregator.js +2 -0
  808. package/dist/esm/queryExecutionContext/Aggregators/MinAggregator.js.map +1 -1
  809. package/dist/esm/queryExecutionContext/Aggregators/StaticValueAggregator.js +1 -0
  810. package/dist/esm/queryExecutionContext/Aggregators/StaticValueAggregator.js.map +1 -1
  811. package/dist/esm/queryExecutionContext/Aggregators/SumAggregator.js +1 -0
  812. package/dist/esm/queryExecutionContext/Aggregators/SumAggregator.js.map +1 -1
  813. package/dist/esm/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.js +5 -3
  814. package/dist/esm/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.js.map +1 -1
  815. package/dist/esm/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.js +6 -3
  816. package/dist/esm/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.js.map +1 -1
  817. package/dist/esm/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.js +23 -7
  818. package/dist/esm/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.js.map +1 -1
  819. package/dist/esm/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.js +14 -6
  820. package/dist/esm/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.js.map +1 -1
  821. package/dist/esm/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.js +3 -0
  822. package/dist/esm/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.js.map +1 -1
  823. package/dist/esm/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.js +2 -0
  824. package/dist/esm/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.js.map +1 -1
  825. package/dist/esm/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.js +2 -0
  826. package/dist/esm/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.js.map +1 -1
  827. package/dist/esm/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.js +2 -0
  828. package/dist/esm/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.js.map +1 -1
  829. package/dist/esm/queryExecutionContext/FetchResult.js +4 -0
  830. package/dist/esm/queryExecutionContext/FetchResult.js.map +1 -1
  831. package/dist/esm/queryExecutionContext/defaultQueryExecutionContext.js +14 -2
  832. package/dist/esm/queryExecutionContext/defaultQueryExecutionContext.js.map +1 -1
  833. package/dist/esm/queryExecutionContext/documentProducer.js +34 -21
  834. package/dist/esm/queryExecutionContext/documentProducer.js.map +1 -1
  835. package/dist/esm/queryExecutionContext/hybridQueryExecutionContext.js +41 -27
  836. package/dist/esm/queryExecutionContext/hybridQueryExecutionContext.js.map +1 -1
  837. package/dist/esm/queryExecutionContext/orderByComparator.js +1 -0
  838. package/dist/esm/queryExecutionContext/orderByComparator.js.map +1 -1
  839. package/dist/esm/queryExecutionContext/orderByDocumentProducerComparator.js +1 -0
  840. package/dist/esm/queryExecutionContext/orderByDocumentProducerComparator.js.map +1 -1
  841. package/dist/esm/queryExecutionContext/orderByQueryExecutionContext.js +1 -0
  842. package/dist/esm/queryExecutionContext/orderByQueryExecutionContext.js.map +1 -1
  843. package/dist/esm/queryExecutionContext/parallelQueryExecutionContextBase.js +20 -2
  844. package/dist/esm/queryExecutionContext/parallelQueryExecutionContextBase.js.map +1 -1
  845. package/dist/esm/queryExecutionContext/pipelinedQueryExecutionContext.js +14 -4
  846. package/dist/esm/queryExecutionContext/pipelinedQueryExecutionContext.js.map +1 -1
  847. package/dist/esm/queryIterator.js +41 -33
  848. package/dist/esm/queryIterator.js.map +1 -1
  849. package/dist/esm/queryMetrics/clientSideMetrics.js +2 -1
  850. package/dist/esm/queryMetrics/clientSideMetrics.js.map +1 -1
  851. package/dist/esm/queryMetrics/queryMetrics.js +14 -1
  852. package/dist/esm/queryMetrics/queryMetrics.js.map +1 -1
  853. package/dist/esm/queryMetrics/queryPreparationTime.js +5 -1
  854. package/dist/esm/queryMetrics/queryPreparationTime.js.map +1 -1
  855. package/dist/esm/queryMetrics/runtimeExecutionTimes.js +4 -1
  856. package/dist/esm/queryMetrics/runtimeExecutionTimes.js.map +1 -1
  857. package/dist/esm/queryMetrics/timeSpan.js +4 -3
  858. package/dist/esm/queryMetrics/timeSpan.js.map +1 -1
  859. package/dist/esm/request/ErrorResponse.js +19 -0
  860. package/dist/esm/request/ErrorResponse.js.map +1 -1
  861. package/dist/esm/request/FeedResponse.js +4 -0
  862. package/dist/esm/request/FeedResponse.js.map +1 -1
  863. package/dist/esm/request/RequestHandler.js +1 -2
  864. package/dist/esm/request/RequestHandler.js.map +1 -1
  865. package/dist/esm/request/ResourceResponse.js +5 -0
  866. package/dist/esm/request/ResourceResponse.js.map +1 -1
  867. package/dist/esm/request/TimeoutError.js +1 -1
  868. package/dist/esm/request/TimeoutError.js.map +1 -1
  869. package/dist/esm/request/hybridSearchQueryResult.js +5 -0
  870. package/dist/esm/request/hybridSearchQueryResult.js.map +1 -1
  871. package/dist/esm/request/request.d.ts.map +1 -1
  872. package/dist/esm/request/request.js +8 -4
  873. package/dist/esm/request/request.js.map +1 -1
  874. package/dist/esm/retry/bulkExecutionRetryPolicy.js +5 -2
  875. package/dist/esm/retry/bulkExecutionRetryPolicy.js.map +1 -1
  876. package/dist/esm/retry/defaultRetryPolicy.js +4 -3
  877. package/dist/esm/retry/defaultRetryPolicy.js.map +1 -1
  878. package/dist/esm/retry/endpointDiscoveryRetryPolicy.js +11 -2
  879. package/dist/esm/retry/endpointDiscoveryRetryPolicy.js.map +1 -1
  880. package/dist/esm/retry/resourceThrottleRetryPolicy.js +20 -10
  881. package/dist/esm/retry/resourceThrottleRetryPolicy.js.map +1 -1
  882. package/dist/esm/retry/retryUtility.js +2 -3
  883. package/dist/esm/retry/retryUtility.js.map +1 -1
  884. package/dist/esm/retry/sessionRetryPolicy.js +8 -4
  885. package/dist/esm/retry/sessionRetryPolicy.js.map +1 -1
  886. package/dist/esm/retry/timeoutFailoverRetryPolicy.d.ts.map +1 -1
  887. package/dist/esm/retry/timeoutFailoverRetryPolicy.js +17 -7
  888. package/dist/esm/retry/timeoutFailoverRetryPolicy.js.map +1 -1
  889. package/dist/esm/routing/QueryRange.js +4 -0
  890. package/dist/esm/routing/QueryRange.js.map +1 -1
  891. package/dist/esm/routing/inMemoryCollectionRoutingMap.js +4 -0
  892. package/dist/esm/routing/inMemoryCollectionRoutingMap.js.map +1 -1
  893. package/dist/esm/routing/partitionKeyRangeCache.js +2 -0
  894. package/dist/esm/routing/partitionKeyRangeCache.js.map +1 -1
  895. package/dist/esm/routing/smartRoutingMapProvider.js +1 -0
  896. package/dist/esm/routing/smartRoutingMapProvider.js.map +1 -1
  897. package/dist/esm/session/VectorSessionToken.js +6 -2
  898. package/dist/esm/session/VectorSessionToken.js.map +1 -1
  899. package/dist/esm/session/sessionContainer.js +5 -3
  900. package/dist/esm/session/sessionContainer.js.map +1 -1
  901. package/dist/esm/utils/batch.js +15 -4
  902. package/dist/esm/utils/batch.js.map +1 -1
  903. package/dist/esm/utils/fixedSizePriorityQueue.js +4 -0
  904. package/dist/esm/utils/fixedSizePriorityQueue.js.map +1 -1
  905. package/dist/esm/utils/hashing/hash.js +1 -1
  906. package/dist/esm/utils/hashing/hash.js.map +1 -1
  907. package/dist/esm/utils/nonStreamingOrderByMap.js +2 -0
  908. package/dist/esm/utils/nonStreamingOrderByMap.js.map +1 -1
  909. package/dist/esm/utils/time.d.ts +8 -0
  910. package/dist/esm/utils/time.d.ts.map +1 -1
  911. package/dist/esm/utils/time.js +19 -0
  912. package/dist/esm/utils/time.js.map +1 -1
  913. package/dist/react-native/ChangeFeedIterator.js +17 -11
  914. package/dist/react-native/ChangeFeedIterator.js.map +1 -1
  915. package/dist/react-native/ChangeFeedResponse.js +8 -0
  916. package/dist/react-native/ChangeFeedResponse.js.map +1 -1
  917. package/dist/react-native/ClientContext.js +122 -29
  918. package/dist/react-native/ClientContext.js.map +1 -1
  919. package/dist/react-native/CosmosClient.d.ts.map +1 -1
  920. package/dist/react-native/CosmosClient.js +37 -3
  921. package/dist/react-native/CosmosClient.js.map +1 -1
  922. package/dist/react-native/CosmosDiagnostics.js +3 -0
  923. package/dist/react-native/CosmosDiagnostics.js.map +1 -1
  924. package/dist/react-native/PartitionKeyRangeFailoverInfo.js +8 -5
  925. package/dist/react-native/PartitionKeyRangeFailoverInfo.js.map +1 -1
  926. package/dist/react-native/bulk/Batcher.js +13 -3
  927. package/dist/react-native/bulk/Batcher.js.map +1 -1
  928. package/dist/react-native/bulk/BulkHelper.js +26 -11
  929. package/dist/react-native/bulk/BulkHelper.js.map +1 -1
  930. package/dist/react-native/bulk/BulkResponse.js +22 -20
  931. package/dist/react-native/bulk/BulkResponse.js.map +1 -1
  932. package/dist/react-native/bulk/CongestionAlgorithm.js +11 -4
  933. package/dist/react-native/bulk/CongestionAlgorithm.js.map +1 -1
  934. package/dist/react-native/bulk/HelperPerPartition.js +14 -1
  935. package/dist/react-native/bulk/HelperPerPartition.js.map +1 -1
  936. package/dist/react-native/bulk/ItemOperationContext.js +4 -0
  937. package/dist/react-native/bulk/ItemOperationContext.js.map +1 -1
  938. package/dist/react-native/bulk/Limiter.js +27 -18
  939. package/dist/react-native/bulk/Limiter.js.map +1 -1
  940. package/dist/react-native/bulk/PartitionMetric.js +4 -0
  941. package/dist/react-native/bulk/PartitionMetric.js.map +1 -1
  942. package/dist/react-native/client/ChangeFeed/ChangeFeedForEpkRange.js +26 -15
  943. package/dist/react-native/client/ChangeFeed/ChangeFeedForEpkRange.js.map +1 -1
  944. package/dist/react-native/client/ChangeFeed/ChangeFeedForPartitionKey.d.ts.map +1 -1
  945. package/dist/react-native/client/ChangeFeed/ChangeFeedForPartitionKey.js +20 -8
  946. package/dist/react-native/client/ChangeFeed/ChangeFeedForPartitionKey.js.map +1 -1
  947. package/dist/react-native/client/ChangeFeed/ChangeFeedIteratorBuilder.js +12 -9
  948. package/dist/react-native/client/ChangeFeed/ChangeFeedIteratorBuilder.js.map +1 -1
  949. package/dist/react-native/client/ChangeFeed/ChangeFeedIteratorResponse.js +9 -0
  950. package/dist/react-native/client/ChangeFeed/ChangeFeedIteratorResponse.js.map +1 -1
  951. package/dist/react-native/client/ChangeFeed/ChangeFeedPolicy.js +1 -0
  952. package/dist/react-native/client/ChangeFeed/ChangeFeedPolicy.js.map +1 -1
  953. package/dist/react-native/client/ChangeFeed/ChangeFeedRange.js +20 -0
  954. package/dist/react-native/client/ChangeFeed/ChangeFeedRange.js.map +1 -1
  955. package/dist/react-native/client/ChangeFeed/ChangeFeedRetentionTimeSpan.js +1 -0
  956. package/dist/react-native/client/ChangeFeed/ChangeFeedRetentionTimeSpan.js.map +1 -1
  957. package/dist/react-native/client/ChangeFeed/ChangeFeedStartFromBeginning.js +1 -0
  958. package/dist/react-native/client/ChangeFeed/ChangeFeedStartFromBeginning.js.map +1 -1
  959. package/dist/react-native/client/ChangeFeed/ChangeFeedStartFromContinuation.js +1 -0
  960. package/dist/react-native/client/ChangeFeed/ChangeFeedStartFromContinuation.js.map +1 -1
  961. package/dist/react-native/client/ChangeFeed/ChangeFeedStartFromNow.js +1 -0
  962. package/dist/react-native/client/ChangeFeed/ChangeFeedStartFromNow.js.map +1 -1
  963. package/dist/react-native/client/ChangeFeed/ChangeFeedStartFromTime.js +2 -0
  964. package/dist/react-native/client/ChangeFeed/ChangeFeedStartFromTime.js.map +1 -1
  965. package/dist/react-native/client/ChangeFeed/CompositeContinuationToken.js +8 -0
  966. package/dist/react-native/client/ChangeFeed/CompositeContinuationToken.js.map +1 -1
  967. package/dist/react-native/client/ChangeFeed/ContinuationTokenForPartitionKey.js +12 -0
  968. package/dist/react-native/client/ChangeFeed/ContinuationTokenForPartitionKey.js.map +1 -1
  969. package/dist/react-native/client/ChangeFeed/FeedRange.js +8 -0
  970. package/dist/react-native/client/ChangeFeed/FeedRange.js.map +1 -1
  971. package/dist/react-native/client/ChangeFeed/FeedRangeQueue.js +1 -0
  972. package/dist/react-native/client/ChangeFeed/FeedRangeQueue.js.map +1 -1
  973. package/dist/react-native/client/ChangeFeed/changeFeedUtils.js +5 -5
  974. package/dist/react-native/client/ChangeFeed/changeFeedUtils.js.map +1 -1
  975. package/dist/react-native/client/ClientUtils.js +1 -1
  976. package/dist/react-native/client/ClientUtils.js.map +1 -1
  977. package/dist/react-native/client/Conflict/Conflict.js +4 -0
  978. package/dist/react-native/client/Conflict/Conflict.js.map +1 -1
  979. package/dist/react-native/client/Conflict/ConflictResponse.js +2 -0
  980. package/dist/react-native/client/Conflict/ConflictResponse.js.map +1 -1
  981. package/dist/react-native/client/Conflict/Conflicts.js +2 -0
  982. package/dist/react-native/client/Conflict/Conflicts.js.map +1 -1
  983. package/dist/react-native/client/Container/Container.js +18 -3
  984. package/dist/react-native/client/Container/Container.js.map +1 -1
  985. package/dist/react-native/client/Container/ContainerResponse.js +2 -0
  986. package/dist/react-native/client/Container/ContainerResponse.js.map +1 -1
  987. package/dist/react-native/client/Container/Containers.js +4 -2
  988. package/dist/react-native/client/Container/Containers.js.map +1 -1
  989. package/dist/react-native/client/Database/Database.js +33 -0
  990. package/dist/react-native/client/Database/Database.js.map +1 -1
  991. package/dist/react-native/client/Database/DatabaseResponse.js +2 -0
  992. package/dist/react-native/client/Database/DatabaseResponse.js.map +1 -1
  993. package/dist/react-native/client/Database/Databases.js +3 -0
  994. package/dist/react-native/client/Database/Databases.js.map +1 -1
  995. package/dist/react-native/client/Item/Item.js +4 -0
  996. package/dist/react-native/client/Item/Item.js.map +1 -1
  997. package/dist/react-native/client/Item/ItemResponse.js +2 -0
  998. package/dist/react-native/client/Item/ItemResponse.js.map +1 -1
  999. package/dist/react-native/client/Item/Items.d.ts.map +1 -1
  1000. package/dist/react-native/client/Item/Items.js +12 -0
  1001. package/dist/react-native/client/Item/Items.js.map +1 -1
  1002. package/dist/react-native/client/Offer/Offer.js +3 -0
  1003. package/dist/react-native/client/Offer/Offer.js.map +1 -1
  1004. package/dist/react-native/client/Offer/OfferResponse.js +2 -0
  1005. package/dist/react-native/client/Offer/OfferResponse.js.map +1 -1
  1006. package/dist/react-native/client/Offer/Offers.js +2 -0
  1007. package/dist/react-native/client/Offer/Offers.js.map +1 -1
  1008. package/dist/react-native/client/Permission/Permission.js +3 -0
  1009. package/dist/react-native/client/Permission/Permission.js.map +1 -1
  1010. package/dist/react-native/client/Permission/PermissionResponse.js +2 -0
  1011. package/dist/react-native/client/Permission/PermissionResponse.js.map +1 -1
  1012. package/dist/react-native/client/Permission/Permissions.js +2 -0
  1013. package/dist/react-native/client/Permission/Permissions.js.map +1 -1
  1014. package/dist/react-native/client/SasToken/SasTokenProperties.js +17 -0
  1015. package/dist/react-native/client/SasToken/SasTokenProperties.js.map +1 -1
  1016. package/dist/react-native/client/Script/Scripts.js +5 -0
  1017. package/dist/react-native/client/Script/Scripts.js.map +1 -1
  1018. package/dist/react-native/client/StoredProcedure/StoredProcedure.js +3 -0
  1019. package/dist/react-native/client/StoredProcedure/StoredProcedure.js.map +1 -1
  1020. package/dist/react-native/client/StoredProcedure/StoredProcedureResponse.js +4 -0
  1021. package/dist/react-native/client/StoredProcedure/StoredProcedureResponse.js.map +1 -1
  1022. package/dist/react-native/client/StoredProcedure/StoredProcedures.js +2 -0
  1023. package/dist/react-native/client/StoredProcedure/StoredProcedures.js.map +1 -1
  1024. package/dist/react-native/client/Trigger/Trigger.js +3 -0
  1025. package/dist/react-native/client/Trigger/Trigger.js.map +1 -1
  1026. package/dist/react-native/client/Trigger/TriggerResponse.js +2 -0
  1027. package/dist/react-native/client/Trigger/TriggerResponse.js.map +1 -1
  1028. package/dist/react-native/client/Trigger/Triggers.js +2 -0
  1029. package/dist/react-native/client/Trigger/Triggers.js.map +1 -1
  1030. package/dist/react-native/client/User/User.js +9 -0
  1031. package/dist/react-native/client/User/User.js.map +1 -1
  1032. package/dist/react-native/client/User/UserResponse.js +2 -0
  1033. package/dist/react-native/client/User/UserResponse.js.map +1 -1
  1034. package/dist/react-native/client/User/Users.js +2 -0
  1035. package/dist/react-native/client/User/Users.js.map +1 -1
  1036. package/dist/react-native/client/UserDefinedFunction/UserDefinedFunction.js +3 -0
  1037. package/dist/react-native/client/UserDefinedFunction/UserDefinedFunction.js.map +1 -1
  1038. package/dist/react-native/client/UserDefinedFunction/UserDefinedFunctionResponse.js +2 -0
  1039. package/dist/react-native/client/UserDefinedFunction/UserDefinedFunctionResponse.js.map +1 -1
  1040. package/dist/react-native/client/UserDefinedFunction/UserDefinedFunctions.js +2 -0
  1041. package/dist/react-native/client/UserDefinedFunction/UserDefinedFunctions.js.map +1 -1
  1042. package/dist/react-native/diagnostics/CosmosDiagnosticsContext.js +8 -7
  1043. package/dist/react-native/diagnostics/CosmosDiagnosticsContext.js.map +1 -1
  1044. package/dist/react-native/diagnostics/DiagnosticNodeInternal.js +26 -7
  1045. package/dist/react-native/diagnostics/DiagnosticNodeInternal.js.map +1 -1
  1046. package/dist/react-native/diagnostics/DiagnosticWriter.js +1 -3
  1047. package/dist/react-native/diagnostics/DiagnosticWriter.js.map +1 -1
  1048. package/dist/react-native/diagnostics/index.js +2 -2
  1049. package/dist/react-native/diagnostics/index.js.map +1 -1
  1050. package/dist/react-native/documents/DatabaseAccount.js +20 -4
  1051. package/dist/react-native/documents/DatabaseAccount.js.map +1 -1
  1052. package/dist/react-native/documents/PartitionKey.js +1 -3
  1053. package/dist/react-native/documents/PartitionKey.js.map +1 -1
  1054. package/dist/react-native/encryption/AeadAes256CbcHmacSha256Algorithm/AeadAes256CbcHmacSha256Algorithm.js +8 -2
  1055. package/dist/react-native/encryption/AeadAes256CbcHmacSha256Algorithm/AeadAes256CbcHmacSha256Algorithm.js.map +1 -1
  1056. package/dist/react-native/encryption/Cache/ClientEncryptionKeyPropertiesCache.js +2 -0
  1057. package/dist/react-native/encryption/Cache/ClientEncryptionKeyPropertiesCache.js.map +1 -1
  1058. package/dist/react-native/encryption/Cache/EncryptionSettingsCache.js +2 -0
  1059. package/dist/react-native/encryption/Cache/EncryptionSettingsCache.js.map +1 -1
  1060. package/dist/react-native/encryption/Cache/KeyEncryptionKeyCache.js +2 -0
  1061. package/dist/react-native/encryption/Cache/KeyEncryptionKeyCache.js.map +1 -1
  1062. package/dist/react-native/encryption/Cache/ProtectedDataEncryptionKeyCache.d.ts.map +1 -1
  1063. package/dist/react-native/encryption/Cache/ProtectedDataEncryptionKeyCache.js +7 -1
  1064. package/dist/react-native/encryption/Cache/ProtectedDataEncryptionKeyCache.js.map +1 -1
  1065. package/dist/react-native/encryption/ClientEncryptionKey/ClientEncryptionKeyResponse.js +2 -0
  1066. package/dist/react-native/encryption/ClientEncryptionKey/ClientEncryptionKeyResponse.js.map +1 -1
  1067. package/dist/react-native/encryption/EncryptionItemQueryIterator.js +24 -27
  1068. package/dist/react-native/encryption/EncryptionItemQueryIterator.js.map +1 -1
  1069. package/dist/react-native/encryption/EncryptionKey/DataEncryptionKey.js +7 -2
  1070. package/dist/react-native/encryption/EncryptionKey/DataEncryptionKey.js.map +1 -1
  1071. package/dist/react-native/encryption/EncryptionKey/ProtectedDataEncryptionKey.d.ts +0 -1
  1072. package/dist/react-native/encryption/EncryptionKey/ProtectedDataEncryptionKey.d.ts.map +1 -1
  1073. package/dist/react-native/encryption/EncryptionKey/ProtectedDataEncryptionKey.js +2 -0
  1074. package/dist/react-native/encryption/EncryptionKey/ProtectedDataEncryptionKey.js.map +1 -1
  1075. package/dist/react-native/encryption/EncryptionKeyResolver/AzureKeyVaultEncryptionKeyResolver.js +6 -5
  1076. package/dist/react-native/encryption/EncryptionKeyResolver/AzureKeyVaultEncryptionKeyResolver.js.map +1 -1
  1077. package/dist/react-native/encryption/EncryptionKeyStoreProvider.d.ts.map +1 -1
  1078. package/dist/react-native/encryption/EncryptionKeyStoreProvider.js +10 -2
  1079. package/dist/react-native/encryption/EncryptionKeyStoreProvider.js.map +1 -1
  1080. package/dist/react-native/encryption/EncryptionManager.js +6 -0
  1081. package/dist/react-native/encryption/EncryptionManager.js.map +1 -1
  1082. package/dist/react-native/encryption/EncryptionProcessor.js +5 -0
  1083. package/dist/react-native/encryption/EncryptionProcessor.js.map +1 -1
  1084. package/dist/react-native/encryption/EncryptionQueryBuilder.js +2 -0
  1085. package/dist/react-native/encryption/EncryptionQueryBuilder.js.map +1 -1
  1086. package/dist/react-native/encryption/EncryptionSettingForProperty.js +6 -0
  1087. package/dist/react-native/encryption/EncryptionSettingForProperty.js.map +1 -1
  1088. package/dist/react-native/encryption/EncryptionSettings.js +6 -3
  1089. package/dist/react-native/encryption/EncryptionSettings.js.map +1 -1
  1090. package/dist/react-native/encryption/KeyEncryptionKey.js +4 -0
  1091. package/dist/react-native/encryption/KeyEncryptionKey.js.map +1 -1
  1092. package/dist/react-native/encryption/Serializers/StringSerializer.js +1 -1
  1093. package/dist/react-native/encryption/Serializers/StringSerializer.js.map +1 -1
  1094. package/dist/react-native/extractPartitionKey.js +2 -2
  1095. package/dist/react-native/extractPartitionKey.js.map +1 -1
  1096. package/dist/react-native/globalEndpointManager.js +21 -4
  1097. package/dist/react-native/globalEndpointManager.js.map +1 -1
  1098. package/dist/react-native/globalPartitionEndpointManager.d.ts.map +1 -1
  1099. package/dist/react-native/globalPartitionEndpointManager.js +16 -9
  1100. package/dist/react-native/globalPartitionEndpointManager.js.map +1 -1
  1101. package/dist/react-native/queryExecutionContext/Aggregators/AverageAggregator.js +2 -0
  1102. package/dist/react-native/queryExecutionContext/Aggregators/AverageAggregator.js.map +1 -1
  1103. package/dist/react-native/queryExecutionContext/Aggregators/CountAggregator.js +1 -0
  1104. package/dist/react-native/queryExecutionContext/Aggregators/CountAggregator.js.map +1 -1
  1105. package/dist/react-native/queryExecutionContext/Aggregators/GlobalStatisticsAggregator.js +1 -0
  1106. package/dist/react-native/queryExecutionContext/Aggregators/GlobalStatisticsAggregator.js.map +1 -1
  1107. package/dist/react-native/queryExecutionContext/Aggregators/MakeListAggregator.js +1 -0
  1108. package/dist/react-native/queryExecutionContext/Aggregators/MakeListAggregator.js.map +1 -1
  1109. package/dist/react-native/queryExecutionContext/Aggregators/MakeSetAggregator.js +1 -0
  1110. package/dist/react-native/queryExecutionContext/Aggregators/MakeSetAggregator.js.map +1 -1
  1111. package/dist/react-native/queryExecutionContext/Aggregators/MaxAggregator.js +2 -0
  1112. package/dist/react-native/queryExecutionContext/Aggregators/MaxAggregator.js.map +1 -1
  1113. package/dist/react-native/queryExecutionContext/Aggregators/MinAggregator.js +2 -0
  1114. package/dist/react-native/queryExecutionContext/Aggregators/MinAggregator.js.map +1 -1
  1115. package/dist/react-native/queryExecutionContext/Aggregators/StaticValueAggregator.js +1 -0
  1116. package/dist/react-native/queryExecutionContext/Aggregators/StaticValueAggregator.js.map +1 -1
  1117. package/dist/react-native/queryExecutionContext/Aggregators/SumAggregator.js +1 -0
  1118. package/dist/react-native/queryExecutionContext/Aggregators/SumAggregator.js.map +1 -1
  1119. package/dist/react-native/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.js +5 -3
  1120. package/dist/react-native/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.js.map +1 -1
  1121. package/dist/react-native/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.js +6 -3
  1122. package/dist/react-native/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.js.map +1 -1
  1123. package/dist/react-native/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.js +23 -7
  1124. package/dist/react-native/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.js.map +1 -1
  1125. package/dist/react-native/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.js +14 -6
  1126. package/dist/react-native/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.js.map +1 -1
  1127. package/dist/react-native/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.js +3 -0
  1128. package/dist/react-native/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.js.map +1 -1
  1129. package/dist/react-native/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.js +2 -0
  1130. package/dist/react-native/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.js.map +1 -1
  1131. package/dist/react-native/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.js +2 -0
  1132. package/dist/react-native/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.js.map +1 -1
  1133. package/dist/react-native/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.js +2 -0
  1134. package/dist/react-native/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.js.map +1 -1
  1135. package/dist/react-native/queryExecutionContext/FetchResult.js +4 -0
  1136. package/dist/react-native/queryExecutionContext/FetchResult.js.map +1 -1
  1137. package/dist/react-native/queryExecutionContext/defaultQueryExecutionContext.js +14 -2
  1138. package/dist/react-native/queryExecutionContext/defaultQueryExecutionContext.js.map +1 -1
  1139. package/dist/react-native/queryExecutionContext/documentProducer.js +34 -21
  1140. package/dist/react-native/queryExecutionContext/documentProducer.js.map +1 -1
  1141. package/dist/react-native/queryExecutionContext/hybridQueryExecutionContext.js +41 -27
  1142. package/dist/react-native/queryExecutionContext/hybridQueryExecutionContext.js.map +1 -1
  1143. package/dist/react-native/queryExecutionContext/orderByComparator.js +1 -0
  1144. package/dist/react-native/queryExecutionContext/orderByComparator.js.map +1 -1
  1145. package/dist/react-native/queryExecutionContext/orderByDocumentProducerComparator.js +1 -0
  1146. package/dist/react-native/queryExecutionContext/orderByDocumentProducerComparator.js.map +1 -1
  1147. package/dist/react-native/queryExecutionContext/orderByQueryExecutionContext.js +1 -0
  1148. package/dist/react-native/queryExecutionContext/orderByQueryExecutionContext.js.map +1 -1
  1149. package/dist/react-native/queryExecutionContext/parallelQueryExecutionContextBase.js +20 -2
  1150. package/dist/react-native/queryExecutionContext/parallelQueryExecutionContextBase.js.map +1 -1
  1151. package/dist/react-native/queryExecutionContext/pipelinedQueryExecutionContext.js +14 -4
  1152. package/dist/react-native/queryExecutionContext/pipelinedQueryExecutionContext.js.map +1 -1
  1153. package/dist/react-native/queryIterator.js +41 -33
  1154. package/dist/react-native/queryIterator.js.map +1 -1
  1155. package/dist/react-native/queryMetrics/clientSideMetrics.js +2 -1
  1156. package/dist/react-native/queryMetrics/clientSideMetrics.js.map +1 -1
  1157. package/dist/react-native/queryMetrics/queryMetrics.js +14 -1
  1158. package/dist/react-native/queryMetrics/queryMetrics.js.map +1 -1
  1159. package/dist/react-native/queryMetrics/queryPreparationTime.js +5 -1
  1160. package/dist/react-native/queryMetrics/queryPreparationTime.js.map +1 -1
  1161. package/dist/react-native/queryMetrics/runtimeExecutionTimes.js +4 -1
  1162. package/dist/react-native/queryMetrics/runtimeExecutionTimes.js.map +1 -1
  1163. package/dist/react-native/queryMetrics/timeSpan.js +4 -3
  1164. package/dist/react-native/queryMetrics/timeSpan.js.map +1 -1
  1165. package/dist/react-native/request/ErrorResponse.js +19 -0
  1166. package/dist/react-native/request/ErrorResponse.js.map +1 -1
  1167. package/dist/react-native/request/FeedResponse.js +4 -0
  1168. package/dist/react-native/request/FeedResponse.js.map +1 -1
  1169. package/dist/react-native/request/RequestHandler.js +1 -2
  1170. package/dist/react-native/request/RequestHandler.js.map +1 -1
  1171. package/dist/react-native/request/ResourceResponse.js +5 -0
  1172. package/dist/react-native/request/ResourceResponse.js.map +1 -1
  1173. package/dist/react-native/request/TimeoutError.js +1 -1
  1174. package/dist/react-native/request/TimeoutError.js.map +1 -1
  1175. package/dist/react-native/request/hybridSearchQueryResult.js +5 -0
  1176. package/dist/react-native/request/hybridSearchQueryResult.js.map +1 -1
  1177. package/dist/react-native/request/request.d.ts.map +1 -1
  1178. package/dist/react-native/request/request.js +8 -4
  1179. package/dist/react-native/request/request.js.map +1 -1
  1180. package/dist/react-native/retry/bulkExecutionRetryPolicy.js +5 -2
  1181. package/dist/react-native/retry/bulkExecutionRetryPolicy.js.map +1 -1
  1182. package/dist/react-native/retry/defaultRetryPolicy.js +4 -3
  1183. package/dist/react-native/retry/defaultRetryPolicy.js.map +1 -1
  1184. package/dist/react-native/retry/endpointDiscoveryRetryPolicy.js +11 -2
  1185. package/dist/react-native/retry/endpointDiscoveryRetryPolicy.js.map +1 -1
  1186. package/dist/react-native/retry/resourceThrottleRetryPolicy.js +20 -10
  1187. package/dist/react-native/retry/resourceThrottleRetryPolicy.js.map +1 -1
  1188. package/dist/react-native/retry/retryUtility.js +2 -3
  1189. package/dist/react-native/retry/retryUtility.js.map +1 -1
  1190. package/dist/react-native/retry/sessionRetryPolicy.js +8 -4
  1191. package/dist/react-native/retry/sessionRetryPolicy.js.map +1 -1
  1192. package/dist/react-native/retry/timeoutFailoverRetryPolicy.d.ts.map +1 -1
  1193. package/dist/react-native/retry/timeoutFailoverRetryPolicy.js +17 -7
  1194. package/dist/react-native/retry/timeoutFailoverRetryPolicy.js.map +1 -1
  1195. package/dist/react-native/routing/QueryRange.js +4 -0
  1196. package/dist/react-native/routing/QueryRange.js.map +1 -1
  1197. package/dist/react-native/routing/inMemoryCollectionRoutingMap.js +4 -0
  1198. package/dist/react-native/routing/inMemoryCollectionRoutingMap.js.map +1 -1
  1199. package/dist/react-native/routing/partitionKeyRangeCache.js +2 -0
  1200. package/dist/react-native/routing/partitionKeyRangeCache.js.map +1 -1
  1201. package/dist/react-native/routing/smartRoutingMapProvider.js +1 -0
  1202. package/dist/react-native/routing/smartRoutingMapProvider.js.map +1 -1
  1203. package/dist/react-native/session/VectorSessionToken.js +6 -2
  1204. package/dist/react-native/session/VectorSessionToken.js.map +1 -1
  1205. package/dist/react-native/session/sessionContainer.js +5 -3
  1206. package/dist/react-native/session/sessionContainer.js.map +1 -1
  1207. package/dist/react-native/utils/batch.js +15 -4
  1208. package/dist/react-native/utils/batch.js.map +1 -1
  1209. package/dist/react-native/utils/fixedSizePriorityQueue.js +4 -0
  1210. package/dist/react-native/utils/fixedSizePriorityQueue.js.map +1 -1
  1211. package/dist/react-native/utils/hashing/hash.js +1 -1
  1212. package/dist/react-native/utils/hashing/hash.js.map +1 -1
  1213. package/dist/react-native/utils/nonStreamingOrderByMap.js +2 -0
  1214. package/dist/react-native/utils/nonStreamingOrderByMap.js.map +1 -1
  1215. package/dist/react-native/utils/time.d.ts +8 -0
  1216. package/dist/react-native/utils/time.d.ts.map +1 -1
  1217. package/dist/react-native/utils/time.js +19 -0
  1218. package/dist/react-native/utils/time.js.map +1 -1
  1219. package/package.json +1 -1
@@ -3,6 +3,8 @@
3
3
  import { OrderByDocumentProducerComparator } from "../orderByDocumentProducerComparator.js";
4
4
  /** @hidden */
5
5
  export class MaxAggregator {
6
+ value;
7
+ comparer;
6
8
  /**
7
9
  * Represents an aggregator for MAX operator.
8
10
  * @hidden
@@ -1 +1 @@
1
- {"version":3,"file":"MaxAggregator.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/Aggregators/MaxAggregator.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAClC,OAAO,EAAE,iCAAiC,EAAE,MAAM,yCAAyC,CAAC;AAQ5F,cAAc;AACd,MAAM,OAAO,aAAa;IAGxB;;;OAGG;IACH;QACE,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,iCAAiC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;IACvE,CAAC;IACD;;OAEG;IACI,SAAS,CAAC,KAAyB;QACxC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;QACzB,CAAC;aAAM,IACL,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,EAAE,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAC1F,CAAC;YACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;QACzB,CAAC;IACH,CAAC;IAED;;OAEG;IACI,SAAS;QACd,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport { OrderByDocumentProducerComparator } from \"../orderByDocumentProducerComparator.js\";\nimport type { Aggregator } from \"./Aggregator.js\";\n\ninterface MaxAggregateResult {\n count: number;\n max?: number;\n}\n\n/** @hidden */\nexport class MaxAggregator implements Aggregator {\n private value: number;\n private comparer: OrderByDocumentProducerComparator;\n /**\n * Represents an aggregator for MAX operator.\n * @hidden\n */\n constructor() {\n this.value = undefined;\n this.comparer = new OrderByDocumentProducerComparator([\"Ascending\"]);\n }\n /**\n * Add the provided item to aggregation result.\n */\n public aggregate(other: MaxAggregateResult): void {\n if (this.value === undefined) {\n this.value = other.max;\n } else if (\n this.comparer.compareValue(other.max, typeof other.max, this.value, typeof this.value) > 0\n ) {\n this.value = other.max;\n }\n }\n\n /**\n * Get the aggregation result.\n */\n public getResult(): number {\n return this.value;\n }\n}\n"]}
1
+ {"version":3,"file":"MaxAggregator.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/Aggregators/MaxAggregator.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAClC,OAAO,EAAE,iCAAiC,EAAE,MAAM,yCAAyC,CAAC;AAQ5F,cAAc;AACd,MAAM,OAAO,aAAa;IAChB,KAAK,CAAS;IACd,QAAQ,CAAoC;IACpD;;;OAGG;IACH;QACE,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,iCAAiC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;IACvE,CAAC;IACD;;OAEG;IACI,SAAS,CAAC,KAAyB;QACxC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;QACzB,CAAC;aAAM,IACL,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,EAAE,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAC1F,CAAC;YACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;QACzB,CAAC;IACH,CAAC;IAED;;OAEG;IACI,SAAS;QACd,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport { OrderByDocumentProducerComparator } from \"../orderByDocumentProducerComparator.js\";\nimport type { Aggregator } from \"./Aggregator.js\";\n\ninterface MaxAggregateResult {\n count: number;\n max?: number;\n}\n\n/** @hidden */\nexport class MaxAggregator implements Aggregator {\n private value: number;\n private comparer: OrderByDocumentProducerComparator;\n /**\n * Represents an aggregator for MAX operator.\n * @hidden\n */\n constructor() {\n this.value = undefined;\n this.comparer = new OrderByDocumentProducerComparator([\"Ascending\"]);\n }\n /**\n * Add the provided item to aggregation result.\n */\n public aggregate(other: MaxAggregateResult): void {\n if (this.value === undefined) {\n this.value = other.max;\n } else if (\n this.comparer.compareValue(other.max, typeof other.max, this.value, typeof this.value) > 0\n ) {\n this.value = other.max;\n }\n }\n\n /**\n * Get the aggregation result.\n */\n public getResult(): number {\n return this.value;\n }\n}\n"]}
@@ -3,6 +3,8 @@
3
3
  import { OrderByDocumentProducerComparator } from "../orderByDocumentProducerComparator.js";
4
4
  /** @hidden */
5
5
  export class MinAggregator {
6
+ value;
7
+ comparer;
6
8
  /**
7
9
  * Represents an aggregator for MIN operator.
8
10
  * @hidden
@@ -1 +1 @@
1
- {"version":3,"file":"MinAggregator.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/Aggregators/MinAggregator.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAClC,OAAO,EAAE,iCAAiC,EAAE,MAAM,yCAAyC,CAAC;AAQ5F,cAAc;AACd,MAAM,OAAO,aAAa;IAGxB;;;OAGG;IACH;QACE,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,iCAAiC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;IACvE,CAAC;IACD;;OAEG;IACI,SAAS,CAAC,KAAyB;QACxC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC7B,oCAAoC;YACpC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;QACzB,CAAC;aAAM,CAAC;YACN,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,+BAA+B;YACpG,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC;YACrE,IAAI,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC/E,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACI,SAAS;QACd,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport { OrderByDocumentProducerComparator } from \"../orderByDocumentProducerComparator.js\";\nimport type { Aggregator } from \"./Aggregator.js\";\n\nexport interface MinAggregateResult {\n min: number;\n count: number;\n}\n\n/** @hidden */\nexport class MinAggregator implements Aggregator {\n private value: number;\n private comparer: OrderByDocumentProducerComparator;\n /**\n * Represents an aggregator for MIN operator.\n * @hidden\n */\n constructor() {\n this.value = undefined;\n this.comparer = new OrderByDocumentProducerComparator([\"Ascending\"]);\n }\n /**\n * Add the provided item to aggregation result.\n */\n public aggregate(other: MinAggregateResult): void {\n if (this.value === undefined) {\n // || typeof this.value === \"object\"\n this.value = other.min;\n } else {\n const otherType = other.min === null ? \"NoValue\" : typeof other.min; // || typeof other === \"object\"\n const thisType = this.value === null ? \"NoValue\" : typeof this.value;\n if (this.comparer.compareValue(other.min, otherType, this.value, thisType) < 0) {\n this.value = other.min;\n }\n }\n }\n\n /**\n * Get the aggregation result.\n */\n public getResult(): number {\n return this.value;\n }\n}\n"]}
1
+ {"version":3,"file":"MinAggregator.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/Aggregators/MinAggregator.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAClC,OAAO,EAAE,iCAAiC,EAAE,MAAM,yCAAyC,CAAC;AAQ5F,cAAc;AACd,MAAM,OAAO,aAAa;IAChB,KAAK,CAAS;IACd,QAAQ,CAAoC;IACpD;;;OAGG;IACH;QACE,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,iCAAiC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;IACvE,CAAC;IACD;;OAEG;IACI,SAAS,CAAC,KAAyB;QACxC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC7B,oCAAoC;YACpC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;QACzB,CAAC;aAAM,CAAC;YACN,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,+BAA+B;YACpG,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC;YACrE,IAAI,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC/E,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACI,SAAS;QACd,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport { OrderByDocumentProducerComparator } from \"../orderByDocumentProducerComparator.js\";\nimport type { Aggregator } from \"./Aggregator.js\";\n\nexport interface MinAggregateResult {\n min: number;\n count: number;\n}\n\n/** @hidden */\nexport class MinAggregator implements Aggregator {\n private value: number;\n private comparer: OrderByDocumentProducerComparator;\n /**\n * Represents an aggregator for MIN operator.\n * @hidden\n */\n constructor() {\n this.value = undefined;\n this.comparer = new OrderByDocumentProducerComparator([\"Ascending\"]);\n }\n /**\n * Add the provided item to aggregation result.\n */\n public aggregate(other: MinAggregateResult): void {\n if (this.value === undefined) {\n // || typeof this.value === \"object\"\n this.value = other.min;\n } else {\n const otherType = other.min === null ? \"NoValue\" : typeof other.min; // || typeof other === \"object\"\n const thisType = this.value === null ? \"NoValue\" : typeof this.value;\n if (this.comparer.compareValue(other.min, otherType, this.value, thisType) < 0) {\n this.value = other.min;\n }\n }\n }\n\n /**\n * Get the aggregation result.\n */\n public getResult(): number {\n return this.value;\n }\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  /** @hidden */
2
2
  export class StaticValueAggregator {
3
+ value;
3
4
  aggregate(other) {
4
5
  if (this.value === undefined) {
5
6
  this.value = other;
@@ -1 +1 @@
1
- {"version":3,"file":"StaticValueAggregator.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/Aggregators/StaticValueAggregator.ts"],"names":[],"mappings":"AAIA,cAAc;AACd,MAAM,OAAO,qBAAqB;IAEzB,SAAS,CAAC,KAAc;QAC7B,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,CAAC;IACH,CAAC;IAEM,SAAS;QACd,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Aggregator } from \"./Aggregator.js\";\n\n/** @hidden */\nexport class StaticValueAggregator implements Aggregator {\n public value: any;\n public aggregate(other: unknown): void {\n if (this.value === undefined) {\n this.value = other;\n }\n }\n\n public getResult(): any {\n return this.value;\n }\n}\n"]}
1
+ {"version":3,"file":"StaticValueAggregator.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/Aggregators/StaticValueAggregator.ts"],"names":[],"mappings":"AAIA,cAAc;AACd,MAAM,OAAO,qBAAqB;IACzB,KAAK,CAAM;IACX,SAAS,CAAC,KAAc;QAC7B,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,CAAC;IACH,CAAC;IAEM,SAAS;QACd,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Aggregator } from \"./Aggregator.js\";\n\n/** @hidden */\nexport class StaticValueAggregator implements Aggregator {\n public value: any;\n public aggregate(other: unknown): void {\n if (this.value === undefined) {\n this.value = other;\n }\n }\n\n public getResult(): any {\n return this.value;\n }\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  /** @hidden */
2
2
  export class SumAggregator {
3
+ sum;
3
4
  /**
4
5
  * Add the provided item to aggregation result.
5
6
  */
@@ -1 +1 @@
1
- {"version":3,"file":"SumAggregator.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/Aggregators/SumAggregator.ts"],"names":[],"mappings":"AAIA,cAAc;AACd,MAAM,OAAO,aAAa;IAExB;;OAEG;IACI,SAAS,CAAC,KAAa;QAC5B,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QACD,IAAI,IAAI,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC3B,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC;QACnB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,GAAG,IAAI,KAAK,CAAC;QACpB,CAAC;IACH,CAAC;IAED;;OAEG;IACI,SAAS;QACd,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Aggregator } from \"./Aggregator.js\";\n\n/** @hidden */\nexport class SumAggregator implements Aggregator {\n public sum: number;\n /**\n * Add the provided item to aggregation result.\n */\n public aggregate(other: number): void {\n if (other === undefined) {\n return;\n }\n if (this.sum === undefined) {\n this.sum = other;\n } else {\n this.sum += other;\n }\n }\n\n /**\n * Get the aggregation result.\n */\n public getResult(): number {\n return this.sum;\n }\n}\n"]}
1
+ {"version":3,"file":"SumAggregator.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/Aggregators/SumAggregator.ts"],"names":[],"mappings":"AAIA,cAAc;AACd,MAAM,OAAO,aAAa;IACjB,GAAG,CAAS;IACnB;;OAEG;IACI,SAAS,CAAC,KAAa;QAC5B,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QACD,IAAI,IAAI,CAAC,GAAG,KAAK,SAAS,EAAE,CAAC;YAC3B,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC;QACnB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,GAAG,IAAI,KAAK,CAAC;QACpB,CAAC;IACH,CAAC;IAED;;OAEG;IACI,SAAS;QACd,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Aggregator } from \"./Aggregator.js\";\n\n/** @hidden */\nexport class SumAggregator implements Aggregator {\n public sum: number;\n /**\n * Add the provided item to aggregation result.\n */\n public aggregate(other: number): void {\n if (other === undefined) {\n return;\n }\n if (this.sum === undefined) {\n this.sum = other;\n } else {\n this.sum += other;\n }\n }\n\n /**\n * Get the aggregation result.\n */\n public getResult(): number {\n return this.sum;\n }\n}\n"]}
@@ -4,13 +4,15 @@ import { getInitialHeader, mergeHeaders } from "../headerUtils.js";
4
4
  import { emptyGroup, extractAggregateResult } from "./emptyGroup.js";
5
5
  /** @hidden */
6
6
  export class GroupByEndpointComponent {
7
+ executionContext;
8
+ queryInfo;
7
9
  constructor(executionContext, queryInfo) {
8
10
  this.executionContext = executionContext;
9
11
  this.queryInfo = queryInfo;
10
- this.groupings = new Map();
11
- this.aggregateResultArray = [];
12
- this.completed = false;
13
12
  }
13
+ groupings = new Map();
14
+ aggregateResultArray = [];
15
+ completed = false;
14
16
  hasMoreResults() {
15
17
  return this.executionContext.hasMoreResults();
16
18
  }
@@ -1 +1 @@
1
- {"version":3,"file":"GroupByEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport type { CosmosHeaders } from \"../CosmosHeaders.js\";\nimport type { QueryInfo } from \"../../request/ErrorResponse.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { Aggregator } from \"../Aggregators/index.js\";\nimport { createAggregator } from \"../Aggregators/index.js\";\nimport { getInitialHeader, mergeHeaders } from \"../headerUtils.js\";\nimport { emptyGroup, extractAggregateResult } from \"./emptyGroup.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\n\ninterface GroupByResult {\n groupByItems: any[];\n payload: any;\n}\n\n/** @hidden */\nexport class GroupByEndpointComponent implements ExecutionContext {\n constructor(\n private executionContext: ExecutionContext,\n private queryInfo: QueryInfo,\n ) {}\n\n private readonly groupings: Map<string, Map<string, Aggregator>> = new Map();\n private readonly aggregateResultArray: any[] = [];\n private completed: boolean = false;\n\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode: DiagnosticNodeInternal): Promise<Response<any>> {\n if (this.completed) {\n return {\n result: undefined,\n headers: getInitialHeader(),\n };\n }\n const aggregateHeaders = getInitialHeader();\n const response = await this.executionContext.fetchMore(diagnosticNode);\n mergeHeaders(aggregateHeaders, response.headers);\n\n if (response === undefined || response.result === undefined) {\n // If there are any groupings, consolidate and return them\n if (this.groupings.size > 0) {\n return this.consolidateGroupResults(aggregateHeaders);\n }\n return { result: undefined, headers: aggregateHeaders };\n }\n\n for (const item of response.result as GroupByResult[]) {\n // If it exists, process it via aggregators\n if (item) {\n const group = item.groupByItems ? await hashObject(item.groupByItems) : emptyGroup;\n const aggregators = this.groupings.get(group);\n const payload = item.payload;\n if (aggregators) {\n // Iterator over all results in the payload\n for (const key of Object.keys(payload)) {\n // in case the value of a group is null make sure we create a dummy payload with item2==null\n const effectiveGroupByValue = payload[key]\n ? payload[key]\n : new Map().set(\"item2\", null);\n const aggregateResult = extractAggregateResult(effectiveGroupByValue);\n aggregators.get(key).aggregate(aggregateResult);\n }\n } else {\n // This is the first time we have seen a grouping. Setup the initial result without aggregate values\n const grouping = new Map();\n this.groupings.set(group, grouping);\n // Iterator over all results in the payload\n for (const key of Object.keys(payload)) {\n const aggregateType = this.queryInfo.groupByAliasToAggregateType[key];\n // Create a new aggregator for this specific aggregate field\n const aggregator = createAggregator(aggregateType);\n grouping.set(key, aggregator);\n if (aggregateType) {\n const aggregateResult = extractAggregateResult(payload[key]);\n aggregator.aggregate(aggregateResult);\n } else {\n aggregator.aggregate(payload[key]);\n }\n }\n }\n }\n }\n\n if (this.executionContext.hasMoreResults()) {\n return {\n result: [],\n headers: aggregateHeaders,\n };\n } else {\n return this.consolidateGroupResults(aggregateHeaders);\n }\n }\n\n private consolidateGroupResults(aggregateHeaders: CosmosHeaders): Response<any> {\n for (const grouping of this.groupings.values()) {\n const groupResult: any = {};\n for (const [aggregateKey, aggregator] of grouping.entries()) {\n groupResult[aggregateKey] = aggregator.getResult();\n }\n this.aggregateResultArray.push(groupResult);\n }\n this.completed = true;\n return { result: this.aggregateResultArray, headers: aggregateHeaders };\n }\n}\n"]}
1
+ {"version":3,"file":"GroupByEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/GroupByEndpointComponent.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport type { CosmosHeaders } from \"../CosmosHeaders.js\";\nimport type { QueryInfo } from \"../../request/ErrorResponse.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { Aggregator } from \"../Aggregators/index.js\";\nimport { createAggregator } from \"../Aggregators/index.js\";\nimport { getInitialHeader, mergeHeaders } from \"../headerUtils.js\";\nimport { emptyGroup, extractAggregateResult } from \"./emptyGroup.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\n\ninterface GroupByResult {\n groupByItems: any[];\n payload: any;\n}\n\n/** @hidden */\nexport class GroupByEndpointComponent implements ExecutionContext {\n constructor(\n private executionContext: ExecutionContext,\n private queryInfo: QueryInfo,\n ) {}\n\n private readonly groupings: Map<string, Map<string, Aggregator>> = new Map();\n private readonly aggregateResultArray: any[] = [];\n private completed: boolean = false;\n\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode: DiagnosticNodeInternal): Promise<Response<any>> {\n if (this.completed) {\n return {\n result: undefined,\n headers: getInitialHeader(),\n };\n }\n const aggregateHeaders = getInitialHeader();\n const response = await this.executionContext.fetchMore(diagnosticNode);\n mergeHeaders(aggregateHeaders, response.headers);\n\n if (response === undefined || response.result === undefined) {\n // If there are any groupings, consolidate and return them\n if (this.groupings.size > 0) {\n return this.consolidateGroupResults(aggregateHeaders);\n }\n return { result: undefined, headers: aggregateHeaders };\n }\n\n for (const item of response.result as GroupByResult[]) {\n // If it exists, process it via aggregators\n if (item) {\n const group = item.groupByItems ? await hashObject(item.groupByItems) : emptyGroup;\n const aggregators = this.groupings.get(group);\n const payload = item.payload;\n if (aggregators) {\n // Iterator over all results in the payload\n for (const key of Object.keys(payload)) {\n // in case the value of a group is null make sure we create a dummy payload with item2==null\n const effectiveGroupByValue = payload[key]\n ? payload[key]\n : new Map().set(\"item2\", null);\n const aggregateResult = extractAggregateResult(effectiveGroupByValue);\n aggregators.get(key).aggregate(aggregateResult);\n }\n } else {\n // This is the first time we have seen a grouping. Setup the initial result without aggregate values\n const grouping = new Map();\n this.groupings.set(group, grouping);\n // Iterator over all results in the payload\n for (const key of Object.keys(payload)) {\n const aggregateType = this.queryInfo.groupByAliasToAggregateType[key];\n // Create a new aggregator for this specific aggregate field\n const aggregator = createAggregator(aggregateType);\n grouping.set(key, aggregator);\n if (aggregateType) {\n const aggregateResult = extractAggregateResult(payload[key]);\n aggregator.aggregate(aggregateResult);\n } else {\n aggregator.aggregate(payload[key]);\n }\n }\n }\n }\n }\n\n if (this.executionContext.hasMoreResults()) {\n return {\n result: [],\n headers: aggregateHeaders,\n };\n } else {\n return this.consolidateGroupResults(aggregateHeaders);\n }\n }\n\n private consolidateGroupResults(aggregateHeaders: CosmosHeaders): Response<any> {\n for (const grouping of this.groupings.values()) {\n const groupResult: any = {};\n for (const [aggregateKey, aggregator] of grouping.entries()) {\n groupResult[aggregateKey] = aggregator.getResult();\n }\n this.aggregateResultArray.push(groupResult);\n }\n this.completed = true;\n return { result: this.aggregateResultArray, headers: aggregateHeaders };\n }\n}\n"]}
@@ -4,12 +4,15 @@ import { getInitialHeader, mergeHeaders } from "../headerUtils.js";
4
4
  import { emptyGroup, extractAggregateResult } from "./emptyGroup.js";
5
5
  /** @hidden */
6
6
  export class GroupByValueEndpointComponent {
7
+ executionContext;
8
+ queryInfo;
9
+ aggregators = new Map();
10
+ aggregateResultArray = [];
11
+ aggregateType;
12
+ completed = false;
7
13
  constructor(executionContext, queryInfo) {
8
14
  this.executionContext = executionContext;
9
15
  this.queryInfo = queryInfo;
10
- this.aggregators = new Map();
11
- this.aggregateResultArray = [];
12
- this.completed = false;
13
16
  // VALUE queries will only every have a single grouping
14
17
  this.aggregateType = this.queryInfo.aggregates[0];
15
18
  }
@@ -1 +1 @@
1
- {"version":3,"file":"GroupByValueEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAEvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AAQrE,cAAc;AACd,MAAM,OAAO,6BAA6B;IAMxC,YACU,gBAAkC,EAClC,SAAoB;QADpB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,cAAS,GAAT,SAAS,CAAW;QAPb,gBAAW,GAA4B,IAAI,GAAG,EAAE,CAAC;QACjD,yBAAoB,GAAU,EAAE,CAAC;QAE1C,cAAS,GAAY,KAAK,CAAC;QAMjC,uDAAuD;QACvD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC;IAEM,cAAc;QACnB,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAsC;QAC3D,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,gBAAgB,EAAE;aAC5B,CAAC;QACJ,CAAC;QACD,MAAM,gBAAgB,GAAG,gBAAgB,EAAE,CAAC;QAC5C,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,YAAY,CAAC,gBAAgB,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;QAEjD,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,EAAE,CAAC;gBAC9B,OAAO,IAAI,CAAC,yBAAyB,CAAC,gBAAgB,CAAC,CAAC;YAC1D,CAAC;YACD,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC;QAC1D,CAAC;QAED,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAyB,EAAE,CAAC;YACtD,IAAI,IAAI,EAAE,CAAC;gBACT,IAAI,QAAQ,GAAW,UAAU,CAAC;gBAClC,IAAI,OAAO,GAAQ,IAAI,CAAC;gBACxB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;oBACtB,4FAA4F;oBAC5F,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;oBACvB,QAAQ,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACjD,CAAC;gBAED,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBAClD,IAAI,CAAC,UAAU,EAAE,CAAC;oBAChB,4EAA4E;oBAC5E,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,gBAAgB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;gBACvE,CAAC;gBAED,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;oBACvB,MAAM,eAAe,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3D,yFAAyF;oBACzF,IAAI,eAAe,KAAK,IAAI,EAAE,CAAC;wBAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;oBACxB,CAAC;oBACD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;gBAC5D,CAAC;qBAAM,CAAC;oBACN,yEAAyE;oBACzE,sDAAsD;oBACtD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;gBACpD,CAAC;YACH,CAAC;QACH,CAAC;QAED,6DAA6D;QAC7D,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,gBAAgB;aAC1B,CAAC;QACJ,CAAC;QAED,IAAI,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,EAAE,CAAC;YAC3C,OAAO,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC;QACnD,CAAC;aAAM,CAAC;YACN,wGAAwG;YACxG,OAAO,IAAI,CAAC,yBAAyB,CAAC,gBAAgB,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC;IAEO,yBAAyB,CAAC,gBAA+B;QAC/D,KAAK,MAAM,UAAU,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,EAAE,CAAC;YACnD,MAAM,MAAM,GAAG,UAAU,CAAC,SAAS,EAAE,CAAC;YACtC,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;gBACzB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACzC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,oBAAoB;YACjC,OAAO,EAAE,gBAAgB;SAC1B,CAAC;IACJ,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport type { CosmosHeaders } from \"../CosmosHeaders.js\";\nimport type { AggregateType, QueryInfo } from \"../../request/ErrorResponse.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { Aggregator } from \"../Aggregators/index.js\";\nimport { createAggregator } from \"../Aggregators/index.js\";\nimport { getInitialHeader, mergeHeaders } from \"../headerUtils.js\";\nimport { emptyGroup, extractAggregateResult } from \"./emptyGroup.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\n\ninterface GroupByResult {\n groupByItems: any[];\n payload: any;\n}\n\n/** @hidden */\nexport class GroupByValueEndpointComponent implements ExecutionContext {\n private readonly aggregators: Map<string, Aggregator> = new Map();\n private readonly aggregateResultArray: any[] = [];\n private aggregateType: AggregateType;\n private completed: boolean = false;\n\n constructor(\n private executionContext: ExecutionContext,\n private queryInfo: QueryInfo,\n ) {\n // VALUE queries will only every have a single grouping\n this.aggregateType = this.queryInfo.aggregates[0];\n }\n\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode: DiagnosticNodeInternal): Promise<Response<any>> {\n if (this.completed) {\n return {\n result: undefined,\n headers: getInitialHeader(),\n };\n }\n const aggregateHeaders = getInitialHeader();\n const response = await this.executionContext.fetchMore(diagnosticNode);\n mergeHeaders(aggregateHeaders, response.headers);\n\n if (response === undefined || response.result === undefined) {\n if (this.aggregators.size > 0) {\n return this.generateAggregateResponse(aggregateHeaders);\n }\n return { result: undefined, headers: aggregateHeaders };\n }\n\n for (const item of response.result as GroupByResult[]) {\n if (item) {\n let grouping: string = emptyGroup;\n let payload: any = item;\n if (item.groupByItems) {\n // If the query contains a GROUP BY clause, it will have a payload property and groupByItems\n payload = item.payload;\n grouping = await hashObject(item.groupByItems);\n }\n\n const aggregator = this.aggregators.get(grouping);\n if (!aggregator) {\n // This is the first time we have seen a grouping so create a new aggregator\n this.aggregators.set(grouping, createAggregator(this.aggregateType));\n }\n\n if (this.aggregateType) {\n const aggregateResult = extractAggregateResult(payload[0]);\n // if aggregate result is null, we need to short circuit aggregation and return undefined\n if (aggregateResult === null) {\n this.completed = true;\n }\n this.aggregators.get(grouping).aggregate(aggregateResult);\n } else {\n // Queries with no aggregates pass the payload directly to the aggregator\n // Example: SELECT VALUE c.team FROM c GROUP BY c.team\n this.aggregators.get(grouping).aggregate(payload);\n }\n }\n }\n\n // We bail early since we got an undefined result back `[{}]`\n if (this.completed) {\n return {\n result: undefined,\n headers: aggregateHeaders,\n };\n }\n\n if (this.executionContext.hasMoreResults()) {\n return { result: [], headers: aggregateHeaders };\n } else {\n // If no results are left in the underlying execution context, convert our aggregate results to an array\n return this.generateAggregateResponse(aggregateHeaders);\n }\n }\n\n private generateAggregateResponse(aggregateHeaders: CosmosHeaders): Response<any> {\n for (const aggregator of this.aggregators.values()) {\n const result = aggregator.getResult();\n if (result !== undefined) {\n this.aggregateResultArray.push(result);\n }\n }\n this.completed = true;\n return {\n result: this.aggregateResultArray,\n headers: aggregateHeaders,\n };\n }\n}\n"]}
1
+ {"version":3,"file":"GroupByValueEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/GroupByValueEndpointComponent.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport type { CosmosHeaders } from \"../CosmosHeaders.js\";\nimport type { AggregateType, QueryInfo } from \"../../request/ErrorResponse.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { Aggregator } from \"../Aggregators/index.js\";\nimport { createAggregator } from \"../Aggregators/index.js\";\nimport { getInitialHeader, mergeHeaders } from \"../headerUtils.js\";\nimport { emptyGroup, extractAggregateResult } from \"./emptyGroup.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\n\ninterface GroupByResult {\n groupByItems: any[];\n payload: any;\n}\n\n/** @hidden */\nexport class GroupByValueEndpointComponent implements ExecutionContext {\n private readonly aggregators: Map<string, Aggregator> = new Map();\n private readonly aggregateResultArray: any[] = [];\n private aggregateType: AggregateType;\n private completed: boolean = false;\n\n constructor(\n private executionContext: ExecutionContext,\n private queryInfo: QueryInfo,\n ) {\n // VALUE queries will only every have a single grouping\n this.aggregateType = this.queryInfo.aggregates[0];\n }\n\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode: DiagnosticNodeInternal): Promise<Response<any>> {\n if (this.completed) {\n return {\n result: undefined,\n headers: getInitialHeader(),\n };\n }\n const aggregateHeaders = getInitialHeader();\n const response = await this.executionContext.fetchMore(diagnosticNode);\n mergeHeaders(aggregateHeaders, response.headers);\n\n if (response === undefined || response.result === undefined) {\n if (this.aggregators.size > 0) {\n return this.generateAggregateResponse(aggregateHeaders);\n }\n return { result: undefined, headers: aggregateHeaders };\n }\n\n for (const item of response.result as GroupByResult[]) {\n if (item) {\n let grouping: string = emptyGroup;\n let payload: any = item;\n if (item.groupByItems) {\n // If the query contains a GROUP BY clause, it will have a payload property and groupByItems\n payload = item.payload;\n grouping = await hashObject(item.groupByItems);\n }\n\n const aggregator = this.aggregators.get(grouping);\n if (!aggregator) {\n // This is the first time we have seen a grouping so create a new aggregator\n this.aggregators.set(grouping, createAggregator(this.aggregateType));\n }\n\n if (this.aggregateType) {\n const aggregateResult = extractAggregateResult(payload[0]);\n // if aggregate result is null, we need to short circuit aggregation and return undefined\n if (aggregateResult === null) {\n this.completed = true;\n }\n this.aggregators.get(grouping).aggregate(aggregateResult);\n } else {\n // Queries with no aggregates pass the payload directly to the aggregator\n // Example: SELECT VALUE c.team FROM c GROUP BY c.team\n this.aggregators.get(grouping).aggregate(payload);\n }\n }\n }\n\n // We bail early since we got an undefined result back `[{}]`\n if (this.completed) {\n return {\n result: undefined,\n headers: aggregateHeaders,\n };\n }\n\n if (this.executionContext.hasMoreResults()) {\n return { result: [], headers: aggregateHeaders };\n } else {\n // If no results are left in the underlying execution context, convert our aggregate results to an array\n return this.generateAggregateResponse(aggregateHeaders);\n }\n }\n\n private generateAggregateResponse(aggregateHeaders: CosmosHeaders): Response<any> {\n for (const aggregator of this.aggregators.values()) {\n const result = aggregator.getResult();\n if (result !== undefined) {\n this.aggregateResultArray.push(result);\n }\n }\n this.completed = true;\n return {\n result: this.aggregateResultArray,\n headers: aggregateHeaders,\n };\n }\n}\n"]}
@@ -8,15 +8,32 @@ import { OrderByComparator } from "../orderByComparator.js";
8
8
  * Represents an endpoint in handling an non-streaming order by distinct query.
9
9
  */
10
10
  export class NonStreamingOrderByDistinctEndpointComponent {
11
+ executionContext;
12
+ queryInfo;
13
+ priorityQueueBufferSize;
14
+ emitRawOrderByPayload;
15
+ /**
16
+ * A Map that holds the distinct values of the items before storing in priority queue.
17
+ */
18
+ aggregateMap;
19
+ /**
20
+ * A priority queue to compute the final sorted results.
21
+ */
22
+ nonStreamingOrderByPQ;
23
+ /**
24
+ * Array to store the final sorted results.
25
+ */
26
+ finalResultArray;
27
+ sortOrders;
28
+ /**
29
+ * Flag to determine if all results are fetched from backend and results can be returned.
30
+ */
31
+ isCompleted = false;
11
32
  constructor(executionContext, queryInfo, priorityQueueBufferSize, emitRawOrderByPayload = false) {
12
33
  this.executionContext = executionContext;
13
34
  this.queryInfo = queryInfo;
14
35
  this.priorityQueueBufferSize = priorityQueueBufferSize;
15
36
  this.emitRawOrderByPayload = emitRawOrderByPayload;
16
- /**
17
- * Flag to determine if all results are fetched from backend and results can be returned.
18
- */
19
- this.isCompleted = false;
20
37
  this.sortOrders = this.queryInfo.orderBy;
21
38
  const comparator = new OrderByComparator(this.sortOrders);
22
39
  this.aggregateMap = new NonStreamingOrderByMap((a, b) => {
@@ -30,7 +47,6 @@ export class NonStreamingOrderByDistinctEndpointComponent {
30
47
  * Build final sorted result array from which responses will be served.
31
48
  */
32
49
  async buildFinalResultArray() {
33
- var _a;
34
50
  // Fetch all distinct values from the map and store in priority queue.
35
51
  const allValues = this.aggregateMap.getAllValuesAndReset();
36
52
  for (const value of allValues) {
@@ -51,7 +67,7 @@ export class NonStreamingOrderByDistinctEndpointComponent {
51
67
  this.finalResultArray[count] = this.nonStreamingOrderByPQ.dequeue();
52
68
  }
53
69
  else {
54
- this.finalResultArray[count] = (_a = this.nonStreamingOrderByPQ.dequeue()) === null || _a === void 0 ? void 0 : _a.payload;
70
+ this.finalResultArray[count] = this.nonStreamingOrderByPQ.dequeue()?.payload;
55
71
  }
56
72
  }
57
73
  }
@@ -94,7 +110,7 @@ export class NonStreamingOrderByDistinctEndpointComponent {
94
110
  resHeaders = response.headers;
95
111
  for (const item of response.result) {
96
112
  if (item) {
97
- const key = await hashObject(item === null || item === void 0 ? void 0 : item.payload);
113
+ const key = await hashObject(item?.payload);
98
114
  this.aggregateMap.set(key, item);
99
115
  }
100
116
  }
@@ -1 +1 @@
1
- {"version":3,"file":"NonStreamingOrderByDistinctEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAErD,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAEvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAE5D;;;GAGG;AACH,MAAM,OAAO,4CAA4C;IAoBvD,YACU,gBAAkC,EAClC,SAAoB,EACpB,uBAA+B,EAC/B,wBAAiC,KAAK;QAHtC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,cAAS,GAAT,SAAS,CAAW;QACpB,4BAAuB,GAAvB,uBAAuB,CAAQ;QAC/B,0BAAqB,GAArB,qBAAqB,CAAiB;QAThD;;WAEG;QACK,gBAAW,GAAY,KAAK,CAAC;QAQnC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;QACzC,MAAM,UAAU,GAAG,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC1D,IAAI,CAAC,YAAY,GAAG,IAAI,sBAAsB,CAC5C,CAAC,CAA4B,EAAE,CAA4B,EAAE,EAAE;YAC7D,OAAO,UAAU,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACvC,CAAC,CACF,CAAC;QACF,IAAI,CAAC,qBAAqB,GAAG,IAAI,sBAAsB,CACrD,CAAC,CAA4B,EAAE,CAA4B,EAAE,EAAE;YAC7D,OAAO,UAAU,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACvC,CAAC,EACD,IAAI,CAAC,uBAAuB,CAC7B,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,qBAAqB;;QACjC,sEAAsE;QACtE,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,oBAAoB,EAAE,CAAC;QAC3D,KAAK,MAAM,KAAK,IAAI,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;QAED,iEAAiE;QACjE,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QACjE,MAAM,SAAS,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,CAAC;QACpD,MAAM,cAAc,GAAG,SAAS,GAAG,MAAM,CAAC;QAE1C,IAAI,cAAc,IAAI,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,gBAAgB,GAAG,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;YAClD,wGAAwG;YACxG,KAAK,IAAI,KAAK,GAAG,cAAc,GAAG,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC;gBACzD,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;oBAC/B,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,CAAC;gBACtE,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,GAAG,MAAA,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;gBAC/E,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAEM,cAAc;QACnB,IAAI,IAAI,CAAC,uBAAuB,KAAK,CAAC;YAAE,OAAO,KAAK,CAAC;QACrD,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,gBAAgB,EAAE;aAC5B,CAAC;QACJ,CAAC;QACD,IAAI,UAAU,GAAG,gBAAgB,EAAE,CAAC;QACpC,oGAAoG;QACpG,IAAI,IAAI,CAAC,uBAAuB,IAAI,CAAC,EAAE,CAAC;YACtC,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,UAAU;aACpB,CAAC;QACJ,CAAC;QAED,0DAA0D;QAC1D,IAAI,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,EAAE,CAAC;YAC3C,uBAAuB;YACvB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;YACvE,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC5D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBACxB,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC;oBACjC,MAAM,IAAI,CAAC,qBAAqB,EAAE,CAAC;oBACnC,OAAO;wBACL,MAAM,EAAE,IAAI,CAAC,gBAAgB;wBAC7B,OAAO,EAAE,QAAQ,CAAC,OAAO;qBAC1B,CAAC;gBACJ,CAAC;gBACD,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;YAC1D,CAAC;YACD,UAAU,GAAG,QAAQ,CAAC,OAAO,CAAC;YAC9B,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;gBACnC,IAAI,IAAI,EAAE,CAAC;oBACT,MAAM,GAAG,GAAG,MAAM,UAAU,CAAC,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,CAAC,CAAC;oBAC5C,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;gBACnC,CAAC;YACH,CAAC;YAED,4DAA4D;YAC5D,IAAI,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,EAAE,CAAC;gBAC3C,OAAO;oBACL,MAAM,EAAE,EAAE;oBACV,OAAO,EAAE,UAAU;iBACpB,CAAC;YACJ,CAAC;QACH,CAAC;QAED,iEAAiE;QACjE,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACjE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,MAAM,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACnC,OAAO;gBACL,MAAM,EAAE,IAAI,CAAC,gBAAgB;gBAC7B,OAAO,EAAE,UAAU;aACpB,CAAC;QACJ,CAAC;QACD,yCAAyC;QACzC,OAAO;YACL,MAAM,EAAE,SAAS;YACjB,OAAO,EAAE,UAAU;SACpB,CAAC;IACJ,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { QueryInfo, Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { getInitialHeader } from \"../headerUtils.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { NonStreamingOrderByResult } from \"../nonStreamingOrderByResult.js\";\nimport { FixedSizePriorityQueue } from \"../../utils/fixedSizePriorityQueue.js\";\nimport { NonStreamingOrderByMap } from \"../../utils/nonStreamingOrderByMap.js\";\nimport { OrderByComparator } from \"../orderByComparator.js\";\n\n/**\n * @hidden\n * Represents an endpoint in handling an non-streaming order by distinct query.\n */\nexport class NonStreamingOrderByDistinctEndpointComponent implements ExecutionContext {\n /**\n * A Map that holds the distinct values of the items before storing in priority queue.\n */\n private aggregateMap: NonStreamingOrderByMap<NonStreamingOrderByResult>;\n /**\n * A priority queue to compute the final sorted results.\n */\n private nonStreamingOrderByPQ: FixedSizePriorityQueue<NonStreamingOrderByResult>;\n /**\n * Array to store the final sorted results.\n */\n private finalResultArray: NonStreamingOrderByResult[];\n\n private sortOrders: string[];\n /**\n * Flag to determine if all results are fetched from backend and results can be returned.\n */\n private isCompleted: boolean = false;\n\n constructor(\n private executionContext: ExecutionContext,\n private queryInfo: QueryInfo,\n private priorityQueueBufferSize: number,\n private emitRawOrderByPayload: boolean = false,\n ) {\n this.sortOrders = this.queryInfo.orderBy;\n const comparator = new OrderByComparator(this.sortOrders);\n this.aggregateMap = new NonStreamingOrderByMap<NonStreamingOrderByResult>(\n (a: NonStreamingOrderByResult, b: NonStreamingOrderByResult) => {\n return comparator.compareItems(a, b);\n },\n );\n this.nonStreamingOrderByPQ = new FixedSizePriorityQueue<NonStreamingOrderByResult>(\n (a: NonStreamingOrderByResult, b: NonStreamingOrderByResult) => {\n return comparator.compareItems(b, a);\n },\n this.priorityQueueBufferSize,\n );\n }\n\n /**\n * Build final sorted result array from which responses will be served.\n */\n private async buildFinalResultArray(): Promise<void> {\n // Fetch all distinct values from the map and store in priority queue.\n const allValues = this.aggregateMap.getAllValuesAndReset();\n for (const value of allValues) {\n this.nonStreamingOrderByPQ.enqueue(value);\n }\n\n // Compute the final result array size based on offset and limit.\n const offSet = this.queryInfo.offset ? this.queryInfo.offset : 0;\n const queueSize = this.nonStreamingOrderByPQ.size();\n const finalArraySize = queueSize - offSet;\n\n if (finalArraySize <= 0) {\n this.finalResultArray = [];\n } else {\n this.finalResultArray = new Array(finalArraySize);\n // Only keep the final result array size number of items in the final result array and discard the rest.\n for (let count = finalArraySize - 1; count >= 0; count--) {\n if (this.emitRawOrderByPayload) {\n this.finalResultArray[count] = this.nonStreamingOrderByPQ.dequeue();\n } else {\n this.finalResultArray[count] = this.nonStreamingOrderByPQ.dequeue()?.payload;\n }\n }\n }\n }\n\n public hasMoreResults(): boolean {\n if (this.priorityQueueBufferSize === 0) return false;\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n if (this.isCompleted) {\n return {\n result: undefined,\n headers: getInitialHeader(),\n };\n }\n let resHeaders = getInitialHeader();\n // if size is 0, just return undefined to signal to more results. Valid if query is TOP 0 or LIMIT 0\n if (this.priorityQueueBufferSize <= 0) {\n return {\n result: undefined,\n headers: resHeaders,\n };\n }\n\n // If there are more results in backend, keep filling map.\n if (this.executionContext.hasMoreResults()) {\n // Grab the next result\n const response = await this.executionContext.fetchMore(diagnosticNode);\n if (response === undefined || response.result === undefined) {\n this.isCompleted = true;\n if (this.aggregateMap.size() > 0) {\n await this.buildFinalResultArray();\n return {\n result: this.finalResultArray,\n headers: response.headers,\n };\n }\n return { result: undefined, headers: response.headers };\n }\n resHeaders = response.headers;\n for (const item of response.result) {\n if (item) {\n const key = await hashObject(item?.payload);\n this.aggregateMap.set(key, item);\n }\n }\n\n // return [] to signal that there are more results to fetch.\n if (this.executionContext.hasMoreResults()) {\n return {\n result: [],\n headers: resHeaders,\n };\n }\n }\n\n // If all results are fetched from backend, prepare final results\n if (!this.executionContext.hasMoreResults() && !this.isCompleted) {\n this.isCompleted = true;\n await this.buildFinalResultArray();\n return {\n result: this.finalResultArray,\n headers: resHeaders,\n };\n }\n // Signal that there are no more results.\n return {\n result: undefined,\n headers: resHeaders,\n };\n }\n}\n"]}
1
+ {"version":3,"file":"NonStreamingOrderByDistinctEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/NonStreamingOrderByDistinctEndpointComponent.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { QueryInfo, Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { getInitialHeader } from \"../headerUtils.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { NonStreamingOrderByResult } from \"../nonStreamingOrderByResult.js\";\nimport { FixedSizePriorityQueue } from \"../../utils/fixedSizePriorityQueue.js\";\nimport { NonStreamingOrderByMap } from \"../../utils/nonStreamingOrderByMap.js\";\nimport { OrderByComparator } from \"../orderByComparator.js\";\n\n/**\n * @hidden\n * Represents an endpoint in handling an non-streaming order by distinct query.\n */\nexport class NonStreamingOrderByDistinctEndpointComponent implements ExecutionContext {\n /**\n * A Map that holds the distinct values of the items before storing in priority queue.\n */\n private aggregateMap: NonStreamingOrderByMap<NonStreamingOrderByResult>;\n /**\n * A priority queue to compute the final sorted results.\n */\n private nonStreamingOrderByPQ: FixedSizePriorityQueue<NonStreamingOrderByResult>;\n /**\n * Array to store the final sorted results.\n */\n private finalResultArray: NonStreamingOrderByResult[];\n\n private sortOrders: string[];\n /**\n * Flag to determine if all results are fetched from backend and results can be returned.\n */\n private isCompleted: boolean = false;\n\n constructor(\n private executionContext: ExecutionContext,\n private queryInfo: QueryInfo,\n private priorityQueueBufferSize: number,\n private emitRawOrderByPayload: boolean = false,\n ) {\n this.sortOrders = this.queryInfo.orderBy;\n const comparator = new OrderByComparator(this.sortOrders);\n this.aggregateMap = new NonStreamingOrderByMap<NonStreamingOrderByResult>(\n (a: NonStreamingOrderByResult, b: NonStreamingOrderByResult) => {\n return comparator.compareItems(a, b);\n },\n );\n this.nonStreamingOrderByPQ = new FixedSizePriorityQueue<NonStreamingOrderByResult>(\n (a: NonStreamingOrderByResult, b: NonStreamingOrderByResult) => {\n return comparator.compareItems(b, a);\n },\n this.priorityQueueBufferSize,\n );\n }\n\n /**\n * Build final sorted result array from which responses will be served.\n */\n private async buildFinalResultArray(): Promise<void> {\n // Fetch all distinct values from the map and store in priority queue.\n const allValues = this.aggregateMap.getAllValuesAndReset();\n for (const value of allValues) {\n this.nonStreamingOrderByPQ.enqueue(value);\n }\n\n // Compute the final result array size based on offset and limit.\n const offSet = this.queryInfo.offset ? this.queryInfo.offset : 0;\n const queueSize = this.nonStreamingOrderByPQ.size();\n const finalArraySize = queueSize - offSet;\n\n if (finalArraySize <= 0) {\n this.finalResultArray = [];\n } else {\n this.finalResultArray = new Array(finalArraySize);\n // Only keep the final result array size number of items in the final result array and discard the rest.\n for (let count = finalArraySize - 1; count >= 0; count--) {\n if (this.emitRawOrderByPayload) {\n this.finalResultArray[count] = this.nonStreamingOrderByPQ.dequeue();\n } else {\n this.finalResultArray[count] = this.nonStreamingOrderByPQ.dequeue()?.payload;\n }\n }\n }\n }\n\n public hasMoreResults(): boolean {\n if (this.priorityQueueBufferSize === 0) return false;\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n if (this.isCompleted) {\n return {\n result: undefined,\n headers: getInitialHeader(),\n };\n }\n let resHeaders = getInitialHeader();\n // if size is 0, just return undefined to signal to more results. Valid if query is TOP 0 or LIMIT 0\n if (this.priorityQueueBufferSize <= 0) {\n return {\n result: undefined,\n headers: resHeaders,\n };\n }\n\n // If there are more results in backend, keep filling map.\n if (this.executionContext.hasMoreResults()) {\n // Grab the next result\n const response = await this.executionContext.fetchMore(diagnosticNode);\n if (response === undefined || response.result === undefined) {\n this.isCompleted = true;\n if (this.aggregateMap.size() > 0) {\n await this.buildFinalResultArray();\n return {\n result: this.finalResultArray,\n headers: response.headers,\n };\n }\n return { result: undefined, headers: response.headers };\n }\n resHeaders = response.headers;\n for (const item of response.result) {\n if (item) {\n const key = await hashObject(item?.payload);\n this.aggregateMap.set(key, item);\n }\n }\n\n // return [] to signal that there are more results to fetch.\n if (this.executionContext.hasMoreResults()) {\n return {\n result: [],\n headers: resHeaders,\n };\n }\n }\n\n // If all results are fetched from backend, prepare final results\n if (!this.executionContext.hasMoreResults() && !this.isCompleted) {\n this.isCompleted = true;\n await this.buildFinalResultArray();\n return {\n result: this.finalResultArray,\n headers: resHeaders,\n };\n }\n // Signal that there are no more results.\n return {\n result: undefined,\n headers: resHeaders,\n };\n }\n}\n"]}
@@ -6,6 +6,19 @@ import { getInitialHeader } from "../headerUtils.js";
6
6
  * Represents an endpoint in handling an non-streaming order by query.
7
7
  */
8
8
  export class NonStreamingOrderByEndpointComponent {
9
+ executionContext;
10
+ sortOrders;
11
+ priorityQueueBufferSize;
12
+ offset;
13
+ emitRawOrderByPayload;
14
+ /**
15
+ * A priority queue to store the final sorted results.
16
+ */
17
+ nonStreamingOrderByPQ;
18
+ /**
19
+ * Flag to determine if all results are fetched from backend and results can be returned from priority queue.
20
+ */
21
+ isCompleted = false;
9
22
  /**
10
23
  * Represents an endpoint in handling an non-streaming order by query. For each processed orderby
11
24
  * result it returns 'payload' item of the result
@@ -19,10 +32,6 @@ export class NonStreamingOrderByEndpointComponent {
19
32
  this.priorityQueueBufferSize = priorityQueueBufferSize;
20
33
  this.offset = offset;
21
34
  this.emitRawOrderByPayload = emitRawOrderByPayload;
22
- /**
23
- * Flag to determine if all results are fetched from backend and results can be returned from priority queue.
24
- */
25
- this.isCompleted = false;
26
35
  const comparator = new OrderByComparator(this.sortOrders);
27
36
  this.nonStreamingOrderByPQ = new FixedSizePriorityQueue((a, b) => {
28
37
  return comparator.compareItems(b, a);
@@ -90,7 +99,6 @@ export class NonStreamingOrderByEndpointComponent {
90
99
  };
91
100
  }
92
101
  async buildFinalResultArray(resHeaders) {
93
- var _a;
94
102
  // Set isCompleted to true.
95
103
  this.isCompleted = true;
96
104
  // Reverse the priority queue to get the results in the correct order
@@ -113,7 +121,7 @@ export class NonStreamingOrderByEndpointComponent {
113
121
  }
114
122
  else {
115
123
  while (!this.nonStreamingOrderByPQ.isEmpty()) {
116
- buffer.push((_a = this.nonStreamingOrderByPQ.dequeue()) === null || _a === void 0 ? void 0 : _a.payload);
124
+ buffer.push(this.nonStreamingOrderByPQ.dequeue()?.payload);
117
125
  }
118
126
  }
119
127
  return {
@@ -1 +1 @@
1
- {"version":3,"file":"NonStreamingOrderByEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { OrderByComparator } from \"../orderByComparator.js\";\nimport type { NonStreamingOrderByResult } from \"../nonStreamingOrderByResult.js\";\nimport { FixedSizePriorityQueue } from \"../../utils/fixedSizePriorityQueue.js\";\nimport type { CosmosHeaders } from \"../headerUtils.js\";\nimport { getInitialHeader } from \"../headerUtils.js\";\n\n/**\n * @hidden\n * Represents an endpoint in handling an non-streaming order by query.\n */\nexport class NonStreamingOrderByEndpointComponent implements ExecutionContext {\n /**\n * A priority queue to store the final sorted results.\n */\n private nonStreamingOrderByPQ: FixedSizePriorityQueue<NonStreamingOrderByResult>;\n /**\n * Flag to determine if all results are fetched from backend and results can be returned from priority queue.\n */\n private isCompleted: boolean = false;\n /**\n * Represents an endpoint in handling an non-streaming order by query. For each processed orderby\n * result it returns 'payload' item of the result\n *\n * @param executionContext - Underlying Execution Context\n * @hidden\n */\n constructor(\n private executionContext: ExecutionContext,\n private sortOrders: any[],\n private priorityQueueBufferSize: number,\n private offset: number = 0,\n private emitRawOrderByPayload: boolean = false,\n ) {\n const comparator = new OrderByComparator(this.sortOrders);\n this.nonStreamingOrderByPQ = new FixedSizePriorityQueue<NonStreamingOrderByResult>(\n (a: NonStreamingOrderByResult, b: NonStreamingOrderByResult) => {\n return comparator.compareItems(b, a);\n },\n this.priorityQueueBufferSize,\n );\n }\n\n /**\n * Determine if there are still remaining resources to processs.\n * @returns true if there is other elements to process in the NonStreamingOrderByEndpointComponent.\n */\n public hasMoreResults(): boolean {\n return this.priorityQueueBufferSize > 0 && this.executionContext.hasMoreResults();\n }\n\n /**\n * Fetches the next batch of the result from the target container.\n * @param diagnosticNode - The diagnostic information for the request.\n */\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n if (this.isCompleted) {\n return {\n result: undefined,\n headers: getInitialHeader(),\n };\n }\n let resHeaders = getInitialHeader();\n // if size is 0, just return undefined to signal to more results. Valid if query is TOP 0 or LIMIT 0\n if (this.priorityQueueBufferSize <= 0) {\n return {\n result: undefined,\n headers: resHeaders,\n };\n }\n // If there are more results in backend, keep filling pq.\n if (this.executionContext.hasMoreResults()) {\n const response = await this.executionContext.fetchMore(diagnosticNode);\n resHeaders = response.headers;\n if (response === undefined || response.result === undefined) {\n this.isCompleted = true;\n if (!this.nonStreamingOrderByPQ.isEmpty()) {\n return this.buildFinalResultArray(resHeaders);\n }\n return { result: undefined, headers: resHeaders };\n }\n\n for (const item of response.result) {\n if (item !== undefined) {\n this.nonStreamingOrderByPQ.enqueue(item);\n }\n }\n }\n\n // If the backend has more results to fetch, return [] to signal that there are more results to fetch.\n if (this.executionContext.hasMoreResults()) {\n return {\n result: [],\n headers: resHeaders,\n };\n }\n\n // If all results are fetched from backend, prepare final results\n if (!this.executionContext.hasMoreResults() && !this.isCompleted) {\n this.isCompleted = true;\n return this.buildFinalResultArray(resHeaders);\n }\n\n // If pq is empty, return undefined to signal that there are no more results.\n return {\n result: undefined,\n headers: resHeaders,\n };\n }\n\n private async buildFinalResultArray(resHeaders: CosmosHeaders): Promise<Response<any>> {\n // Set isCompleted to true.\n this.isCompleted = true;\n // Reverse the priority queue to get the results in the correct order\n this.nonStreamingOrderByPQ = this.nonStreamingOrderByPQ.reverse();\n // For offset limit case we set the size of priority queue to offset + limit\n // and we drain offset number of items from the priority queue\n while (\n this.offset < this.priorityQueueBufferSize &&\n this.offset > 0 &&\n !this.nonStreamingOrderByPQ.isEmpty()\n ) {\n this.nonStreamingOrderByPQ.dequeue();\n this.offset--;\n }\n\n // If pq is not empty, return the result from pq.\n if (!this.nonStreamingOrderByPQ.isEmpty()) {\n const buffer: any[] = [];\n if (this.emitRawOrderByPayload) {\n while (!this.nonStreamingOrderByPQ.isEmpty()) {\n buffer.push(this.nonStreamingOrderByPQ.dequeue());\n }\n } else {\n while (!this.nonStreamingOrderByPQ.isEmpty()) {\n buffer.push(this.nonStreamingOrderByPQ.dequeue()?.payload);\n }\n }\n return {\n result: buffer,\n headers: resHeaders,\n };\n }\n }\n}\n"]}
1
+ {"version":3,"file":"NonStreamingOrderByEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/NonStreamingOrderByEndpointComponent.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { OrderByComparator } from \"../orderByComparator.js\";\nimport type { NonStreamingOrderByResult } from \"../nonStreamingOrderByResult.js\";\nimport { FixedSizePriorityQueue } from \"../../utils/fixedSizePriorityQueue.js\";\nimport type { CosmosHeaders } from \"../headerUtils.js\";\nimport { getInitialHeader } from \"../headerUtils.js\";\n\n/**\n * @hidden\n * Represents an endpoint in handling an non-streaming order by query.\n */\nexport class NonStreamingOrderByEndpointComponent implements ExecutionContext {\n /**\n * A priority queue to store the final sorted results.\n */\n private nonStreamingOrderByPQ: FixedSizePriorityQueue<NonStreamingOrderByResult>;\n /**\n * Flag to determine if all results are fetched from backend and results can be returned from priority queue.\n */\n private isCompleted: boolean = false;\n /**\n * Represents an endpoint in handling an non-streaming order by query. For each processed orderby\n * result it returns 'payload' item of the result\n *\n * @param executionContext - Underlying Execution Context\n * @hidden\n */\n constructor(\n private executionContext: ExecutionContext,\n private sortOrders: any[],\n private priorityQueueBufferSize: number,\n private offset: number = 0,\n private emitRawOrderByPayload: boolean = false,\n ) {\n const comparator = new OrderByComparator(this.sortOrders);\n this.nonStreamingOrderByPQ = new FixedSizePriorityQueue<NonStreamingOrderByResult>(\n (a: NonStreamingOrderByResult, b: NonStreamingOrderByResult) => {\n return comparator.compareItems(b, a);\n },\n this.priorityQueueBufferSize,\n );\n }\n\n /**\n * Determine if there are still remaining resources to processs.\n * @returns true if there is other elements to process in the NonStreamingOrderByEndpointComponent.\n */\n public hasMoreResults(): boolean {\n return this.priorityQueueBufferSize > 0 && this.executionContext.hasMoreResults();\n }\n\n /**\n * Fetches the next batch of the result from the target container.\n * @param diagnosticNode - The diagnostic information for the request.\n */\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n if (this.isCompleted) {\n return {\n result: undefined,\n headers: getInitialHeader(),\n };\n }\n let resHeaders = getInitialHeader();\n // if size is 0, just return undefined to signal to more results. Valid if query is TOP 0 or LIMIT 0\n if (this.priorityQueueBufferSize <= 0) {\n return {\n result: undefined,\n headers: resHeaders,\n };\n }\n // If there are more results in backend, keep filling pq.\n if (this.executionContext.hasMoreResults()) {\n const response = await this.executionContext.fetchMore(diagnosticNode);\n resHeaders = response.headers;\n if (response === undefined || response.result === undefined) {\n this.isCompleted = true;\n if (!this.nonStreamingOrderByPQ.isEmpty()) {\n return this.buildFinalResultArray(resHeaders);\n }\n return { result: undefined, headers: resHeaders };\n }\n\n for (const item of response.result) {\n if (item !== undefined) {\n this.nonStreamingOrderByPQ.enqueue(item);\n }\n }\n }\n\n // If the backend has more results to fetch, return [] to signal that there are more results to fetch.\n if (this.executionContext.hasMoreResults()) {\n return {\n result: [],\n headers: resHeaders,\n };\n }\n\n // If all results are fetched from backend, prepare final results\n if (!this.executionContext.hasMoreResults() && !this.isCompleted) {\n this.isCompleted = true;\n return this.buildFinalResultArray(resHeaders);\n }\n\n // If pq is empty, return undefined to signal that there are no more results.\n return {\n result: undefined,\n headers: resHeaders,\n };\n }\n\n private async buildFinalResultArray(resHeaders: CosmosHeaders): Promise<Response<any>> {\n // Set isCompleted to true.\n this.isCompleted = true;\n // Reverse the priority queue to get the results in the correct order\n this.nonStreamingOrderByPQ = this.nonStreamingOrderByPQ.reverse();\n // For offset limit case we set the size of priority queue to offset + limit\n // and we drain offset number of items from the priority queue\n while (\n this.offset < this.priorityQueueBufferSize &&\n this.offset > 0 &&\n !this.nonStreamingOrderByPQ.isEmpty()\n ) {\n this.nonStreamingOrderByPQ.dequeue();\n this.offset--;\n }\n\n // If pq is not empty, return the result from pq.\n if (!this.nonStreamingOrderByPQ.isEmpty()) {\n const buffer: any[] = [];\n if (this.emitRawOrderByPayload) {\n while (!this.nonStreamingOrderByPQ.isEmpty()) {\n buffer.push(this.nonStreamingOrderByPQ.dequeue());\n }\n } else {\n while (!this.nonStreamingOrderByPQ.isEmpty()) {\n buffer.push(this.nonStreamingOrderByPQ.dequeue()?.payload);\n }\n }\n return {\n result: buffer,\n headers: resHeaders,\n };\n }\n }\n}\n"]}
@@ -1,6 +1,9 @@
1
1
  import { getInitialHeader, mergeHeaders } from "../headerUtils.js";
2
2
  /** @hidden */
3
3
  export class OffsetLimitEndpointComponent {
4
+ executionContext;
5
+ offset;
6
+ limit;
4
7
  constructor(executionContext, offset, limit) {
5
8
  this.executionContext = executionContext;
6
9
  this.offset = offset;
@@ -1 +1 @@
1
- {"version":3,"file":"OffsetLimitEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEnE,cAAc;AACd,MAAM,OAAO,4BAA4B;IACvC,YACU,gBAAkC,EAClC,MAAc,EACd,KAAa;QAFb,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAQ;IACpB,CAAC;IAEG,cAAc;QACnB,OAAO,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IACvF,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,MAAM,gBAAgB,GAAG,gBAAgB,EAAE,CAAC;QAC5C,MAAM,MAAM,GAAU,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,YAAY,CAAC,gBAAgB,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;QACjD,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;QAED,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACpB,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC;iBAAM,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;gBAC1B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClB,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,CAAC;QACH,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC;IACvD,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { getInitialHeader, mergeHeaders } from \"../headerUtils.js\";\n\n/** @hidden */\nexport class OffsetLimitEndpointComponent implements ExecutionContext {\n constructor(\n private executionContext: ExecutionContext,\n private offset: number,\n private limit: number,\n ) {}\n\n public hasMoreResults(): boolean {\n return (this.offset > 0 || this.limit > 0) && this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n const aggregateHeaders = getInitialHeader();\n const buffer: any[] = [];\n const response = await this.executionContext.fetchMore(diagnosticNode);\n mergeHeaders(aggregateHeaders, response.headers);\n if (response === undefined || response.result === undefined) {\n return { result: undefined, headers: response.headers };\n }\n\n for (const item of response.result) {\n if (this.offset > 0) {\n this.offset--;\n } else if (this.limit > 0) {\n buffer.push(item);\n this.limit--;\n }\n }\n return { result: buffer, headers: aggregateHeaders };\n }\n}\n"]}
1
+ {"version":3,"file":"OffsetLimitEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/OffsetLimitEndpointComponent.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEnE,cAAc;AACd,MAAM,OAAO,4BAA4B;IAE7B;IACA;IACA;IAHV,YACU,gBAAkC,EAClC,MAAc,EACd,KAAa;QAFb,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAQ;IACpB,CAAC;IAEG,cAAc;QACnB,OAAO,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IACvF,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,MAAM,gBAAgB,GAAG,gBAAgB,EAAE,CAAC;QAC5C,MAAM,MAAM,GAAU,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,YAAY,CAAC,gBAAgB,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;QACjD,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;QAED,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACpB,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC;iBAAM,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;gBAC1B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClB,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,CAAC;QACH,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC;IACvD,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { getInitialHeader, mergeHeaders } from \"../headerUtils.js\";\n\n/** @hidden */\nexport class OffsetLimitEndpointComponent implements ExecutionContext {\n constructor(\n private executionContext: ExecutionContext,\n private offset: number,\n private limit: number,\n ) {}\n\n public hasMoreResults(): boolean {\n return (this.offset > 0 || this.limit > 0) && this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n const aggregateHeaders = getInitialHeader();\n const buffer: any[] = [];\n const response = await this.executionContext.fetchMore(diagnosticNode);\n mergeHeaders(aggregateHeaders, response.headers);\n if (response === undefined || response.result === undefined) {\n return { result: undefined, headers: response.headers };\n }\n\n for (const item of response.result) {\n if (this.offset > 0) {\n this.offset--;\n } else if (this.limit > 0) {\n buffer.push(item);\n this.limit--;\n }\n }\n return { result: buffer, headers: aggregateHeaders };\n }\n}\n"]}
@@ -1,5 +1,7 @@
1
1
  /** @hidden */
2
2
  export class OrderByEndpointComponent {
3
+ executionContext;
4
+ emitRawOrderByPayload;
3
5
  /**
4
6
  * Represents an endpoint in handling an order by query. For each processed orderby
5
7
  * result it returns 'payload' item of the result
@@ -1 +1 @@
1
- {"version":3,"file":"OrderByEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.ts"],"names":[],"mappings":"AAMA,cAAc;AACd,MAAM,OAAO,wBAAwB;IACnC;;;;;;OAMG;IACH,YACU,gBAAkC,EAClC,wBAAiC,KAAK;QADtC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,0BAAqB,GAArB,qBAAqB,CAAiB;IAC7C,CAAC;IACJ;;;OAGG;IACI,cAAc;QACnB,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,MAAM,MAAM,GAAU,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;QACD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAC/B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACpB,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC;QAED,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\n\n/** @hidden */\nexport class OrderByEndpointComponent implements ExecutionContext {\n /**\n * Represents an endpoint in handling an order by query. For each processed orderby\n * result it returns 'payload' item of the result\n *\n * @param executionContext - Underlying Execution Context\n * @hidden\n */\n constructor(\n private executionContext: ExecutionContext,\n private emitRawOrderByPayload: boolean = false,\n ) {}\n /**\n * Determine if there are still remaining resources to processs.\n * @returns true if there is other elements to process in the OrderByEndpointComponent.\n */\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n const buffer: any[] = [];\n const response = await this.executionContext.fetchMore(diagnosticNode);\n if (response === undefined || response.result === undefined) {\n return { result: undefined, headers: response.headers };\n }\n for (const item of response.result) {\n if (this.emitRawOrderByPayload) {\n buffer.push(item);\n } else {\n buffer.push(item.payload);\n }\n }\n\n return { result: buffer, headers: response.headers };\n }\n}\n"]}
1
+ {"version":3,"file":"OrderByEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/OrderByEndpointComponent.ts"],"names":[],"mappings":"AAMA,cAAc;AACd,MAAM,OAAO,wBAAwB;IASzB;IACA;IATV;;;;;;OAMG;IACH,YACU,gBAAkC,EAClC,wBAAiC,KAAK;QADtC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,0BAAqB,GAArB,qBAAqB,CAAiB;IAC7C,CAAC;IACJ;;;OAGG;IACI,cAAc;QACnB,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,MAAM,MAAM,GAAU,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;QACD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAC/B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACpB,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC;QAED,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\n\n/** @hidden */\nexport class OrderByEndpointComponent implements ExecutionContext {\n /**\n * Represents an endpoint in handling an order by query. For each processed orderby\n * result it returns 'payload' item of the result\n *\n * @param executionContext - Underlying Execution Context\n * @hidden\n */\n constructor(\n private executionContext: ExecutionContext,\n private emitRawOrderByPayload: boolean = false,\n ) {}\n /**\n * Determine if there are still remaining resources to processs.\n * @returns true if there is other elements to process in the OrderByEndpointComponent.\n */\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n const buffer: any[] = [];\n const response = await this.executionContext.fetchMore(diagnosticNode);\n if (response === undefined || response.result === undefined) {\n return { result: undefined, headers: response.headers };\n }\n for (const item of response.result) {\n if (this.emitRawOrderByPayload) {\n buffer.push(item);\n } else {\n buffer.push(item.payload);\n }\n }\n\n return { result: buffer, headers: response.headers };\n }\n}\n"]}
@@ -1,6 +1,8 @@
1
1
  import { hashObject } from "../../utils/hashObject.js";
2
2
  /** @hidden */
3
3
  export class OrderedDistinctEndpointComponent {
4
+ executionContext;
5
+ hashedLastResult;
4
6
  constructor(executionContext) {
5
7
  this.executionContext = executionContext;
6
8
  }
@@ -1 +1 @@
1
- {"version":3,"file":"OrderedDistinctEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,cAAc;AACd,MAAM,OAAO,gCAAgC;IAE3C,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;IAAG,CAAC;IAEnD,cAAc;QACnB,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,MAAM,MAAM,GAAU,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;QACD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,YAAY,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC;gBAC5C,IAAI,YAAY,KAAK,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBAC3C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAClB,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAC;gBACvC,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\n\n/** @hidden */\nexport class OrderedDistinctEndpointComponent implements ExecutionContext {\n private hashedLastResult: string;\n constructor(private executionContext: ExecutionContext) {}\n\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n const buffer: any[] = [];\n const response = await this.executionContext.fetchMore(diagnosticNode);\n if (response === undefined || response.result === undefined) {\n return { result: undefined, headers: response.headers };\n }\n for (const item of response.result) {\n if (item) {\n const hashedResult = await hashObject(item);\n if (hashedResult !== this.hashedLastResult) {\n buffer.push(item);\n this.hashedLastResult = hashedResult;\n }\n }\n }\n return { result: buffer, headers: response.headers };\n }\n}\n"]}
1
+ {"version":3,"file":"OrderedDistinctEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/OrderedDistinctEndpointComponent.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,cAAc;AACd,MAAM,OAAO,gCAAgC;IAEvB;IADZ,gBAAgB,CAAS;IACjC,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;IAAG,CAAC;IAEnD,cAAc;QACnB,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,MAAM,MAAM,GAAU,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;QACD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,YAAY,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC;gBAC5C,IAAI,YAAY,KAAK,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBAC3C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAClB,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAC;gBACvC,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\n\n/** @hidden */\nexport class OrderedDistinctEndpointComponent implements ExecutionContext {\n private hashedLastResult: string;\n constructor(private executionContext: ExecutionContext) {}\n\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n const buffer: any[] = [];\n const response = await this.executionContext.fetchMore(diagnosticNode);\n if (response === undefined || response.result === undefined) {\n return { result: undefined, headers: response.headers };\n }\n for (const item of response.result) {\n if (item) {\n const hashedResult = await hashObject(item);\n if (hashedResult !== this.hashedLastResult) {\n buffer.push(item);\n this.hashedLastResult = hashedResult;\n }\n }\n }\n return { result: buffer, headers: response.headers };\n }\n}\n"]}
@@ -1,6 +1,8 @@
1
1
  import { hashObject } from "../../utils/hashObject.js";
2
2
  /** @hidden */
3
3
  export class UnorderedDistinctEndpointComponent {
4
+ executionContext;
5
+ hashedResults;
4
6
  constructor(executionContext) {
5
7
  this.executionContext = executionContext;
6
8
  this.hashedResults = new Set();
@@ -1 +1 @@
1
- {"version":3,"file":"UnorderedDistinctEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,cAAc;AACd,MAAM,OAAO,kCAAkC;IAE7C,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QACpD,IAAI,CAAC,aAAa,GAAG,IAAI,GAAG,EAAE,CAAC;IACjC,CAAC;IAEM,cAAc;QACnB,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,MAAM,MAAM,GAAU,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;QACD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,YAAY,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC;gBAC5C,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,CAAC;oBAC1C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAClB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;gBACvC,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\n\n/** @hidden */\nexport class UnorderedDistinctEndpointComponent implements ExecutionContext {\n private hashedResults: Set<string>;\n constructor(private executionContext: ExecutionContext) {\n this.hashedResults = new Set();\n }\n\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n const buffer: any[] = [];\n const response = await this.executionContext.fetchMore(diagnosticNode);\n if (response === undefined || response.result === undefined) {\n return { result: undefined, headers: response.headers };\n }\n for (const item of response.result) {\n if (item) {\n const hashedResult = await hashObject(item);\n if (!this.hashedResults.has(hashedResult)) {\n buffer.push(item);\n this.hashedResults.add(hashedResult);\n }\n }\n }\n return { result: buffer, headers: response.headers };\n }\n}\n"]}
1
+ {"version":3,"file":"UnorderedDistinctEndpointComponent.js","sourceRoot":"","sources":["../../../../src/queryExecutionContext/EndpointComponent/UnorderedDistinctEndpointComponent.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,cAAc;AACd,MAAM,OAAO,kCAAkC;IAEzB;IADZ,aAAa,CAAc;IACnC,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QACpD,IAAI,CAAC,aAAa,GAAG,IAAI,GAAG,EAAE,CAAC;IACjC,CAAC;IAEM,cAAc;QACnB,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,cAAuC;QAC5D,MAAM,MAAM,GAAU,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;QACvE,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAC5D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC1D,CAAC;QACD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACnC,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,YAAY,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC;gBAC5C,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,CAAC;oBAC1C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAClB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;gBACvC,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport type { Response } from \"../../request/index.js\";\nimport type { ExecutionContext } from \"../ExecutionContext.js\";\nimport { hashObject } from \"../../utils/hashObject.js\";\nimport type { DiagnosticNodeInternal } from \"../../diagnostics/DiagnosticNodeInternal.js\";\n\n/** @hidden */\nexport class UnorderedDistinctEndpointComponent implements ExecutionContext {\n private hashedResults: Set<string>;\n constructor(private executionContext: ExecutionContext) {\n this.hashedResults = new Set();\n }\n\n public hasMoreResults(): boolean {\n return this.executionContext.hasMoreResults();\n }\n\n public async fetchMore(diagnosticNode?: DiagnosticNodeInternal): Promise<Response<any>> {\n const buffer: any[] = [];\n const response = await this.executionContext.fetchMore(diagnosticNode);\n if (response === undefined || response.result === undefined) {\n return { result: undefined, headers: response.headers };\n }\n for (const item of response.result) {\n if (item) {\n const hashedResult = await hashObject(item);\n if (!this.hashedResults.has(hashedResult)) {\n buffer.push(item);\n this.hashedResults.add(hashedResult);\n }\n }\n }\n return { result: buffer, headers: response.headers };\n }\n}\n"]}
@@ -9,6 +9,10 @@ export var FetchResultType;
9
9
  })(FetchResultType || (FetchResultType = {}));
10
10
  /** @hidden */
11
11
  export class FetchResult {
12
+ feedResponse;
13
+ headers;
14
+ fetchResultType;
15
+ error;
12
16
  /**
13
17
  * Wraps fetch results for the document producer.
14
18
  * This allows the document producer to buffer exceptions so that actual results don't get flushed during splits.
@@ -1 +1 @@
1
- {"version":3,"file":"FetchResult.js","sourceRoot":"","sources":["../../../src/queryExecutionContext/FetchResult.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAClC,cAAc;AACd,MAAM,CAAN,IAAY,eAIX;AAJD,WAAY,eAAe;IACzB,qDAAU,CAAA;IACV,+DAAe,CAAA;IACf,yDAAY,CAAA;AACd,CAAC,EAJW,eAAe,KAAf,eAAe,QAI1B;AAED,cAAc;AACd,MAAM,OAAO,WAAW;IAKtB;;;;;;;OAOG;IACH,YAAY,YAAqB,EAAE,KAAc,EAAE,OAAiB;QAClE,2BAA2B;QAC3B,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;YACjC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC,MAAM,CAAC;QAChD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC,SAAS,CAAC;QACnD,CAAC;IACH,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n/** @hidden */\nexport enum FetchResultType {\n \"Done\" = 0,\n \"Exception\" = 1,\n \"Result\" = 2,\n}\n\n/** @hidden */\nexport class FetchResult {\n public feedResponse: any;\n public headers: any;\n public fetchResultType: FetchResultType;\n public error: any;\n /**\n * Wraps fetch results for the document producer.\n * This allows the document producer to buffer exceptions so that actual results don't get flushed during splits.\n *\n * @param feedReponse - The response the document producer got back on a successful fetch\n * @param error - The exception meant to be buffered on an unsuccessful fetch\n * @hidden\n */\n constructor(feedResponse: unknown, error: unknown, headers?: unknown) {\n // TODO: feedResponse/error\n if (feedResponse !== undefined) {\n this.feedResponse = feedResponse;\n this.headers = headers;\n this.fetchResultType = FetchResultType.Result;\n } else {\n this.error = error;\n this.fetchResultType = FetchResultType.Exception;\n }\n }\n}\n"]}
1
+ {"version":3,"file":"FetchResult.js","sourceRoot":"","sources":["../../../src/queryExecutionContext/FetchResult.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAClC,cAAc;AACd,MAAM,CAAN,IAAY,eAIX;AAJD,WAAY,eAAe;IACzB,qDAAU,CAAA;IACV,+DAAe,CAAA;IACf,yDAAY,CAAA;AACd,CAAC,EAJW,eAAe,KAAf,eAAe,QAI1B;AAED,cAAc;AACd,MAAM,OAAO,WAAW;IACf,YAAY,CAAM;IAClB,OAAO,CAAM;IACb,eAAe,CAAkB;IACjC,KAAK,CAAM;IAClB;;;;;;;OAOG;IACH,YAAY,YAAqB,EAAE,KAAc,EAAE,OAAiB;QAClE,2BAA2B;QAC3B,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;YACjC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC,MAAM,CAAC;QAChD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC,SAAS,CAAC;QACnD,CAAC;IACH,CAAC;CACF","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n/** @hidden */\nexport enum FetchResultType {\n \"Done\" = 0,\n \"Exception\" = 1,\n \"Result\" = 2,\n}\n\n/** @hidden */\nexport class FetchResult {\n public feedResponse: any;\n public headers: any;\n public fetchResultType: FetchResultType;\n public error: any;\n /**\n * Wraps fetch results for the document producer.\n * This allows the document producer to buffer exceptions so that actual results don't get flushed during splits.\n *\n * @param feedReponse - The response the document producer got back on a successful fetch\n * @param error - The exception meant to be buffered on an unsuccessful fetch\n * @hidden\n */\n constructor(feedResponse: unknown, error: unknown, headers?: unknown) {\n // TODO: feedResponse/error\n if (feedResponse !== undefined) {\n this.feedResponse = feedResponse;\n this.headers = headers;\n this.fetchResultType = FetchResultType.Result;\n } else {\n this.error = error;\n this.fetchResultType = FetchResultType.Exception;\n }\n }\n}\n"]}
@@ -15,9 +15,19 @@ var STATES;
15
15
  })(STATES || (STATES = {}));
16
16
  /** @hidden */
17
17
  export class DefaultQueryExecutionContext {
18
+ static STATES = STATES;
19
+ resources; // TODO: any resources
20
+ currentIndex;
21
+ currentPartitionIndex;
22
+ fetchFunctions;
23
+ options; // TODO: any options
24
+ continuationToken; // TODO: any continuation
18
25
  get continuation() {
19
26
  return this.continuationToken;
20
27
  }
28
+ state;
29
+ nextFetchFunction;
30
+ correlatedActivityId;
21
31
  /**
22
32
  * Provides the basic Query Execution Context.
23
33
  * This wraps the internal logic query execution using provided fetch functions
@@ -136,7 +146,10 @@ export class DefaultQueryExecutionContext {
136
146
  if (this.options && this.options.bufferItems === true) {
137
147
  const fetchFunction = this.fetchFunctions[this.currentPartitionIndex];
138
148
  this.nextFetchFunction = fetchFunction
139
- ? fetchFunction(childDiagnosticNode, Object.assign(Object.assign({}, this.options), { continuationToken: this.continuationToken }), this.correlatedActivityId)
149
+ ? fetchFunction(childDiagnosticNode, {
150
+ ...this.options,
151
+ continuationToken: this.continuationToken,
152
+ }, this.correlatedActivityId)
140
153
  : undefined;
141
154
  }
142
155
  }
@@ -177,5 +190,4 @@ export class DefaultQueryExecutionContext {
177
190
  return res;
178
191
  }
179
192
  }
180
- DefaultQueryExecutionContext.STATES = STATES;
181
193
  //# sourceMappingURL=defaultQueryExecutionContext.js.map