annotate servlet/src/digilib/auth/AuthOpsImpl.java @ 33:054ebc851059

first update of new client-version
author luginbue
date Thu, 21 Feb 2002 02:27:06 +0100
parents 0ff3ede32060
children 3b8797fc3e90 9cedd170b581
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
1 /* AuthOps -- Authentication class implementation
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
2
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
3 Digital Image Library servlet components
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
4
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
5 Copyright (C) 2001, 2002 Robert Casties (robcast@mail.berlios.de)
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
6
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
7 This program is free software; you can redistribute it and/or modify it
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
9 Free Software Foundation; either version 2 of the License, or (at your
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
10 option) any later version.
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
11
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
12 Please read license.txt for the full details. A copy of the GPL
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
13 may be found at http://www.gnu.org/copyleft/lgpl.html
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
14
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
15 You should have received a copy of the GNU General Public License
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
16 along with this program; if not, write to the Free Software
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
18
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
19 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
20
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
21 package digilib.auth;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
22
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
23 import javax.servlet.http.HttpServletRequest;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
24 import java.util.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
25
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
26 import digilib.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
27
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
28 public abstract class AuthOpsImpl implements AuthOps {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
29
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
30 protected Utils util;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
31
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
32 public AuthOpsImpl() {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
33 util = new Utils();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
34 try {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
35 init();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
36 } catch (AuthOpException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
37 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
38 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
39
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
40 public AuthOpsImpl(Utils u) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
41 util = u;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
42 try {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
43 init();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
44 } catch (AuthOpException e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
45 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
46 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
47
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
48 public boolean isAuthRequired(String filepath, HttpServletRequest request) throws AuthOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
49 // check permissions
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
50 List rolesRequired = rolesForPath(filepath, request);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
51 return (rolesRequired != null);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
52 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
53
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
54 public boolean isAuthorized(String filepath, HttpServletRequest request) throws AuthOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
55 List rolesAllowed = rolesForPath(filepath, request);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
56 return isRoleAuthorized(rolesAllowed, request);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
57 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
58
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
59 public boolean isRoleAuthorized(List roles, HttpServletRequest request) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
60 ListIterator r = roles.listIterator();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
61 String s = "";
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
62 while (r.hasNext()) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
63 s = (String)r.next();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
64 util.dprintln(5, "Testing role: "+s);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
65 if (request.isUserInRole(s)) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
66 util.dprintln(5, "Role Authorized");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
67 return true;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
68 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
69 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
70 return false;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
71 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
72
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
73 public abstract void init() throws AuthOpException;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
74
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
75 public abstract List rolesForPath(String filepath, HttpServletRequest request) throws AuthOpException;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
76
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
77 }