mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
Merged V2.2 to HEAD
7462: Renamed ManageLinkValidationTaskDialog to ManageReviewTaskDialog as it is now more generic Enabled deployment and link validation in parallel review tasks Created separate JSP page for manage change request task dialog When a server is edited it is now scrolled to Some minor UI tidyup 7467: Added ability to define excludes for a deployment via a regular expression 7475: Incorporated new icons from Linton 7492: Allows multiple callbacks for deployment. Adds new FAILED deployment event. 7493: Added ability to view previous deployment attempts git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@8380 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -25,6 +25,9 @@
|
||||
package org.alfresco.web.bean.wcm;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Calendar;
|
||||
import java.util.Date;
|
||||
import java.util.GregorianCalendar;
|
||||
import java.util.List;
|
||||
|
||||
import javax.faces.context.FacesContext;
|
||||
@@ -34,6 +37,7 @@ import org.alfresco.model.WCMAppModel;
|
||||
import org.alfresco.service.cmr.repository.NodeRef;
|
||||
import org.alfresco.service.cmr.repository.NodeService;
|
||||
import org.alfresco.service.cmr.search.ResultSet;
|
||||
import org.alfresco.service.cmr.search.SearchParameters;
|
||||
import org.alfresco.service.cmr.search.SearchService;
|
||||
import org.alfresco.service.namespace.NamespaceService;
|
||||
import org.alfresco.util.ISO9075;
|
||||
@@ -52,7 +56,28 @@ public final class DeploymentUtil
|
||||
{
|
||||
private static final Log logger = LogFactory.getLog(DeploymentUtil.class);
|
||||
|
||||
/**
|
||||
* Returns all deployment attempts for the given store
|
||||
*
|
||||
* @param store The store to get the deployment attempts for
|
||||
* @return List of NodeRef's representing the deployment attempts
|
||||
*/
|
||||
public static List<NodeRef> findDeploymentAttempts(String store)
|
||||
{
|
||||
// return all deployment attempts
|
||||
return findDeploymentAttempts(store, null, null);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns all deployment attempts for the given store
|
||||
*
|
||||
* @param store The store to get the deployment attempts for
|
||||
* @param fromDate If present only attempts after the given date are returned
|
||||
* @param toDate If present only attempts before the given date are returned, if null
|
||||
* toDate defaults to today's date
|
||||
* @return List of NodeRef's representing the deployment attempts
|
||||
*/
|
||||
public static List<NodeRef> findDeploymentAttempts(String store, Date fromDate, Date toDate)
|
||||
{
|
||||
FacesContext fc = FacesContext.getCurrentInstance();
|
||||
SearchService searchService = Repository.getServiceRegistry(fc).getSearchService();
|
||||
@@ -66,14 +91,79 @@ public final class DeploymentUtil
|
||||
query.append(":\"");
|
||||
query.append(store);
|
||||
query.append("\"");
|
||||
|
||||
|
||||
// constrain the search by date if a fromDate is applied
|
||||
if (fromDate != null)
|
||||
{
|
||||
if (toDate == null)
|
||||
{
|
||||
toDate = new Date();
|
||||
}
|
||||
|
||||
// see if the dates are the same (ignoring the time)
|
||||
boolean sameDate = false;
|
||||
Calendar fromCal = new GregorianCalendar();
|
||||
fromCal.setTime(fromDate);
|
||||
Calendar toCal = new GregorianCalendar();
|
||||
toCal.setTime(toDate);
|
||||
if ((fromCal.get(Calendar.YEAR) == toCal.get(Calendar.YEAR)) &&
|
||||
(fromCal.get(Calendar.MONTH) == toCal.get(Calendar.MONTH)) &&
|
||||
(fromCal.get(Calendar.DAY_OF_MONTH) == toCal.get(Calendar.DAY_OF_MONTH)))
|
||||
{
|
||||
sameDate = true;
|
||||
}
|
||||
|
||||
// add date to query
|
||||
query.append(" AND @");
|
||||
query.append(NamespaceService.WCMAPP_MODEL_PREFIX);
|
||||
query.append("\\:");
|
||||
query.append(WCMAppModel.PROP_DEPLOYATTEMPTTIME.getLocalName());
|
||||
query.append(":");
|
||||
|
||||
if (sameDate)
|
||||
{
|
||||
// convert date into format needed for range query
|
||||
String queryDate = formatLuceneQueryDate(fromDate, false);
|
||||
|
||||
// query for exact date
|
||||
query.append("\"");
|
||||
query.append(queryDate);
|
||||
query.append("\"");
|
||||
}
|
||||
else
|
||||
{
|
||||
// convert to date into format needed for range query
|
||||
String queryFromDate = formatLuceneQueryDate(fromDate, true);
|
||||
String queryToDate = formatLuceneQueryDate(toDate, true);
|
||||
|
||||
// create a date range query
|
||||
query.append("[");
|
||||
query.append(queryFromDate);
|
||||
query.append(" TO ");
|
||||
query.append(queryToDate);
|
||||
query.append("]");
|
||||
}
|
||||
}
|
||||
|
||||
if (logger.isDebugEnabled())
|
||||
logger.debug("Finding deploymentattempt nodes using query: " + query.toString());
|
||||
|
||||
ResultSet results = null;
|
||||
List<NodeRef> attempts = new ArrayList<NodeRef>();
|
||||
try
|
||||
{
|
||||
// sort the results by deploymentattempttime
|
||||
SearchParameters sp = new SearchParameters();
|
||||
sp.addStore(Repository.getStoreRef());
|
||||
sp.setLanguage(SearchService.LANGUAGE_LUCENE);
|
||||
sp.setQuery(query.toString());
|
||||
sp.addSort("@" + WCMAppModel.PROP_DEPLOYATTEMPTTIME, false);
|
||||
|
||||
// execute the query
|
||||
results = searchService.query(Repository.getStoreRef(),
|
||||
SearchService.LANGUAGE_LUCENE, query.toString());
|
||||
results = searchService.query(sp);
|
||||
|
||||
if (logger.isDebugEnabled())
|
||||
logger.debug("Found " + results.length() + " deployment attempts");
|
||||
|
||||
for (NodeRef attempt : results.getNodeRefs())
|
||||
{
|
||||
@@ -218,7 +308,6 @@ public final class DeploymentUtil
|
||||
return findServers(webProject, false, availableOnly);
|
||||
}
|
||||
|
||||
|
||||
private static List<NodeRef> findServers(NodeRef webProject, boolean live, boolean availableOnly)
|
||||
{
|
||||
FacesContext context = FacesContext.getCurrentInstance();
|
||||
@@ -257,6 +346,9 @@ public final class DeploymentUtil
|
||||
query.append("\"");
|
||||
}
|
||||
|
||||
if (logger.isDebugEnabled())
|
||||
logger.debug("Finding deployment servers using query: " + query.toString());
|
||||
|
||||
// execute the query
|
||||
ResultSet results = null;
|
||||
List<NodeRef> servers = new ArrayList<NodeRef>();
|
||||
@@ -265,6 +357,9 @@ public final class DeploymentUtil
|
||||
results = searchService.query(Repository.getStoreRef(),
|
||||
SearchService.LANGUAGE_LUCENE, query.toString());
|
||||
|
||||
if (logger.isDebugEnabled())
|
||||
logger.debug("Found " + results.length() + " deployment servers");
|
||||
|
||||
for (NodeRef server : results.getNodeRefs())
|
||||
{
|
||||
servers.add(server);
|
||||
@@ -280,4 +375,28 @@ public final class DeploymentUtil
|
||||
|
||||
return servers;
|
||||
}
|
||||
|
||||
private static String formatLuceneQueryDate(Date date, boolean range)
|
||||
{
|
||||
Calendar cal = new GregorianCalendar();
|
||||
cal.setTime(date);
|
||||
|
||||
StringBuilder queryDate = new StringBuilder();
|
||||
queryDate.append(cal.get(Calendar.YEAR));
|
||||
if (range)
|
||||
{
|
||||
queryDate.append("\\");
|
||||
}
|
||||
queryDate.append("-");
|
||||
queryDate.append((cal.get(Calendar.MONTH)+1));
|
||||
if (range)
|
||||
{
|
||||
queryDate.append("\\");
|
||||
}
|
||||
queryDate.append("-");
|
||||
queryDate.append(cal.get(Calendar.DAY_OF_MONTH));
|
||||
queryDate.append("T00:00:00");
|
||||
|
||||
return queryDate.toString();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user