/**
* Copyright (c) Istituto Nazionale di Fisica Nucleare (INFN). 2006-2016
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.glite.security.voms.admin.view.actions.user;
import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.InterceptorRef;
import org.apache.struts2.convention.annotation.Result;
import org.apache.struts2.convention.annotation.Results;
import org.glite.security.voms.admin.configuration.VOMSConfiguration;
import org.glite.security.voms.admin.configuration.VOMSConfigurationConstants;
import org.glite.security.voms.admin.event.EventManager;
import org.glite.security.voms.admin.event.request.MembershipRemovalSubmittedEvent;
import org.glite.security.voms.admin.operations.CurrentAdmin;
import org.glite.security.voms.admin.persistence.dao.generic.DAOFactory;
import org.glite.security.voms.admin.persistence.dao.generic.RequestDAO;
import org.glite.security.voms.admin.persistence.model.VOMSUser;
import org.glite.security.voms.admin.persistence.model.request.MembershipRemovalRequest;
import org.glite.security.voms.admin.view.actions.BaseAction;
import com.opensymphony.xwork2.validator.annotations.RegexFieldValidator;
import com.opensymphony.xwork2.validator.annotations.RequiredStringValidator;
import com.opensymphony.xwork2.validator.annotations.ValidatorType;
@Results({ @Result(name = BaseAction.SUCCESS, location = "userHome"),
@Result(name = BaseAction.INPUT, location = "requestMembershipRemoval"),
@Result(name = "registrationDisabled", location = "userHome") })
@InterceptorRef(value = "authenticatedStack", params = {
"token.includeMethods", "execute" })
public class RequestMembershipRemovalAction extends UserActionSupport {
/**
*
*/
private static final long serialVersionUID = 1L;
String reason;
@Override
public void validate() {
VOMSUser u = CurrentAdmin.instance().getVoUser();
if (!getModel().equals(u))
addActionError("You cannot submit a membership removal request for another user!");
RequestDAO reqDAO = DAOFactory.instance().getRequestDAO();
if (reqDAO.userHasPendingMembershipRemovalRequest(getModel()))
addActionError("User has pending membership removal requests!");
}
@Override
public String execute() throws Exception {
if (!VOMSConfiguration.instance().getBoolean(
VOMSConfigurationConstants.REGISTRATION_SERVICE_ENABLED, true))
return "registrationDisabled";
RequestDAO reqDAO = DAOFactory.instance().getRequestDAO();
MembershipRemovalRequest req = reqDAO.createMembershipRemovalRequest(
getModel(), reason, getDefaultFutureDate());
EventManager.instance()
.dispatch(new MembershipRemovalSubmittedEvent(req, getHomeURL()));
refreshPendingRequests();
return SUCCESS;
}
@RegexFieldValidator(type = ValidatorType.FIELD, regex = "^[^<>&=;]*$",
message = "You entered invalid characters in the reason field!")
@RequiredStringValidator(type = ValidatorType.FIELD,
message = "Please enter a reason.")
public String getReason() {
return reason;
}
public void setReason(String reason) {
this.reason = reason;
}
@Override
@Action("request-membership-removal-input")
public String input() throws Exception {
return super.input();
}
}