KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > dspace > app > webui > filter > RegisteredOnlyFilter


1 /*
2  * RegisteredOnlyFilter.java
3  *
4  * Version: $Revision: 1.7 $
5  *
6  * Date: $Date: 2005/10/17 03:35:45 $
7  *
8  * Copyright (c) 2002-2005, Hewlett-Packard Company and Massachusetts
9  * Institute of Technology. All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions are
13  * met:
14  *
15  * - Redistributions of source code must retain the above copyright
16  * notice, this list of conditions and the following disclaimer.
17  *
18  * - Redistributions in binary form must reproduce the above copyright
19  * notice, this list of conditions and the following disclaimer in the
20  * documentation and/or other materials provided with the distribution.
21  *
22  * - Neither the name of the Hewlett-Packard Company nor the name of the
23  * Massachusetts Institute of Technology nor the names of their
24  * contributors may be used to endorse or promote products derived from
25  * this software without specific prior written permission.
26  *
27  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
28  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
29  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
30  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
31  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
32  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
33  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
34  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
35  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
36  * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
37  * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
38  * DAMAGE.
39  */

40 package org.dspace.app.webui.filter;
41
42 import java.io.IOException JavaDoc;
43 import java.sql.SQLException JavaDoc;
44
45 import javax.servlet.Filter JavaDoc;
46 import javax.servlet.FilterChain JavaDoc;
47 import javax.servlet.FilterConfig JavaDoc;
48 import javax.servlet.ServletException JavaDoc;
49 import javax.servlet.ServletRequest JavaDoc;
50 import javax.servlet.ServletResponse JavaDoc;
51 import javax.servlet.http.HttpServletRequest JavaDoc;
52 import javax.servlet.http.HttpServletResponse JavaDoc;
53
54 import org.apache.log4j.Logger;
55 import org.dspace.app.webui.util.Authenticate;
56 import org.dspace.app.webui.util.JSPManager;
57 import org.dspace.app.webui.util.UIUtil;
58 import org.dspace.core.Context;
59 import org.dspace.core.LogManager;
60
61 /**
62  * DSpace filter that only allows requests from individual authenticated users
63  * to proceed. Other requests prompt the authentication procedure.
64  *
65  * @author Robert Tansley
66  * @version $Revision: 1.7 $
67  */

68 public class RegisteredOnlyFilter implements Filter JavaDoc
69 {
70     /** log4j category */
71     private static Logger log = Logger.getLogger(RegisteredOnlyFilter.class);
72
73     public void init(FilterConfig JavaDoc config)
74     {
75         // Do nothing
76
}
77
78     public void doFilter(ServletRequest JavaDoc request, ServletResponse JavaDoc response,
79             FilterChain JavaDoc chain) throws ServletException JavaDoc, IOException JavaDoc
80     {
81         Context context = null;
82
83         // We need HTTP request objects
84
HttpServletRequest JavaDoc hrequest = (HttpServletRequest JavaDoc) request;
85         HttpServletResponse JavaDoc hresponse = (HttpServletResponse JavaDoc) response;
86
87         try
88         {
89             // Obtain a context
90
context = UIUtil.obtainContext(hrequest);
91
92             // Continue if logged in or startAuthentication finds a user;
93
// otherwise it will issue redirect so just return.
94
if (context.getCurrentUser() != null ||
95                 Authenticate.startAuthentication(context, hrequest, hresponse))
96             {
97                 // Allow request to proceed
98
chain.doFilter(hrequest, hresponse);
99             }
100         }
101         catch (SQLException JavaDoc se)
102         {
103             log.warn(LogManager.getHeader(context, "database_error", se
104                     .toString()), se);
105             JSPManager.showInternalError(hrequest, hresponse);
106         }
107
108         // Abort the context if it's still valid
109
if ((context != null) && context.isValid())
110         {
111             context.abort();
112         }
113     }
114
115     public void destroy()
116     {
117         // Nothing
118
}
119 }
120
Popular Tags