Revision 2312
Added by Matt Jones over 20 years ago
src/edu/ucsb/nceas/metacat/MetaCatServlet.java | ||
---|---|---|
43 | 43 |
import java.text.SimpleDateFormat; |
44 | 44 |
import java.util.Enumeration; |
45 | 45 |
import java.util.Hashtable; |
46 |
import java.util.Iterator; |
|
46 | 47 |
import java.util.PropertyResourceBundle; |
47 | 48 |
import java.util.Vector; |
49 |
import java.util.regex.PatternSyntaxException; |
|
48 | 50 |
import java.util.zip.ZipEntry; |
49 | 51 |
import java.util.zip.ZipOutputStream; |
50 | 52 |
|
... | ... | |
131 | 133 |
|
132 | 134 |
private String htmlpath = null; |
133 | 135 |
|
136 |
private String[] administrators = null; |
|
137 |
|
|
134 | 138 |
private PropertyResourceBundle options = null; |
135 | 139 |
|
136 | 140 |
private MetaCatUtil util = null; |
... | ... | |
197 | 201 |
dataDirectory = new File(datafilepath); |
198 | 202 |
servletpath = MetaCatUtil.getOption("servletpath"); |
199 | 203 |
htmlpath = MetaCatUtil.getOption("htmlpath"); |
204 |
String adminList = MetaCatUtil.getOption("administrators"); |
|
205 |
try { |
|
206 |
administrators = adminList.split(":"); |
|
207 |
} catch (PatternSyntaxException pse) { |
|
208 |
administrators = null; |
|
209 |
MetaCatUtil.debugMessage("Error in MetacatServlet.init: " |
|
210 |
+ pse.getMessage(), 20); |
|
211 |
} |
|
200 | 212 |
|
201 | 213 |
System.out.println("Metacat (" + Version.getVersion() |
202 | 214 |
+ ") initialized."); |
... | ... | |
497 | 509 |
out.println(Version.getVersionAsXml()); |
498 | 510 |
out.close(); |
499 | 511 |
} else if (action.equals("getlog")) { |
500 |
handleGetLogAction(params, request, response); |
|
512 |
handleGetLogAction(params, request, response, username); |
|
513 |
} else if (action.equals("buildindex")) { |
|
514 |
handleBuildIndexAction(params, request, response, username); |
|
501 | 515 |
} else if (action.equals("login") || action.equals("logout")) { |
516 |
/* |
|
502 | 517 |
} else if (action.equals("protocoltest")) { |
503 | 518 |
String testURL = "metacat://dev.nceas.ucsb.edu/NCEAS.897766.9"; |
504 | 519 |
try { |
... | ... | |
544 | 559 |
mue.printStackTrace(out); |
545 | 560 |
out.close(); |
546 | 561 |
} |
562 |
*/ |
|
547 | 563 |
} else { |
548 | 564 |
PrintWriter out = response.getWriter(); |
549 | 565 |
out.println("<?xml version=\"1.0\"?>"); |
... | ... | |
2091 | 2107 |
* Print a report from the event log based on filter parameters passed in |
2092 | 2108 |
* from the web. |
2093 | 2109 |
* |
2094 |
* TODO: make sure urlencoding of timestamp params is working |
|
2095 |
* |
|
2096 | 2110 |
* @param params the parameters from the web request |
2097 | 2111 |
* @param request the http request object for getting request details |
2098 | 2112 |
* @param response the http response object for writing output |
2099 | 2113 |
*/ |
2100 | 2114 |
private void handleGetLogAction(Hashtable params, HttpServletRequest request, |
2101 |
HttpServletResponse response) |
|
2115 |
HttpServletResponse response, String username)
|
|
2102 | 2116 |
{ |
2103 |
// Get all of the parameters in the correct formats |
|
2104 |
String[] ipAddress = (String[])params.get("ipaddress"); |
|
2105 |
String[] principal = (String[])params.get("principal"); |
|
2106 |
String[] docid = (String[])params.get("docid"); |
|
2107 |
String[] event = (String[])params.get("event"); |
|
2108 |
String[] startArray = (String[]) params.get("start"); |
|
2109 |
String[] endArray = (String[]) params.get("end"); |
|
2110 |
String start = null; |
|
2111 |
String end = null; |
|
2112 |
if (startArray != null) { |
|
2113 |
start = startArray[0]; |
|
2114 |
} |
|
2115 |
if (endArray != null) { |
|
2116 |
end = endArray[0]; |
|
2117 |
} |
|
2118 |
Timestamp startDate = null; |
|
2119 |
Timestamp endDate = null; |
|
2120 |
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); |
|
2121 | 2117 |
try { |
2122 |
if (start != null) { |
|
2123 |
startDate = new Timestamp((format.parse(start)).getTime()); |
|
2118 |
response.setContentType("text/xml"); |
|
2119 |
PrintWriter out = response.getWriter(); |
|
2120 |
|
|
2121 |
// Check that the user is authenticated as an administrator account |
|
2122 |
boolean adminIsAuthenticated = false; |
|
2123 |
for (int i = 0; i < administrators.length; i++) { |
|
2124 |
if (username.equals(administrators[i])) { |
|
2125 |
adminIsAuthenticated = true; |
|
2126 |
} |
|
2124 | 2127 |
} |
2125 |
if (end != null) { |
|
2126 |
endDate = new Timestamp((format.parse(end)).getTime()); |
|
2128 |
if (!adminIsAuthenticated) { |
|
2129 |
out.print("<error>"); |
|
2130 |
out.print("The user \"" + username + |
|
2131 |
"\" is not authorized for this action."); |
|
2132 |
out.print("</error>"); |
|
2133 |
return; |
|
2127 | 2134 |
} |
2128 |
} catch (ParseException e) { |
|
2129 |
System.out.println("Failed to created Timestamp from input."); |
|
2135 |
|
|
2136 |
// Get all of the parameters in the correct formats |
|
2137 |
String[] ipAddress = (String[])params.get("ipaddress"); |
|
2138 |
String[] principal = (String[])params.get("principal"); |
|
2139 |
String[] docid = (String[])params.get("docid"); |
|
2140 |
String[] event = (String[])params.get("event"); |
|
2141 |
String[] startArray = (String[]) params.get("start"); |
|
2142 |
String[] endArray = (String[]) params.get("end"); |
|
2143 |
String start = null; |
|
2144 |
String end = null; |
|
2145 |
if (startArray != null) { |
|
2146 |
start = startArray[0]; |
|
2147 |
} |
|
2148 |
if (endArray != null) { |
|
2149 |
end = endArray[0]; |
|
2150 |
} |
|
2151 |
Timestamp startDate = null; |
|
2152 |
Timestamp endDate = null; |
|
2153 |
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); |
|
2154 |
try { |
|
2155 |
if (start != null) { |
|
2156 |
startDate = new Timestamp((format.parse(start)).getTime()); |
|
2157 |
} |
|
2158 |
if (end != null) { |
|
2159 |
endDate = new Timestamp((format.parse(end)).getTime()); |
|
2160 |
} |
|
2161 |
} catch (ParseException e) { |
|
2162 |
System.out.println("Failed to created Timestamp from input."); |
|
2163 |
} |
|
2164 |
|
|
2165 |
// Request the report by passing the filter parameters |
|
2166 |
out.println(EventLog.getInstance().getReport(ipAddress, principal, |
|
2167 |
docid, event, startDate, endDate)); |
|
2168 |
out.close(); |
|
2169 |
} catch (IOException e) { |
|
2170 |
MetaCatUtil.debugMessage( |
|
2171 |
"Could not open http response for writing: " + e.getMessage(), 5); |
|
2130 | 2172 |
} |
2173 |
} |
|
2131 | 2174 |
|
2132 |
// Request the report by passing the filter parameters |
|
2175 |
/** |
|
2176 |
* Rebuild the index for one or more documents. If the docid parameter is |
|
2177 |
* provided, rebuild for just that one document or list of documents. If |
|
2178 |
* not, then rebuild the index for all documents in the xml_documents |
|
2179 |
* table. |
|
2180 |
* |
|
2181 |
* @param params the parameters from the web request |
|
2182 |
* @param request the http request object for getting request details |
|
2183 |
* @param response the http response object for writing output |
|
2184 |
* @param username the username of the authenticated user |
|
2185 |
*/ |
|
2186 |
private void handleBuildIndexAction(Hashtable params, |
|
2187 |
HttpServletRequest request, HttpServletResponse response, |
|
2188 |
String username) |
|
2189 |
{ |
|
2190 |
// Get all of the parameters in the correct formats |
|
2191 |
String[] docid = (String[])params.get("docid"); |
|
2192 |
|
|
2193 |
// Rebuild the indices for appropriate documents |
|
2133 | 2194 |
try { |
2134 | 2195 |
response.setContentType("text/xml"); |
2135 | 2196 |
PrintWriter out = response.getWriter(); |
2136 |
out.println(EventLog.getInstance().getReport(ipAddress, principal, |
|
2137 |
docid, event, startDate, endDate)); |
|
2197 |
|
|
2198 |
// Check that the user is authenticated as an administrator account |
|
2199 |
boolean adminIsAuthenticated = false; |
|
2200 |
for (int i = 0; i < administrators.length; i++) { |
|
2201 |
if (username.equals(administrators[i])) { |
|
2202 |
adminIsAuthenticated = true; |
|
2203 |
} |
|
2204 |
} |
|
2205 |
if (!adminIsAuthenticated) { |
|
2206 |
out.print("<error>"); |
|
2207 |
out.print("The user \"" + username + |
|
2208 |
"\" is not authorized for this action."); |
|
2209 |
out.print("</error>"); |
|
2210 |
return; |
|
2211 |
} |
|
2212 |
|
|
2213 |
// Process the documents |
|
2214 |
out.println("<success>"); |
|
2215 |
if (docid == null || docid.length == 0) { |
|
2216 |
// Process all of the documents |
|
2217 |
try { |
|
2218 |
Vector documents = getDocumentList(); |
|
2219 |
Iterator it = documents.iterator(); |
|
2220 |
while (it.hasNext()) { |
|
2221 |
String id = (String) it.next(); |
|
2222 |
buildDocumentIndex(id, out); |
|
2223 |
} |
|
2224 |
} catch (SQLException se) { |
|
2225 |
out.print("<error>"); |
|
2226 |
out.print(se.getMessage()); |
|
2227 |
out.println("</error>"); |
|
2228 |
} |
|
2229 |
} else { |
|
2230 |
// Only process the requested documents |
|
2231 |
for (int i = 0; i < docid.length; i++) { |
|
2232 |
buildDocumentIndex(docid[i], out); |
|
2233 |
} |
|
2234 |
} |
|
2235 |
out.println("</success>"); |
|
2138 | 2236 |
out.close(); |
2139 | 2237 |
} catch (IOException e) { |
2140 | 2238 |
MetaCatUtil.debugMessage( |
... | ... | |
2144 | 2242 |
} |
2145 | 2243 |
|
2146 | 2244 |
/** |
2245 |
* Build the index for one document by reading the document and |
|
2246 |
* calling its buildIndex() method. |
|
2247 |
* |
|
2248 |
* @param docid the document (with revision) to rebuild |
|
2249 |
* @param out the PrintWriter to which output is printed |
|
2250 |
*/ |
|
2251 |
private void buildDocumentIndex(String docid, PrintWriter out) |
|
2252 |
{ |
|
2253 |
try { |
|
2254 |
DocumentImpl doc = new DocumentImpl(docid, false); |
|
2255 |
doc.buildIndex(); |
|
2256 |
out.print("<docid>" + docid); |
|
2257 |
out.println("</docid>"); |
|
2258 |
} catch (McdbException me) { |
|
2259 |
out.print("<error>"); |
|
2260 |
out.print(me.getMessage()); |
|
2261 |
out.println("</error>"); |
|
2262 |
} |
|
2263 |
} |
|
2264 |
|
|
2265 |
/** |
|
2147 | 2266 |
* Handle documents passed to metacat that are encoded using the |
2148 | 2267 |
* "multipart/form-data" mime type. This is typically used for uploading |
2149 | 2268 |
* data files which may be binary and large. |
... | ... | |
2554 | 2673 |
} |
2555 | 2674 |
|
2556 | 2675 |
/* |
2676 |
* Get the list of documents from the database and return the list in an |
|
2677 |
* Vector of identifiers. |
|
2678 |
* |
|
2679 |
* @ returns the array of identifiers |
|
2680 |
*/ |
|
2681 |
private Vector getDocumentList() throws SQLException |
|
2682 |
{ |
|
2683 |
Vector docList = new Vector(); |
|
2684 |
PreparedStatement pstmt = null; |
|
2685 |
ResultSet rs = null; |
|
2686 |
DBConnection conn = null; |
|
2687 |
int serialNumber = -1; |
|
2688 |
|
|
2689 |
try { |
|
2690 |
//check out DBConnection |
|
2691 |
conn = DBConnectionPool |
|
2692 |
.getDBConnection("MetaCatServlet.getDocumentList"); |
|
2693 |
serialNumber = conn.getCheckOutSerialNumber(); |
|
2694 |
pstmt = conn.prepareStatement("SELECT docid, rev" |
|
2695 |
+ " FROM xml_documents "); |
|
2696 |
pstmt.execute(); |
|
2697 |
rs = pstmt.getResultSet(); |
|
2698 |
while (rs.next()) { |
|
2699 |
String docid = rs.getString(1); |
|
2700 |
String rev = rs.getString(2); |
|
2701 |
docList.add(docid + "." + rev); |
|
2702 |
} |
|
2703 |
} catch (SQLException e) { |
|
2704 |
MetaCatUtil.debugMessage( |
|
2705 |
"Exception in MetacatServlet.getDocumentList: " |
|
2706 |
+ e.getMessage(), 30); |
|
2707 |
throw e; |
|
2708 |
} finally { |
|
2709 |
try { |
|
2710 |
rs.close(); |
|
2711 |
pstmt.close(); |
|
2712 |
|
|
2713 |
} catch (SQLException se) { |
|
2714 |
MetaCatUtil.debugMessage( |
|
2715 |
"Exception in MetacatServlet.getDocumentList: " |
|
2716 |
+ se.getMessage(), 30); |
|
2717 |
throw se; |
|
2718 |
} finally { |
|
2719 |
DBConnectionPool.returnDBConnection(conn, serialNumber); |
|
2720 |
} |
|
2721 |
} |
|
2722 |
return docList; |
|
2723 |
} |
|
2724 |
|
|
2725 |
/* |
|
2557 | 2726 |
* A method to output setAccess action result |
2558 | 2727 |
*/ |
2559 | 2728 |
private void outputResponse(Vector successList, Vector errorList, |
Also available in: Unified diff
Added in servlet action 'buildindex' for building the XML_index table entries
for either a set of documents (if one or more docid params are provided) or
for the whole set of documents in the xml_documents table. The buildindex
action is restricted to only be accessible by users who are listed in the
metacat.properties file as 'administrators'. So this is a new category of
users that we can use to control administrative actions. In addition, I
restricted access to the 'getlog' action of metacat to the administrative
users.