net.sourceforge.openutils.mgnlcriteria.jcr.query.DirectJcrQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of openutils-mgnlcriteria Show documentation
Show all versions of openutils-mgnlcriteria Show documentation
A Hibernate's Criteria-like API to programmatically generate JCR queries with Magnolia
/**
*
* Criteria API for Magnolia CMS (http://www.openmindlab.com/lab/products/mgnlcriteria.html)
* Copyright(C) 2009-2011, Openmind S.r.l. http://www.openmindonline.it
*
* 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 net.sourceforge.openutils.mgnlcriteria.jcr.query;
import info.magnolia.cms.core.HierarchyManager;
import net.sourceforge.openutils.mgnlcriteria.advanced.impl.QueryExecutorHelper;
/**
* @see JCRCriteriaFactory#createDirectJcrQuery(info.magnolia.cms.core.HierarchyManager, String, String)
* @author fgiust
* @version $Id: DirectJcrQuery.java 3369 2011-03-05 20:08:02Z fgiust $
*/
public class DirectJcrQuery implements ExecutableQuery
{
private HierarchyManager hm;
private String query;
private String language;
private String spellCheckString;
private int maxResults;
private int offset;
/**
* @param hm
* @param query
* @param language
*/
public DirectJcrQuery(HierarchyManager hm, String query, String language)
{
this.hm = hm;
this.query = query;
this.language = language;
}
/**
* Sets the spellCheckString.
* @param spellCheckString the spellCheckString to set
* @return the DirectJcrQuery instance for chaining
*/
public DirectJcrQuery setSpellCheckString(String spellCheckString)
{
this.spellCheckString = spellCheckString;
return this;
}
/**
* Sets the maxResults.
* @param maxResults the maxResults to set
* @return the DirectJcrQuery instance for chaining
*/
public DirectJcrQuery setMaxResultsPerPage(int maxResults)
{
this.maxResults = maxResults;
return this;
}
/**
* Sets the offset.
* @param offset the offset to set
* @return the DirectJcrQuery instance for chaining
*/
public DirectJcrQuery setOffset(int offset)
{
this.offset = offset;
return this;
}
/**
* Utility method for setting offset easier. If this method is called you should not use setOffset/setMaxResults
* directly anymore.
* @param itemsPerPage number of items per page
* @param pageNumberStartingFromOne page number (starting from 1)
* @return the DirectJcrQuery instance for chaining
*/
public DirectJcrQuery setPaging(int itemsPerPage, int pageNumberStartingFromOne)
{
this.maxResults = itemsPerPage;
this.offset = (Math.max(pageNumberStartingFromOne, 1) - 1) * maxResults;
return this;
}
/**
* {@inheritDoc}
*/
public AdvancedResult execute()
{
return QueryExecutorHelper.execute(query, language, hm, maxResults, offset, spellCheckString, false);
}
}