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

mongo4cats.operations.Accumulator.scala Maven / Gradle / Ivy

/*
 * Copyright 2020 Kirill5k
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package mongo4cats.operations

import com.mongodb.client.model.{Accumulators, BsonField}
import mongo4cats.AsJava

trait Accumulator {

  /** Gets a field name for a \$group operation representing the sum of the values of the given expression when applied to all members of
    * the group.
    *
    * @param fieldName
    *   the field name
    * @param expression
    *   the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]]
    * @return
    *   the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/sum/]]
    */
  def sum[T](fieldName: String, expression: T): Accumulator

  /** Gets a field name for a \$group operation representing the average of the values of the given expression when applied to all members
    * of the group.
    *
    * @param fieldName
    *   the field name
    * @param expression
    *   the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]]
    * @return
    *   the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/avg/]]
    */
  def avg[T](fieldName: String, expression: T): Accumulator

  /** Gets a field name for a \$group operation representing the value of the given expression when applied to the first member of the
    * group.
    *
    * @param fieldName
    *   the field name
    * @param expression
    *   the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]]
    * @return
    *   the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/first/]]
    */
  def first[T](fieldName: String, expression: T): Accumulator

  /** Gets a field name for a \$group operation representing the value of the given expression when applied to the last member of the group.
    *
    * @param fieldName
    *   the field name
    * @param expression
    *   the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]]
    * @return
    *   the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/last/]]
    */
  def last[T](fieldName: String, expression: T): Accumulator

  /** Gets a field name for a \$group operation representing the maximum of the values of the given expression when applied to all members
    * of the group.
    *
    * @param fieldName
    *   the field name
    * @param expression
    *   the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]]
    * @return
    *   the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/max/]]
    */
  def max[T](fieldName: String, expression: T): Accumulator

  /** Gets a field name for a \$group operation representing the minimum of the values of the given expression when applied to all members
    * of the group.
    *
    * @param fieldName
    *   the field name
    * @param expression
    *   the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]]
    * @return
    *   the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/min/]]
    */
  def min[T](fieldName: String, expression: T): Accumulator

  /** Gets a field name for a \$group operation representing an array of all values that results from applying an expression to each
    * document in a group of documents that share the same group by key.
    *
    * @param fieldName
    *   the field name
    * @param expression
    *   the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]]
    * @return
    *   the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/push/]]
    */
  def push[T](fieldName: String, expression: T): Accumulator

  /** Gets a field name for a \$group operation representing all unique values that results from applying the given expression to each
    * document in a group of documents that share the same group by key.
    *
    * @param fieldName
    *   the field name
    * @param expression
    *   the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]]
    * @return
    *   the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/addToSet/]]
    */
  def addToSet[T](fieldName: String, expression: T): Accumulator

  /** Gets a field name for a \$group operation representing the sample standard deviation of the values of the given expression when
    * applied to all members of the group.
    *
    * 

Use if the values encompass the entire population of data you want to represent and do not wish to generalize about a larger * population.

* * @param fieldName * the field name * @param expression * the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]] * @return * the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/stdDevPop/]] * @since 3.2 */ def stdDevPop[T](fieldName: String, expression: T): Accumulator /** Gets a field name for a \$group operation representing the sample standard deviation of the values of the given expression when * applied to all members of the group. * *

Use if the values encompass a sample of a population of data from which to generalize about the population.

* * @param fieldName * the field name * @param expression * the expression [[https://docs.mongodb.com/manual/meta/aggregation-quick-reference/#std-label-aggregation-expressions]] * @return * the accumulator [[https://docs.mongodb.com/manual/reference/operator/aggregation/stdDevSamp/]] */ def stdDevSamp[T](fieldName: String, expression: T): Accumulator /** Merges 2 field accumulators together. * * @param anotherAccumulator * the accumulator to be merged with * @return * the accumulator */ def combinedWith(anotherAccumulator: Accumulator): Accumulator private[mongo4cats] def accumulators: List[BsonField] private[mongo4cats] def toBson: java.util.List[BsonField] } object Accumulator extends AsJava { private val empty: Accumulator = AccumulatorBuilder(Nil) /** Creates an \$accumulator pipeline stage * * @param fieldName * the field name * @param initFunction * a function used to initialize the state * @param accumulateFunction * a function used to accumulate documents * @param mergeFunction * a function used to merge two internal states, e.g. accumulated on different shards or threads. It returns the resulting state of the * accumulator. * @param initArgs * init function’s arguments * @param accumulateArgs * additional accumulate function’s arguments. The first argument to the function is ‘state’. * @param finalizeFunction * a function used to finalize the state and return the result * @param lang * a language specifier * @return * the \$accumulator pipeline stage [[https://docs.mongodb.com/manual/reference/operator/aggregation/accumulator/]] * @since 4.1 */ def apply( fieldName: String, initFunction: String, accumulateFunction: String, mergeFunction: String, initArgs: List[String] = Nil, accumulateArgs: List[String] = Nil, finalizeFunction: Option[String] = None, lang: String = "jr" ): Accumulator = AccumulatorBuilder { Accumulators.accumulator( fieldName, initFunction, if (initArgs.nonEmpty) asJava(initArgs) else null, accumulateFunction, if (accumulateArgs.nonEmpty) asJava(accumulateArgs) else null, mergeFunction, finalizeFunction.orNull, lang ) :: Nil } def sum[T](fieldName: String, expression: T): Accumulator = empty.sum(fieldName, expression) def avg[T](fieldName: String, expression: T): Accumulator = empty.avg(fieldName, expression) def first[T](fieldName: String, expression: T): Accumulator = empty.first(fieldName, expression) def last[T](fieldName: String, expression: T): Accumulator = empty.last(fieldName, expression) def max[T](fieldName: String, expression: T): Accumulator = empty.max(fieldName, expression) def min[T](fieldName: String, expression: T): Accumulator = empty.min(fieldName, expression) def push[T](fieldName: String, expression: T): Accumulator = empty.push(fieldName, expression) def addToSet[T](fieldName: String, expression: T): Accumulator = empty.addToSet(fieldName, expression) def stdDevPop[T](fieldName: String, expression: T): Accumulator = empty.stdDevPop(fieldName, expression) def stdDevSamp[T](fieldName: String, expression: T): Accumulator = empty.stdDevSamp(fieldName, expression) } final private case class AccumulatorBuilder( override val accumulators: List[BsonField] ) extends Accumulator with AsJava { def sum[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.sum(fieldName, expression) :: accumulators) def avg[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.avg(fieldName, expression) :: accumulators) def first[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.first(fieldName, expression) :: accumulators) def last[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.last(fieldName, expression) :: accumulators) def max[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.max(fieldName, expression) :: accumulators) def min[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.min(fieldName, expression) :: accumulators) def push[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.push(fieldName, expression) :: accumulators) def addToSet[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.addToSet(fieldName, expression) :: accumulators) def stdDevPop[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.stdDevPop(fieldName, expression) :: accumulators) def stdDevSamp[T](fieldName: String, expression: T): Accumulator = AccumulatorBuilder(Accumulators.stdDevSamp(fieldName, expression) :: accumulators) override def combinedWith(anotherAccumulator: Accumulator): Accumulator = AccumulatorBuilder(anotherAccumulator.accumulators ::: accumulators) override private[mongo4cats] def toBson: java.util.List[BsonField] = asJava(accumulators.reverse) }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy