/**
* 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;
}