UNPKG

@azure/cosmos

Version:
55 lines 2.82 kB
// Copyright (c) Microsoft Corporation. // Licensed under the MIT License. import { MetadataLookUpType } from "../CosmosDiagnostics.js"; import { getIdFromLink } from "../common/helper.js"; import { withMetadataDiagnostics } from "../utils/diagnostics.js"; import { createCompleteRoutingMap } from "./CollectionRoutingMapFactory.js"; import { hashPartitionKey, binarySearchOnPartitionKeyRanges } from "../utils/hashing/hash.js"; /** @hidden */ export class PartitionKeyRangeCache { clientContext; collectionRoutingMapByCollectionId; constructor(clientContext) { this.clientContext = clientContext; this.collectionRoutingMapByCollectionId = {}; } /** * Finds or Instantiates the requested Collection Routing Map * @param collectionLink - Requested collectionLink * @hidden */ async onCollectionRoutingMap(collectionLink, diagnosticNode, forceRefresh = false) { const collectionId = getIdFromLink(collectionLink); if (this.collectionRoutingMapByCollectionId[collectionId] === undefined || forceRefresh) { this.collectionRoutingMapByCollectionId[collectionId] = this.requestCollectionRoutingMap(collectionLink, diagnosticNode); } return this.collectionRoutingMapByCollectionId[collectionId]; } /** * Given the query ranges and a collection, invokes the callback on the list of overlapping partition key ranges * @hidden */ async getOverlappingRanges(collectionLink, queryRange, diagnosticNode, forceRefresh = false) { const crm = await this.onCollectionRoutingMap(collectionLink, diagnosticNode, forceRefresh); return crm.getOverlappingRanges(queryRange); } async requestCollectionRoutingMap(collectionLink, diagnosticNode) { const { resources } = await withMetadataDiagnostics(async (metadataDiagnostics) => { return this.clientContext .queryPartitionKeyRanges(collectionLink) .fetchAllInternal(metadataDiagnostics); }, diagnosticNode, MetadataLookUpType.PartitionKeyRangeLookUp); return createCompleteRoutingMap(resources.map((r) => [r, true])); } /** * Given a partition key, returns the partition key range id * @internal */ async getPartitionKeyRangeIdFromPartitionKey(collectionLink, partitionKey, partitionKeyDefinition, diagnosticNode) { const hashedPartitionKey = hashPartitionKey(partitionKey, partitionKeyDefinition); const partitionKeyRanges = (await this.onCollectionRoutingMap(collectionLink, diagnosticNode)).getOrderedParitionKeyRanges(); const partitionKeyRangeId = binarySearchOnPartitionKeyRanges(partitionKeyRanges, hashedPartitionKey); return partitionKeyRangeId; } } //# sourceMappingURL=partitionKeyRangeCache.js.map