1 | package org.medias.eccad.presentation.filtre; |
---|
2 | |
---|
3 | import java.io.IOException; |
---|
4 | |
---|
5 | import javax.faces.context.FacesContext; |
---|
6 | import javax.servlet.Filter; |
---|
7 | import javax.servlet.FilterChain; |
---|
8 | import javax.servlet.FilterConfig; |
---|
9 | import javax.servlet.ServletException; |
---|
10 | import javax.servlet.ServletRequest; |
---|
11 | import javax.servlet.ServletResponse; |
---|
12 | import javax.servlet.http.HttpServletRequest; |
---|
13 | import javax.servlet.http.HttpServletResponse; |
---|
14 | import javax.servlet.http.HttpSession; |
---|
15 | |
---|
16 | |
---|
17 | import org.medias.eccad.helpers.LoggerPerso; |
---|
18 | import org.medias.eccad.presentation.bean.SessionBean; |
---|
19 | |
---|
20 | public class AuthorizationFilter implements Filter { |
---|
21 | private String errorPage; |
---|
22 | |
---|
23 | /**Filter should be configured with an system error page.*/ |
---|
24 | public void init (FilterConfig FilterConfig) throws ServletException { |
---|
25 | if (FilterConfig != null) { |
---|
26 | errorPage = FilterConfig.getInitParameter("error_page"); |
---|
27 | } |
---|
28 | } |
---|
29 | |
---|
30 | public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) |
---|
31 | throws ServletException, IOException { |
---|
32 | LoggerPerso.log(AuthorizationFilter.class, LoggerPerso.DEBUG, "dofilter : en cours"); |
---|
33 | if(errorPage == null) { |
---|
34 | returnError((HttpServletRequest) request, (HttpServletResponse) response,"AuthorizationFilter not properly configured! Contact Administrator."); |
---|
35 | } |
---|
36 | |
---|
37 | SessionBean sessionbean = (SessionBean)((HttpSession)FacesContext.getCurrentInstance().getExternalContext().getSession(false)).getAttribute("sessionBean"); |
---|
38 | |
---|
39 | if (sessionbean == null) { |
---|
40 | returnError((HttpServletRequest)request, (HttpServletResponse) response,"User does not exist in session!"); |
---|
41 | } |
---|
42 | |
---|
43 | LoggerPerso.log(AuthorizationFilter.class, LoggerPerso.DEBUG, "dofilter : quasi terminé"); |
---|
44 | |
---|
45 | if (sessionbean.getEmail() == null) |
---|
46 | returnError((HttpServletRequest) request, (HttpServletResponse) response,"User does not exist in session!"); |
---|
47 | else |
---|
48 | chain.doFilter(request,response); |
---|
49 | } |
---|
50 | |
---|
51 | private void returnError(HttpServletRequest request, HttpServletResponse response, String string) throws IOException { |
---|
52 | response.sendRedirect(errorPage); |
---|
53 | |
---|
54 | } |
---|
55 | |
---|
56 | public void destroy() { |
---|
57 | // TODO Auto-generated method stub |
---|
58 | |
---|
59 | } |
---|
60 | } |
---|