/*
This file is part of Cyclos (www.cyclos.org).
A project of the Social Trade Organisation (www.socialtrade.org).
Cyclos 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.
Cyclos 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 Cyclos; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package nl.strohalm.cyclos.controls;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import nl.strohalm.cyclos.annotations.Inject;
import nl.strohalm.cyclos.entities.exceptions.QueryParseException;
import nl.strohalm.cyclos.entities.settings.LocalSettings;
import nl.strohalm.cyclos.exceptions.ExternalException;
import nl.strohalm.cyclos.exceptions.PermissionDeniedException;
import nl.strohalm.cyclos.services.elements.ElementService;
import nl.strohalm.cyclos.services.groups.GroupService;
import nl.strohalm.cyclos.services.settings.SettingsService;
import nl.strohalm.cyclos.utils.ActionHelper;
import nl.strohalm.cyclos.utils.ImageHelper;
import nl.strohalm.cyclos.utils.ImageHelper.ImageType;
import nl.strohalm.cyclos.utils.MessageHelper;
import nl.strohalm.cyclos.utils.validation.ValidationException;
import org.apache.commons.io.FileUtils;
import org.apache.commons.lang.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.upload.MultipartRequestHandler;
/**
* Base action where there is no logged user expected
* @author luis
*/
public abstract class BasePublicAction extends Action {
private final Log LOG = LogFactory.getLog(BasePublicAction.class);
protected ElementService elementService;
protected GroupService groupService;
protected ActionHelper actionHelper;
protected MessageHelper messageHelper;
protected SettingsService settingsService;
/**
* The Struts standard execute method is reserved, being the executeAction the one that subclasses must implement
*/
@Override
public final ActionForward execute(final ActionMapping mapping, final ActionForm actionForm, final HttpServletRequest request, final HttpServletResponse response) throws Exception {
// Check for uploads that exceeded the max length
final Boolean maxLengthExceeded = (Boolean) request.getAttribute(MultipartRequestHandler.ATTRIBUTE_MAX_LENGTH_EXCEEDED);
if (maxLengthExceeded != null && maxLengthExceeded) {
final LocalSettings settings = settingsService.getLocalSettings();
return ActionHelper.sendError(mapping, request, response, "error.maxUploadSizeExceeded", FileUtils.byteCountToDisplaySize(settings.getMaxUploadBytes()));
}
// Create an action context
request.setAttribute("formAction", mapping.getPath());
try {
// Process the action
return executeAction(mapping, actionForm, request, response);
} catch (final PermissionDeniedException e) {
return ActionHelper.sendError(mapping, request, response, "error.permissionDenied");
} catch (final QueryParseException e) {
return ActionHelper.sendError(mapping, request, response, "error.queryParse");
} catch (final ImageHelper.UnknownImageTypeException e) {
final String recognizedTypes = StringUtils.join(ImageType.values(), ", ");
return ActionHelper.sendError(mapping, request, response, "error.unknownImageType", recognizedTypes);
} catch (final ValidationException e) {
return ActionHelper.handleValidationException(mapping, request, response, e);
} catch (final ExternalException e) {
return ActionHelper.sendErrorWithMessage(mapping, request, response, e.getMessage());
} catch (final Exception e) {
actionHelper.generateLog(request, getServlet().getServletContext(), e);
LOG.error("Application error on " + getClass().getName(), e);
return ActionHelper.sendError(mapping, request, response, null);
}
}
@Inject
public final void setActionHelper(final ActionHelper actionHelper) {
this.actionHelper = actionHelper;
}
@Inject
public final void setElementService(final ElementService elementService) {
this.elementService = elementService;
}
@Inject
public final void setGroupService(final GroupService groupService) {
this.groupService = groupService;
}
@Inject
public final void setMessageHelper(final MessageHelper messageHelper) {
this.messageHelper = messageHelper;
}
@Inject
public void setSettingsService(final SettingsService settingsService) {
this.settingsService = settingsService;
}
/**
* This method must be implemented to perform the action itself
*/
protected abstract ActionForward executeAction(ActionMapping mapping, ActionForm actionForm, HttpServletRequest request, HttpServletResponse response) throws Exception;
}