/** * The contents of this file are subject to the Mozilla Public License * Version 1.1 (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.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the * License for the specific language governing rights and limitations under * the License. * * The Original Code is OpenELIS code. * * Copyright (C) The Minnesota Department of Health. All Rights Reserved. * * Contributor(s): CIRG, University of Washington, Seattle WA. */ package us.mn.state.health.lims.systemuser.action; import java.util.ArrayList; import java.util.List; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.validator.GenericValidator; import org.apache.struts.Globals; import org.apache.struts.action.ActionForm; import org.apache.struts.action.ActionForward; import org.apache.struts.action.ActionMapping; import org.apache.struts.action.ActionMessages; import org.apache.struts.action.DynaActionForm; import us.mn.state.health.lims.common.action.BaseAction; import us.mn.state.health.lims.common.exception.LIMSRuntimeException; import us.mn.state.health.lims.common.util.validator.ActionError; import us.mn.state.health.lims.hibernate.HibernateUtil; import us.mn.state.health.lims.login.dao.LoginDAO; import us.mn.state.health.lims.login.daoimpl.LoginDAOImpl; import us.mn.state.health.lims.login.valueholder.Login; import us.mn.state.health.lims.systemuser.dao.SystemUserDAO; import us.mn.state.health.lims.systemuser.daoimpl.SystemUserDAOImpl; import us.mn.state.health.lims.systemuser.valueholder.SystemUser; import us.mn.state.health.lims.systemuser.valueholder.UnifiedSystemUser; import us.mn.state.health.lims.userrole.dao.UserRoleDAO; import us.mn.state.health.lims.userrole.daoimpl.UserRoleDAOImpl; import us.mn.state.health.lims.userrole.valueholder.UserRole; public class UnifiedSystemUserDeleteAction extends BaseAction { static private String FWD_CLOSE = "close"; protected ActionForward performAction(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception { String forward = "success"; DynaActionForm dynaForm = (DynaActionForm) form; String[] selectedIDs = (String[]) dynaForm.get("selectedIDs"); List<Login> loginUsers = new ArrayList<Login>(); List<SystemUser> systemUsers = new ArrayList<SystemUser>(); List<UserRole> userRoles = new ArrayList<UserRole>(); String sysUserId = getSysUserId(request); for (int i = 0; i < selectedIDs.length; i++) { String systemUserId = UnifiedSystemUser.getSystemUserIDFromCombinedID(selectedIDs[i]); if(!GenericValidator.isBlankOrNull(systemUserId)){ SystemUser systemUser = new SystemUser(); systemUser.setId(systemUserId); systemUser.setSysUserId(sysUserId); systemUsers.add( systemUser); } String loginUserId = UnifiedSystemUser.getLoginUserIDFromCombinedID(selectedIDs[i]); if(!GenericValidator.isBlankOrNull(loginUserId)){ Login loginUser = new Login(); loginUser.setId(loginUserId); loginUser.setSysUserId(sysUserId); loginUsers.add( loginUser); } } UserRoleDAO userRoleDAO = new UserRoleDAOImpl(); for( SystemUser systemUser : systemUsers){ List<String> roleIds = userRoleDAO.getRoleIdsForUser(systemUser.getId()); for( String roleId : roleIds){ UserRole userRole = new UserRole(); userRole.setSystemUserId(systemUser.getId()); userRole.setRoleId(roleId); userRole.setSysUserId(sysUserId); userRoles.add(userRole); } } SystemUserDAO systemUserDAO = new SystemUserDAOImpl(); LoginDAO loginDAO = new LoginDAOImpl(); org.hibernate.Transaction tx = HibernateUtil.getSession().beginTransaction(); ActionMessages errors = null; try { userRoleDAO.deleteData(userRoles); for( SystemUser systemUser : systemUsers){ //we're not going to actually delete them to preserve auditing systemUserDAO.getData(systemUser); systemUser.setSysUserId(sysUserId); systemUser.setIsActive("N"); systemUserDAO.updateData(systemUser); } loginDAO.deleteData(loginUsers); tx.commit(); } catch (LIMSRuntimeException lre) { tx.rollback(); errors = new ActionMessages(); ActionError error = null; if (lre.getException() instanceof org.hibernate.StaleObjectStateException) { error = new ActionError("errors.OptimisticLockException", null, null); } else { error = new ActionError("errors.DeleteException", null, null); } errors.add(ActionMessages.GLOBAL_MESSAGE, error); saveErrors(request, errors); request.setAttribute(Globals.ERROR_KEY, errors); forward = FWD_FAIL; } finally { HibernateUtil.closeSession(); } if (forward.equals(FWD_FAIL)) return mapping.findForward(forward); if (TRUE.equalsIgnoreCase(request.getParameter("close"))) { forward = FWD_CLOSE; } request.setAttribute("menuDefinition", "RoleMenuDefinition"); return mapping.findForward(forward); } protected String getPageTitleKey() { return null; } protected String getPageSubtitleKey() { return null; } }