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

com.redhat.lightblue.mongo.crud.DocFinder Maven / Gradle / Ivy

/*
 Copyright 2013 Red Hat, Inc. and/or its affiliates.

 This file is part of lightblue.

 This program is free software: you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
 the Free Software Foundation, either version 3 of the License, or
 (at your option) any later version.

 This program 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 General Public License for more details.

 You should have received a copy of the GNU General Public License
 along with this program.  If not, see .
 */
package com.redhat.lightblue.mongo.crud;

import com.mongodb.DBCollection;
import com.mongodb.DBObject;

import com.redhat.lightblue.crud.CRUDOperationContext;

/**
 * Finds documents, sorts them, and limits the result set.
 */
public interface DocFinder {

    /**
     * Finds documents.
     *
     * @param ctx The operation context. The found documents are stored in the
     * context.
     * @param coll The collection on which the find operation will be performed
     * @param mongoQuery The MongoDB query
     * @param mongoProjection The MongoDB projection
     * @param mongoSort Optional sort
     * @param from Optional from index, starting from 0
     * @param to Optional to index, starting from 0
     *
     * The find implementation should search for documents in the given
     * collection using the search criteria. If a sort is given, the results
     * should be sorted, and optionally, a subset of the result set should be
     * returned.
     *
     * @return Total number of objects found with given query before applying
     * from and to conditions
     */
    long find(CRUDOperationContext ctx,
              DBCollection coll,
              DBObject mongoQuery,
              DBObject mongoProjection,
              DBObject mongoSort,
              Long from,
              Long to);

    /**
     * Sets the maximum allowed result set size. Any value <=0 means there is no
     * limit @param size the max
     *
     * result set size, or lte 0 for no limit
     */
    @Deprecated
    void setMaxResultSetSize(int size);

    /**
     * Sets the maximum time a query can execute on the server. Any value less
     * <= 0 means there is no limit. @param milliseconds t
     *
     * he time limit in milliseconds, or lte 0 for no limit
     */
    void setMaxQueryTimeMS(long milliseconds);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy