annotate servlet/src/digilib/auth/XMLAuthOps.java @ 72:300d5ba8b33b

New servlet version 1.5b. Mostly cleanup. Global parameters for digilib now in DigilibConfiguration, per request parameters are now all in DigilibRequest. The DocuImage implementation can be selected by the configuration docuimage-class. Pixel-by-pixel view implemented with "mo=clip".
author robcast
date Fri, 24 Jan 2003 21:40:59 +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 /* XMLAuthOps -- Authentication class implementation using XML files
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 import java.io.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
26
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
27 import digilib.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
28 import digilib.io.*;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
29
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
30
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
31 public class XMLAuthOps extends AuthOpsImpl {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
32
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
33 private String configFile = "/docuserver/www/digitallibrary/WEB-INF/digilib-auth.xml";
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
34 private HashTree authPaths;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
35 private HashTree authIPs;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
36
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
37 public XMLAuthOps(Utils u, String confFile) throws AuthOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
38 util = u;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
39 configFile = confFile;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
40 init();
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
41 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
42
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
43 public void setConfig(String confFile) throws AuthOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
44 configFile = confFile;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
45 init();
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 void init() throws AuthOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
49 util.dprintln(10, "xmlauthops.init ("+configFile+")");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
50 Hashtable pathList = null;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
51 Hashtable ipList = null;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
52 try {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
53 // create data loader for auth-path file
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
54 File confFile = new File(configFile);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
55 // load authPaths
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
56 XMLListLoader pathLoader = new XMLListLoader("digilib-paths", "path", "name", "role");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
57 pathList = pathLoader.loadURL(confFile.toURL().toString());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
58 // load authIPs
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
59 XMLListLoader ipLoader = new XMLListLoader("digilib-addresses", "address", "ip", "role");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
60 ipList = ipLoader.loadURL(confFile.toURL().toString());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
61 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
62 catch (Exception e) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
63 throw new AuthOpException("ERROR loading authorization config file: "+e);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
64 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
65 if ((pathList == null)||(ipList == null)) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
66 throw new AuthOpException("ERROR unable to load authorization config file!");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
67 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
68 // setup path tree
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
69 authPaths = new HashTree(pathList, "/", ",");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
70 // setup ip tree
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
71 authIPs = new HashTree(ipList, ".", ",");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
72 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
73
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
74 public List rolesForPath(String filepath, HttpServletRequest request) throws digilib.auth.AuthOpException {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
75 util.dprintln(4, "rolesForPath ("+filepath+") by ["+request.getRemoteAddr()+"]");
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
76
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
77 // check if the requests address provides a role
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
78 List provided = authIPs.match(request.getRemoteAddr());
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
79 if ((provided != null)&&(provided.contains("ALL"))) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
80 // ALL switches off checking;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
81 return null;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
82 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
83 // which roles are required?
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
84 List required = authPaths.match(filepath);
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
85 // do any provided roles match?
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
86 if ((provided != null)&&(required != null)) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
87 for (int i = 0; i < provided.size(); i++) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
88 if (required.contains(provided.get(i))) {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
89 // satisfied
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
90 return null;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
91 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
92 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
93 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
94 return required;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
95 }
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
96
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
97 }