2 * ============LICENSE_START==========================================
4 * ===================================================================
5 * Copyright © 2017 AT&T Intellectual Property. All rights reserved.
6 * ===================================================================
8 * Unless otherwise specified, all software contained herein is licensed
9 * under the Apache License, Version 2.0 (the “License”);
10 * you may not use this software except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
21 * Unless otherwise specified, all documentation contained herein is licensed
22 * under the Creative Commons License, Attribution 4.0 Intl. (the “License”);
23 * you may not use this documentation except in compliance with the License.
24 * You may obtain a copy of the License at
26 * https://creativecommons.org/licenses/by/4.0/
28 * Unless required by applicable law or agreed to in writing, documentation
29 * distributed under the License is distributed on an "AS IS" BASIS,
30 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
31 * See the License for the specific language governing permissions and
32 * limitations under the License.
34 * ============LICENSE_END============================================
36 * ECOMP is a trademark and service mark of AT&T Intellectual Property.
38 package org.openecomp.portalapp.portal.interceptor;
40 import javax.servlet.http.HttpServletRequest;
41 import javax.servlet.http.HttpServletResponse;
43 import org.openecomp.portalapp.authentication.LoginStrategy;
44 import org.openecomp.portalapp.portal.domain.EPUser;
45 import org.openecomp.portalapp.portal.utils.EcompPortalUtils;
46 import org.openecomp.portalapp.util.EPUserUtils;
47 import org.openecomp.portalapp.util.SessionCookieUtil;
48 import org.openecomp.portalsdk.core.controller.FusionBaseController;
49 import org.openecomp.portalsdk.core.domain.support.CollaborateList;
50 import org.openecomp.portalsdk.core.exception.SessionExpiredException;
51 import org.openecomp.portalsdk.core.logging.logic.EELFLoggerDelegate;
52 import org.springframework.beans.factory.annotation.Autowired;
53 import org.springframework.web.method.HandlerMethod;
54 import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
56 public class SessionTimeoutInterceptor extends HandlerInterceptorAdapter {
57 EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(SessionTimeoutInterceptor.class);
60 private LoginStrategy loginStrategy;
62 public SessionTimeoutInterceptor() {
65 public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
68 if (!isHandlerMethod(handler))
71 HandlerMethod method = (HandlerMethod) handler;
73 if (!isFusionController(method.getBean()))
76 if (method.getBean() instanceof FusionBaseController) {
77 FusionBaseController controller = (FusionBaseController) method.getBean();
79 if (!controller.isAccessible()) {
81 EPUser user = EPUserUtils.getUserSession(request);
83 if (request.getRequestURI().indexOf("logout.htm") > -1) {
84 CollaborateList.delUserName(user.getOrgUserId());
85 throw new SessionExpiredException();
87 resetSessionMaxIdleTimeOut(request);
88 CollaborateList.addUserName(user.getOrgUserId());
90 } catch (Exception e) {
91 logger.error(EELFLoggerDelegate.errorLogger, "preHandle failed", e);
102 private void resetSessionMaxIdleTimeOut(HttpServletRequest request) {
103 SessionCookieUtil.resetSessionMaxIdleTimeOut(request);
107 private boolean isFusionController(Object controller) {
108 if (controller instanceof FusionBaseController)
113 private boolean isHandlerMethod(Object controller) {
114 if (controller instanceof HandlerMethod)