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