/** * This file is part of the @egodigital/egoose distribution. * Copyright (c) e.GO Digital GmbH, Aachen, Germany (https://www.e-go-digital.com/) * * @egodigital/egoose is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, version 3. * * @egodigital/egoose is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see . */ import { MongoDatabase } from '../mongo'; import { StatisticProviderBase } from '../statistics'; import * as mongoose from 'mongoose'; /** * A basic statistic provider that loads data from Mongo database. */ export declare abstract class MongoDatabaseStatisticProviderBase extends StatisticProviderBase { readonly database: TDatabase; /** * Initializes a new instance of that class. * * @param {TDatabase} database The underlying database connection. */ constructor(database: TDatabase); /** @inheritdoc */ close(): Promise; /** * Counts all documents of a collection. * * @param {Function} modelSelector The function that returns the model to use. * @param {any} [filter] The optional filter. * * @return {Promise} The promise that contains the number of documents. */ protected countDocuments(modelSelector: (db: TDatabase) => mongoose.Model, filter?: any): Promise; }