mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
125605 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2) 125498 slanglois: MNT-16155 Update source headers - remove svn:eol-style property on Java and JSP source files git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@125783 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
102 lines
3.7 KiB
Java
102 lines
3.7 KiB
Java
package org.alfresco.web.bean.coci;
|
|
|
|
import javax.faces.context.FacesContext;
|
|
|
|
import org.alfresco.model.ContentModel;
|
|
import org.alfresco.web.app.Application;
|
|
import org.alfresco.web.bean.repository.Node;
|
|
import org.alfresco.web.ui.common.ReportedException;
|
|
import org.alfresco.web.ui.common.Utils;
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
public class CCUndoCheckoutFileDialog extends CheckinCheckoutDialog
|
|
{
|
|
private static final long serialVersionUID = -6957120889259486975L;
|
|
|
|
public static final String LBL_UNDO_CHECKOUT = "undo_checkout";
|
|
public static final String MSG_UNDO_CHECKOUT_FOR = "undo_checkout_for";
|
|
private final static String MSG_LEFT_QUOTE = "left_qoute";
|
|
private final static String MSG_RIGHT_QUOTE = "right_quote";
|
|
|
|
private static Log logger = LogFactory.getLog(CheckinCheckoutDialog.class);
|
|
|
|
@Override
|
|
protected String finishImpl(FacesContext context, String outcome) throws Exception
|
|
{
|
|
return undoCheckoutFile(context, outcome);
|
|
}
|
|
|
|
@Override
|
|
public String getContainerTitle()
|
|
{
|
|
FacesContext fc = FacesContext.getCurrentInstance();
|
|
return Application.getMessage(fc, MSG_UNDO_CHECKOUT_FOR) + " " + Application.getMessage(fc, MSG_LEFT_QUOTE)
|
|
+ property.getDocument().getName() + Application.getMessage(fc, MSG_RIGHT_QUOTE);
|
|
}
|
|
|
|
@Override
|
|
public boolean getFinishButtonDisabled()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public String getFinishButtonLabel()
|
|
{
|
|
return Application.getMessage(FacesContext.getCurrentInstance(), LBL_UNDO_CHECKOUT);
|
|
|
|
}
|
|
|
|
/**
|
|
* Action to undo the checkout of a locked document. This document may
|
|
* either by the original copy or the working copy node. Therefore calculate
|
|
* which it is, if the working copy is found then we simply cancel checkout
|
|
* on that document. If the original copy is found then we need to find the
|
|
* appropriate working copy and perform the action on that node.
|
|
*/
|
|
public String undoCheckoutFile(FacesContext context, String outcome)
|
|
{
|
|
Node node = property.getDocument();
|
|
if (node != null)
|
|
{
|
|
try
|
|
{
|
|
if (node.hasAspect(ContentModel.ASPECT_WORKING_COPY))
|
|
{
|
|
this.property.getVersionOperationsService().cancelCheckout(node.getNodeRef());
|
|
}
|
|
else if (node.hasAspect(ContentModel.ASPECT_LOCKABLE))
|
|
{
|
|
// TODO: find the working copy for this document and cancel
|
|
// the checkout on it
|
|
// is this possible? as currently only the workingcopy
|
|
// aspect has the copyReference
|
|
// attribute - this means we cannot find out where the copy
|
|
// is to cancel it!
|
|
// can we construct an XPath node lookup?
|
|
throw new RuntimeException("NOT IMPLEMENTED");
|
|
}
|
|
else
|
|
{
|
|
throw new IllegalStateException("Node supplied for undo checkout has neither Working Copy or Locked aspect!");
|
|
}
|
|
|
|
resetState();
|
|
}
|
|
catch (Throwable err)
|
|
{
|
|
Utils.addErrorMessage(Application.getMessage(FacesContext.getCurrentInstance(), MSG_ERROR_CANCELCHECKOUT) + err.getMessage(), err);
|
|
ReportedException.throwIfNecessary(err);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
logger.warn("WARNING: undoCheckout called without a current WorkingDocument!");
|
|
}
|
|
|
|
return outcome + ":browse";
|
|
}
|
|
|
|
}
|