mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
13424: ETHREEOH-1242: Sample LDAP authentication config breaks site invites in Share 13427: Fixes for ETHREEOH-1157: Propagate exceptions using ReportedException 13428: Fix ETHREEOH-1493: Upgrade from 2.1-A to 3.1 uses incorrect patch id and fixes_to_schema 13429: Specific fix for ETHREEOH-1157: duplicate/triplicate users not properly prohibited 13436: Merged V2.2 to V3.1 13435: Merged V2.1 to V2.2 12307: Merged DEV/V2.1SP7 to 2.1 11927: ETWOONE-396 12112: ETWOONE-396 13437: Fixed ETHREEOH-1498: Mismatched closing XML tag in ehcache-custom.xml.sample.cluster 13439: Fix for ETHREEOH-1157: JSF Dialogs Absorbing Exceptions 13456: Fixed ETHREEOH-1472: Changes to systemBootstrap cause bootstrapping ACP's not to work 13469: Upgrade patch to update internal version2Store counter (follow-on fix for ETHREEOH-1540) 13491: Chaining example for DOC-84 13492: Fixed paths in zip file 13494: Fixed GenericBootstrapPatch when overriding bootstrap views 13495: Added @version javadoc 13496: Minor logging updates 13497: Fixed ETHREEOH-1431: Authentication case sensitivity switch doesn't work 13500: Temporary fix for Sharepoint issue raised last week 13502: ETHREEOH-1575: It's impossible to create Change Request task 13511: Fix for ETHREEOH-1549: Impossible to create HTML web content 13529: Fix for ETHREEOH-1595 13531: Fix for ETHREEOH-1607: Error on chaining example xml - malformed comment 13537: Build fix ... exclude the system user from auto creation 13538: Build Fix - further contraints to aviod auto-creation of guest ___________________________________________________________________ Modified: svn:mergeinfo Merged /alfresco/BRANCHES/V2.1:r12307 Merged /alfresco/BRANCHES/V2.2:r13435 Merged /alfresco/BRANCHES/V3.1:r 13424,13427-13429,13436-13437,13439,13442-13450,13452,13454-13456, 13469-13473,13475-13476,13479-13480,13491-13500,13502,13511,13529-13538 git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@13619 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
189 lines
6.6 KiB
Java
189 lines
6.6 KiB
Java
/*
|
|
* Copyright (C) 2005-2007 Alfresco Software Limited.
|
|
*
|
|
* 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 2
|
|
* 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, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
* As a special exception to the terms and conditions of version 2.0 of
|
|
* the GPL, you may redistribute this Program in connection with Free/Libre
|
|
* and Open Source Software ("FLOSS") applications as described in Alfresco's
|
|
* FLOSS exception. You should have recieved a copy of the text describing
|
|
* the FLOSS exception, and it is also available here:
|
|
* http://www.alfresco.com/legal/licensing"
|
|
*/
|
|
package org.alfresco.repo.webservice;
|
|
|
|
import org.alfresco.service.ServiceRegistry;
|
|
import org.alfresco.util.GUID;
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
/**
|
|
* An abstract implementation of the query session that keeps track of the paging data.
|
|
* It provides support for paging of results of <code>Serializable[]</code> instances.
|
|
*
|
|
* @author Derek Hulley
|
|
* @since 2.1
|
|
*/
|
|
public abstract class AbstractQuerySession<RESULTSET, RESULTSETROW> implements QuerySession<RESULTSET>
|
|
{
|
|
private static Log logger = LogFactory.getLog(AbstractQuerySession.class);
|
|
|
|
private String id;
|
|
private long maxResults;
|
|
private long batchSize;
|
|
private ServerQuery<RESULTSET> query;
|
|
/** a transient cache of the query results */
|
|
private transient RESULTSET cachedResults;
|
|
|
|
/**
|
|
* A pointer to the first row to be returned. When the last result is returned, the
|
|
* position will be out of range of the current results by 1.
|
|
*/
|
|
private long position;
|
|
/**
|
|
* Keep track of whether the position has previously passed the end of a set of results.
|
|
*/
|
|
private boolean expectMoreResults;
|
|
|
|
/**
|
|
* Common constructor that initialises the session's id and batch size
|
|
*
|
|
* @param maxResults
|
|
* the maximum number of results to retrieve for the query. This is not the page
|
|
* size, which is normally significantly smaller.
|
|
* @param batchSize
|
|
* the batch size this session will use
|
|
* @param query
|
|
* the query that generates the results
|
|
*/
|
|
public AbstractQuerySession(long maxResults, long batchSize, ServerQuery<RESULTSET> query)
|
|
{
|
|
this.id = GUID.generate();
|
|
this.batchSize = batchSize;
|
|
this.maxResults = maxResults;
|
|
this.query = query;
|
|
this.position = 0;
|
|
this.expectMoreResults = true;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public String getId()
|
|
{
|
|
return this.id;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public ServerQuery<RESULTSET> getQuery()
|
|
{
|
|
return query;
|
|
}
|
|
|
|
/**
|
|
* Helper method to get the results. This may be a cached value or may be
|
|
* freshly retrieved from the query object.
|
|
*
|
|
* @param serviceRegistry the
|
|
* @return the query results, new or cached
|
|
*/
|
|
protected RESULTSET getQueryResults(ServiceRegistry serviceRegistry)
|
|
{
|
|
if (cachedResults != null)
|
|
{
|
|
return cachedResults;
|
|
}
|
|
// Get the results and cache them
|
|
cachedResults = query.execute(serviceRegistry, maxResults);
|
|
// Done
|
|
return cachedResults;
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public boolean haveMoreResults()
|
|
{
|
|
return expectMoreResults;
|
|
}
|
|
|
|
protected abstract RESULTSETROW[] makeArray(int size);
|
|
|
|
/**
|
|
* Helper method to page through the results. The task of retrieving, unwrapping and
|
|
* rewrapping the array of results (rows) is left up to the derived implementations.
|
|
*/
|
|
protected final RESULTSETROW[] getNextResults(RESULTSETROW[] allResults)
|
|
{
|
|
/*
|
|
* This class can't manipulate the query to get the results because each
|
|
* query implementation's results (the array of rows) is contained within
|
|
* a different type of object. This method helps
|
|
*/
|
|
|
|
long allResultsSize = allResults.length;
|
|
|
|
RESULTSETROW[] batchedResults = null;
|
|
if (position >= allResultsSize)
|
|
{
|
|
// We are already past the last result
|
|
batchedResults = makeArray(0);
|
|
// Position is after last
|
|
position = allResultsSize;
|
|
}
|
|
else if (position == 0 && batchSize >= allResultsSize)
|
|
{
|
|
// We can give back the original results
|
|
batchedResults = allResults;
|
|
// Position is after last
|
|
position = allResultsSize;
|
|
}
|
|
else if ((position + batchSize) >= allResultsSize)
|
|
{
|
|
// There isn't an excess of rows remaining, so copy to the last one
|
|
long rowCopyCount = allResultsSize - position; //ETWOONE-396 second part
|
|
batchedResults = makeArray((int)rowCopyCount);
|
|
System.arraycopy(allResults, (int)position, batchedResults, 0, (int)rowCopyCount);
|
|
// Position is after last
|
|
position = allResultsSize;
|
|
}
|
|
else
|
|
{
|
|
// There are an excess of rows remaining
|
|
batchedResults = makeArray((int)batchSize);
|
|
System.arraycopy(allResults, (int)position, batchedResults, 0, (int)batchSize);
|
|
// Position increases by the batch size
|
|
position += batchSize;
|
|
}
|
|
// Keep track of whether we expect more results
|
|
if (position >= allResultsSize)
|
|
{
|
|
expectMoreResults = false;
|
|
}
|
|
// Done
|
|
if (logger.isDebugEnabled())
|
|
{
|
|
logger.debug("\n" +
|
|
"Fetched next set of results: \n" +
|
|
" Total results count: " + allResultsSize + "\n" +
|
|
" Batch size: " + batchedResults.length + "\n" +
|
|
" New Position: " + position);
|
|
}
|
|
return batchedResults;
|
|
}
|
|
}
|