All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.azure.cosmos.spark.ItemsScan.scala Maven / Gradle / Ivy

// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

package com.azure.cosmos.spark

import com.azure.cosmos.models.PartitionKeyDefinition
import org.apache.spark.broadcast.Broadcast
import org.apache.spark.sql.SparkSession
import org.apache.spark.sql.connector.expressions.NamedReference
import org.apache.spark.sql.connector.read.SupportsRuntimeFiltering
import org.apache.spark.sql.sources.Filter
import org.apache.spark.sql.types.StructType

private[spark] class ItemsScan(session: SparkSession,
                               schema: StructType,
                               config: Map[String, String],
                               readConfig: CosmosReadConfig,
                               analyzedFilters: AnalyzedAggregatedFilters,
                               cosmosClientStateHandles: Broadcast[CosmosClientMetadataCachesSnapshots],
                               diagnosticsConfig: DiagnosticsConfig,
                               sparkEnvironmentInfo: String,
                               partitionKeyDefinition: PartitionKeyDefinition)
  extends ItemsScanBase(
    session,
    schema,
    config,
    readConfig,
    analyzedFilters,
    cosmosClientStateHandles,
    diagnosticsConfig,
    sparkEnvironmentInfo,
    partitionKeyDefinition)
    with SupportsRuntimeFiltering { // SupportsRuntimeFiltering extends scan
  override def filterAttributes(): Array[NamedReference] = {
    runtimeFilterAttributesCore()
  }

  override def filter(filters: Array[Filter]): Unit = {
    runtimeFilterCore(filters)
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy