001    /**
002     * Copyright 2005-2011 The Kuali Foundation
003     *
004     * Licensed under the Educational Community License, Version 2.0 (the "License");
005     * you may not use this file except in compliance with the License.
006     * You may obtain a copy of the License at
007     *
008     * http://www.opensource.org/licenses/ecl2.php
009     *
010     * Unless required by applicable law or agreed to in writing, software
011     * distributed under the License is distributed on an "AS IS" BASIS,
012     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     * See the License for the specific language governing permissions and
014     * limitations under the License.
015     */
016    package org.kuali.rice.krad.web.controller;
017    
018    import java.util.HashMap;
019    import java.util.Map;
020    
021    import javax.servlet.http.HttpServletRequest;
022    import javax.servlet.http.HttpServletResponse;
023    
024    import org.apache.commons.lang.StringUtils;
025    import org.apache.log4j.Logger;
026    import org.kuali.rice.core.framework.parameter.ParameterService;
027    import org.kuali.rice.core.framework.services.CoreFrameworkServiceLocator;
028    import org.kuali.rice.kim.api.KimConstants;
029    import org.kuali.rice.kim.api.services.KimApiServiceLocator;
030    import org.kuali.rice.krad.service.KRADServiceLocatorWeb;
031    import org.kuali.rice.krad.service.KualiModuleService;
032    import org.kuali.rice.krad.service.ModuleService;
033    import org.kuali.rice.krad.util.GlobalVariables;
034    import org.kuali.rice.krad.util.KRADConstants;
035    import org.springframework.web.servlet.HandlerInterceptor;
036    import org.springframework.web.servlet.ModelAndView;
037    
038    /**
039     * TODO jawbenne don't forget to fill this in. 
040     * 
041     * @author Kuali Rice Team (rice.collab@kuali.org)
042     */
043    public class ModuleLockingHandlerInterceptor implements HandlerInterceptor {
044    
045        private static final Logger LOG = Logger.getLogger(ModuleLockingHandlerInterceptor.class);
046        
047        
048        private KualiModuleService kualiModuleService;
049        private String moduleLockedMapping;
050        
051        /**
052         * @return the moduleLockedMapping
053         */
054        public String getModuleLockedMapping() {
055            return this.moduleLockedMapping;
056        }
057    
058        /**
059         * @param moduleLockedMapping the moduleLockedMapping to set
060         */
061        public void setModuleLockedMapping(String moduleLockedMapping) {
062            this.moduleLockedMapping = moduleLockedMapping;
063        }
064    
065        /**
066         * @param kualiModuleService the kualiModuleService to set
067         */
068        public void setKualiModuleService(KualiModuleService kualiModuleService) {
069            this.kualiModuleService = kualiModuleService;
070        }
071    
072        /**
073         * This overridden method ...
074         * 
075         * @see org.springframework.web.servlet.HandlerInterceptor#afterCompletion(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, java.lang.Object, java.lang.Exception)
076         */
077        @Override
078        public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception exception) throws Exception {
079            // do nothing
080        }
081    
082        /**
083         * This overridden method ...
084         * 
085         * @see org.springframework.web.servlet.HandlerInterceptor#postHandle(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, java.lang.Object, org.springframework.web.servlet.ModelAndView)
086         */
087        @Override
088        public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndview)
089                throws Exception {
090            // do nothing
091        }
092    
093        /**
094         * This overridden method ...
095         * 
096         * @see org.springframework.web.servlet.HandlerInterceptor#preHandle(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, java.lang.Object)
097         */
098        @Override
099        public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
100            if(isModuleLocked(request)) {
101                response.sendRedirect(this.getModuleLockedMapping() + "?" + ModuleLockedController.MODULE_PARAMETER + "=" + getModuleService(request).getModuleConfiguration().getNamespaceCode());
102            }
103            return true;
104        }
105        
106        private ModuleService getModuleService(HttpServletRequest request) {
107            String boClass = request.getParameter(KRADConstants.BUSINESS_OBJECT_CLASS_ATTRIBUTE);
108            if(StringUtils.isBlank(boClass)) {
109                boClass= request.getParameter(KRADConstants.DATA_OBJECT_CLASS_ATTRIBUTE);
110            }
111            ModuleService moduleService = null;
112            if(StringUtils.isNotBlank(boClass)) {
113                try {
114                    moduleService = getKualiModuleService().getResponsibleModuleService(Class.forName(boClass));
115                } catch (ClassNotFoundException classNotFoundException) {
116                    LOG.warn("BO class not found: " + boClass, classNotFoundException);
117                }
118            } else {
119                moduleService = getKualiModuleService().getResponsibleModuleService(this.getClass());
120            }
121            return moduleService;
122        }
123    
124        protected boolean isModuleLocked(HttpServletRequest request) {
125            ModuleService moduleService = getModuleService(request);
126            if(moduleService != null && moduleService.isLocked()) {
127                String principalId = GlobalVariables.getUserSession().getPrincipalId();
128                String namespaceCode = KRADConstants.KUALI_RICE_SYSTEM_NAMESPACE;
129                String permissionName = KimConstants.PermissionNames.ACCESS_LOCKED_MODULE;
130                Map<String, String> permissionDetails = new HashMap<String, String>();
131                Map<String, String> qualification = new HashMap<String, String>();
132                if(!KimApiServiceLocator.getPermissionService().isAuthorized(principalId, namespaceCode, permissionName, permissionDetails, qualification)) {
133                    return true;
134                }
135            }
136            return false;
137        }
138        
139        protected KualiModuleService getKualiModuleService() {
140            if ( kualiModuleService == null ) {
141                kualiModuleService = KRADServiceLocatorWeb.getKualiModuleService();
142            }
143            return kualiModuleService;
144        }
145    }