Project

General

Profile

« Previous | Next » 

Revision 3514

Added by barteau over 16 years ago

Added param to indicate if public has read access or not, in the method "readFromMetacat". It only does this if reading a metadata document, for a skin-format,
and the user is not public. This is useful to the skin's metadata display/editing form, for indicating public accessiblity (or inaccessibility).
Also, my "auto-format" moved a bunch of curly braces to the typical position.

View differences:

src/edu/ucsb/nceas/metacat/MetaCatServlet.java
122 122
 * action value is quite specific. This documentation will be reorganized to
123 123
 * reflect this information.
124 124
 */
125
public class MetaCatServlet extends HttpServlet
126
{
125
public class MetaCatServlet extends HttpServlet {
127 126
    private static Hashtable sessionHash = new Hashtable();
128 127
    private Timer timer = null;
129 128
    private static boolean sitemapScheduled;
......
140 139
    public static final String EML2KEYWORD = ":eml";
141 140
    public static final String XMLFORMAT = "xml";
142 141
    private static final String CONFIG_DIR = "WEB-INF";
143
    private static final String CONFIG_NAME = "metacat.properties"; 
142
    private static final String CONFIG_NAME = "metacat.properties";
144 143
    
145 144
    /**
146 145
     * Initialize the servlet by creating appropriate database connections
147 146
     */
148
    public void init(ServletConfig config) throws ServletException
149
    {
147
    public void init(ServletConfig config) throws ServletException {
150 148
        try {
151 149
            super.init(config);
152 150
            Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
153 151
            
154 152
            ServletContext context = config.getServletContext();
155

  
153
            
156 154
            // Initialize the properties file for our options
157 155
            String dirPath = context.getRealPath(CONFIG_DIR);
158 156
            File propertyFile = new File(dirPath, CONFIG_NAME);
......
167 165
                logMetacat.error("Error in loading options: "
168 166
                        + ioe.getMessage());
169 167
            }
170

  
168
            
171 169
            // Check if the servlet was configured, and if not stop the
172
            // initialization and skip to the configuration web form when 
170
            // initialization and skip to the configuration web form when
173 171
            // metacat is called
174 172
            boolean configured = options.getOption("configured").equals("true");
175 173
            if (!configured) {
......
184 182
            
185 183
            // Index the paths specified in the metacat.properties
186 184
            checkIndexPaths();
187

  
185
            
188 186
            // initiate the indexing Queue
189 187
            IndexingQueue.getInstance();
190 188
            
191
            // start the IndexingThread if indexingTimerTaskTime more than 0. 
192
            // It will index all the documents not yet indexed in the database             
189
            // start the IndexingThread if indexingTimerTaskTime more than 0.
190
            // It will index all the documents not yet indexed in the database
193 191
            int indexingTimerTaskTime = Integer.parseInt(MetaCatUtil.getOption("indexingTimerTaskTime"));
194 192
            int delayTime = Integer.parseInt(MetaCatUtil.getOption("indexingInitialDelay"));
195
           
193
            
196 194
            if(indexingTimerTaskTime > 0){
197
            	timer = new Timer();
198
            	timer.schedule(new IndexingTimerTask(), delayTime, indexingTimerTaskTime);
195
                timer = new Timer();
196
                timer.schedule(new IndexingTimerTask(), delayTime, indexingTimerTaskTime);
199 197
            }
200 198
            
201
            // read the config files: 
199
            // read the config files:
202 200
            Vector skins = MetaCatUtil.getOptionList(MetaCatUtil.getOption("skinconfigfiles"));
203 201
            String skinName, skinDirPath = null;
204 202
            File skinPropertyFile = null;
205
           
203
            
206 204
            for (int i = 0; i < skins.size(); i++) {
207
            	skinName = (String) skins.elementAt(i);
205
                skinName = (String) skins.elementAt(i);
208 206
                skinDirPath = context.getRealPath(CONFIG_DIR + "/skin.configs/" + skinName);
209
                skinPropertyFile = new File(skinDirPath, skinName + ".properties"); 
207
                skinPropertyFile = new File(skinDirPath, skinName + ".properties");
210 208
                Properties skinOption = null;
211 209
                try	{
212
                	skinOption = new Properties();
210
                    skinOption = new Properties();
213 211
                    FileInputStream fis = new FileInputStream(skinPropertyFile);
214 212
                    skinOption.load(fis);
215 213
                    fis.close();
216 214
                } catch (IOException ioe) {
217 215
                    logMetacat.error("Error in loading options for skin " + "skinName" +" : "
218 216
                            + ioe.getMessage());
219
                }                
217
                }
220 218
                MetaCatUtil.skinconfigs.put(skinName, skinOption);
221 219
            }
222

  
220
            
223 221
            /*
224 222
             *  If spatial option is turned on and set to regenerate the
225
             *  spatial cache on restart, trigger the harvester regeneratation method 
223
             *  spatial cache on restart, trigger the harvester regeneratation method
226 224
             */
227 225
            if ( MetaCatUtil.getOption("runSpatialOption").equals("true") &&
228
                 MetaCatUtil.getOption("regenerateCacheOnRestart").equals("true") ) {
229

  
226
                    MetaCatUtil.getOption("regenerateCacheOnRestart").equals("true") ) {
227
                
230 228
                // Begin timer
231 229
                long before = System.currentTimeMillis();
232
                 
230
                
233 231
                // regenerate the entire spatial cache
234 232
                // may be expensive with many documents
235 233
                SpatialHarvester sh = new SpatialHarvester();
236 234
                sh.regenerate();
237 235
                sh.destroy();
238

  
239
		// After running the first time, we want to to set regenerateCacheOnRestart to false
240
		// so that it does not regenerate the cache every time tomcat is restarted
241
		MetaCatUtil.setOption("regenerateCacheOnRestart","false");
242

  
236
                
237
                // After running the first time, we want to to set regenerateCacheOnRestart to false
238
                // so that it does not regenerate the cache every time tomcat is restarted
239
                MetaCatUtil.setOption("regenerateCacheOnRestart","false");
240
                
243 241
                // End timer
244 242
                long after = System.currentTimeMillis();
245 243
                logMetacat.info(" ------ Spatial Harvester Time  " + (after - before) + "ms");
246

  
247
	    } else {
244
                
245
            } else {
248 246
                logMetacat.info(" \n **** Spatial cache is not set to regenerate on restart");
249 247
            }
250 248
            
251 249
            sitemapScheduled = false;
252 250
            
253 251
            logMetacat.info("Metacat (" + Version.getVersion()
254
                               + ") initialized.");
255

  
252
            + ") initialized.");
253
            
256 254
        } catch (ServletException ex) {
257 255
            throw ex;
258 256
        } catch (SQLException e) {
......
265 263
                    + ie.getMessage());
266 264
        }
267 265
    }
268

  
266
    
269 267
    /**
270 268
     * Close all db connections from the pool
271 269
     */
272
    public void destroy()
273
    {
270
    public void destroy() {
274 271
        // Close all db connection
275 272
        System.out.println("Destroying MetacatServlet");
276 273
        timer.cancel();
277 274
        IndexingQueue.getInstance().setMetacatRunning(false);
278 275
        DBConnectionPool.release();
279 276
    }
280

  
277
    
281 278
    /** Handle "GET" method requests from HTTP clients */
282 279
    public void doGet(HttpServletRequest request, HttpServletResponse response)
283
            throws ServletException, IOException
284
    {
285

  
280
    throws ServletException, IOException {
281
        
286 282
        // Process the data and send back the response
287 283
        handleGetOrPost(request, response);
288 284
    }
289

  
285
    
290 286
    /** Handle "POST" method requests from HTTP clients */
291 287
    public void doPost(HttpServletRequest request, HttpServletResponse response)
292
            throws ServletException, IOException
293
    {
294

  
288
    throws ServletException, IOException {
289
        
295 290
        // Process the data and send back the response
296 291
        handleGetOrPost(request, response);
297 292
    }
298

  
293
    
299 294
    /**
300 295
     * Index the paths specified in the metacat.properties
301 296
     */
302 297
    private void checkIndexPaths() {
303 298
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
304 299
        MetaCatUtil.pathsForIndexing
305
            = MetaCatUtil.getOptionList(MetaCatUtil.getOption("indexPaths"));
306
    
300
                = MetaCatUtil.getOptionList(MetaCatUtil.getOption("indexPaths"));
301
        
307 302
        if (MetaCatUtil.pathsForIndexing != null) {
308
    
303
            
309 304
            logMetacat.debug("Indexing paths specified in metacat.properties....");
310
    
305
            
311 306
            DBConnection conn = null;
312 307
            int serialNumber = -1;
313 308
            PreparedStatement pstmt = null;
314 309
            PreparedStatement pstmt1 = null;
315 310
            ResultSet rs = null;
316
    
311
            
317 312
            for (int i = 0; i < MetaCatUtil.pathsForIndexing.size(); i++) {
318 313
                logMetacat.debug("Checking if '"
319
                           + (String) MetaCatUtil.pathsForIndexing.elementAt(i)
320
                           + "' is indexed.... ");
321
    
314
                        + (String) MetaCatUtil.pathsForIndexing.elementAt(i)
315
                        + "' is indexed.... ");
316
                
322 317
                try {
323 318
                    //check out DBConnection
324 319
                    conn = DBConnectionPool.
325
                        getDBConnection("MetaCatServlet.checkIndexPaths");
320
                            getDBConnection("MetaCatServlet.checkIndexPaths");
326 321
                    serialNumber = conn.getCheckOutSerialNumber();
327
    
322
                    
328 323
                    pstmt = conn.prepareStatement(
329
                        "SELECT * FROM xml_path_index " + "WHERE path = ?");
324
                            "SELECT * FROM xml_path_index " + "WHERE path = ?");
330 325
                    pstmt.setString(1, (String) MetaCatUtil.pathsForIndexing
331
                                    .elementAt(i));
332
    
326
                            .elementAt(i));
327
                    
333 328
                    pstmt.execute();
334 329
                    rs = pstmt.getResultSet();
335
    
330
                    
336 331
                    if (!rs.next()) {
337 332
                        logMetacat.debug(".....not indexed yet.");
338 333
                        rs.close();
339 334
                        pstmt.close();
340 335
                        conn.increaseUsageCount(1);
341
    
336
                        
342 337
                        logMetacat.debug(
343
                              "Inserting following path in xml_path_index: "
344
                              + (String)MetaCatUtil.pathsForIndexing
345
                                                   .elementAt(i));
346
   			if(((String)MetaCatUtil.pathsForIndexing.elementAt(i)).indexOf("@")<0){ 
347
                        	pstmt = conn.prepareStatement("SELECT DISTINCT n.docid, "
348
                              		+ "n.nodedata, n.nodedatanumerical, n.parentnodeid"
349
                              		+ " FROM xml_nodes n, xml_index i WHERE"
350
                              		+ " i.path = ? and n.parentnodeid=i.nodeid and"
351
                              		+ " n.nodetype LIKE 'TEXT' order by n.parentnodeid");
352
			} else {
353
                        	pstmt = conn.prepareStatement("SELECT DISTINCT n.docid, "
354
                              		+ "n.nodedata, n.nodedatanumerical, n.parentnodeid"
355
                              		+ " FROM xml_nodes n, xml_index i WHERE"
356
                              		+ " i.path = ? and n.nodeid=i.nodeid and"
357
                              		+ " n.nodetype LIKE 'ATTRIBUTE' order by n.parentnodeid");
358
			}
338
                                "Inserting following path in xml_path_index: "
339
                                + (String)MetaCatUtil.pathsForIndexing
340
                                .elementAt(i));
341
                        if(((String)MetaCatUtil.pathsForIndexing.elementAt(i)).indexOf("@")<0){
342
                            pstmt = conn.prepareStatement("SELECT DISTINCT n.docid, "
343
                                    + "n.nodedata, n.nodedatanumerical, n.parentnodeid"
344
                                    + " FROM xml_nodes n, xml_index i WHERE"
345
                                    + " i.path = ? and n.parentnodeid=i.nodeid and"
346
                                    + " n.nodetype LIKE 'TEXT' order by n.parentnodeid");
347
                        } else {
348
                            pstmt = conn.prepareStatement("SELECT DISTINCT n.docid, "
349
                                    + "n.nodedata, n.nodedatanumerical, n.parentnodeid"
350
                                    + " FROM xml_nodes n, xml_index i WHERE"
351
                                    + " i.path = ? and n.nodeid=i.nodeid and"
352
                                    + " n.nodetype LIKE 'ATTRIBUTE' order by n.parentnodeid");
353
                        }
359 354
                        pstmt.setString(1, (String) MetaCatUtil.
360
                                        pathsForIndexing.elementAt(i));
355
                                pathsForIndexing.elementAt(i));
361 356
                        pstmt.execute();
362 357
                        rs = pstmt.getResultSet();
363
    
358
                        
364 359
                        int count = 0;
365 360
                        logMetacat.debug(
366
                                       "Executed the select statement for: "
367
                                       + (String) MetaCatUtil.pathsForIndexing
368
                                         .elementAt(i));
369
    
361
                                "Executed the select statement for: "
362
                                + (String) MetaCatUtil.pathsForIndexing
363
                                .elementAt(i));
364
                        
370 365
                        try {
371 366
                            while (rs.next()) {
372
    
367
                                
373 368
                                String docid = rs.getString(1);
374 369
                                String nodedata = rs.getString(2);
375 370
                                float nodedatanumerical = rs.getFloat(3);
376 371
                                int parentnodeid = rs.getInt(4);
377
    
372
                                
378 373
                                if (!nodedata.trim().equals("")) {
379 374
                                    pstmt1 = conn.prepareStatement(
380
                                        "INSERT INTO xml_path_index"
381
                                        + " (docid, path, nodedata, "
382
                                        + "nodedatanumerical, parentnodeid)"
383
                                        + " VALUES (?, ?, ?, ?, ?)");
384
    
375
                                            "INSERT INTO xml_path_index"
376
                                            + " (docid, path, nodedata, "
377
                                            + "nodedatanumerical, parentnodeid)"
378
                                            + " VALUES (?, ?, ?, ?, ?)");
379
                                    
385 380
                                    pstmt1.setString(1, docid);
386 381
                                    pstmt1.setString(2, (String) MetaCatUtil.
387
                                                pathsForIndexing.elementAt(i));
382
                                            pathsForIndexing.elementAt(i));
388 383
                                    pstmt1.setString(3, nodedata);
389 384
                                    pstmt1.setFloat(4, nodedatanumerical);
390 385
                                    pstmt1.setInt(5, parentnodeid);
391
    
386
                                    
392 387
                                    pstmt1.execute();
393 388
                                    pstmt1.close();
394
    
389
                                    
395 390
                                    count++;
396
    
391
                                    
397 392
                                }
398 393
                            }
399
                        }
400
                        catch (Exception e) {
394
                        } catch (Exception e) {
401 395
                            System.out.println("Exception:" + e.getMessage());
402 396
                            e.printStackTrace();
403 397
                        }
404
    
398
                        
405 399
                        rs.close();
406 400
                        pstmt.close();
407 401
                        conn.increaseUsageCount(1);
408
    
402
                        
409 403
                        logMetacat.info("Indexed " + count
410 404
                                + " records from xml_nodes for '"
411 405
                                + (String) MetaCatUtil.pathsForIndexing.elementAt(i)
412 406
                                + "'");
413
    
407
                        
414 408
                    } else {
415
                    	logMetacat.debug(".....already indexed.");
409
                        logMetacat.debug(".....already indexed.");
416 410
                    }
417
    
411
                    
418 412
                    rs.close();
419 413
                    pstmt.close();
420 414
                    conn.increaseUsageCount(1);
421
    
415
                    
422 416
                } catch (Exception e) {
423 417
                    logMetacat.error("Error in MetaCatServlet.checkIndexPaths: "
424
                                             + e.getMessage());
418
                            + e.getMessage());
425 419
                }finally {
426 420
                    //check in DBonnection
427 421
                    DBConnectionPool.returnDBConnection(conn, serialNumber);
428 422
                }
429
    
430
    
423
                
424
                
431 425
            }
432
    
426
            
433 427
            logMetacat.debug("Path Indexing Completed");
434 428
        }
435
    }    
436

  
429
    }
430
    
437 431
    /**
438 432
     * Control servlet response depending on the action parameter specified
439 433
     */
440 434
    private void handleGetOrPost(HttpServletRequest request,
441
            HttpServletResponse response) throws ServletException, IOException
442
    {
435
            HttpServletResponse response) throws ServletException, IOException {
443 436
        MetaCatUtil util = new MetaCatUtil();
444 437
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
445 438
        
......
460 453
        //size is greater than initial value, shrink the connection pool
461 454
        //size to initial value
462 455
        DBConnectionPool.shrinkDBConnectionPoolSize();
463

  
456
        
464 457
        //Debug message to print out the method which have a busy DBConnection
465 458
        try {
466 459
            DBConnectionPool pool = DBConnectionPool.getInstance();
......
470 463
                    + e.getMessage());
471 464
            e.printStackTrace();
472 465
        }
473

  
466
        
474 467
        String ctype = request.getContentType();
475 468
        if (ctype != null && ctype.startsWith("multipart/form-data")) {
476 469
            handleMultipartForm(request, response);
477 470
        } else {
478

  
471
            
479 472
            String name = null;
480 473
            String[] value = null;
481 474
            String[] docid = new String[3];
......
487 480
            //     e.g.,  http://localhost:8180/knb/metacat/test.1.1/knb
488 481
            String pathInfo = request.getPathInfo();
489 482
            if (pathInfo != null) {
490
            	String[] path = pathInfo.split("/");
491
            	if (path.length > 1) {
492
            		String docidToRead = path[1];
493
            		String docs[] = new String[1];
494
            		docs[0] = docidToRead;
495
            		logMetacat.debug("READING DOCID FROM PATHINFO: " + docs[0]);
496
            		params.put("docid", docs);
497
            		String skin = null;
498
            		if (path.length > 2) {
499
            			skin = path[2];
500
            			String skins[] = new String[1];
501
            			skins[0] = skin;
502
            			params.put("qformat", skins);
503
            		}
483
                String[] path = pathInfo.split("/");
484
                if (path.length > 1) {
485
                    String docidToRead = path[1];
486
                    String docs[] = new String[1];
487
                    docs[0] = docidToRead;
488
                    logMetacat.debug("READING DOCID FROM PATHINFO: " + docs[0]);
489
                    params.put("docid", docs);
490
                    String skin = null;
491
                    if (path.length > 2) {
492
                        skin = path[2];
493
                        String skins[] = new String[1];
494
                        skins[0] = skin;
495
                        params.put("qformat", skins);
496
                    }
504 497
                    handleReadAction(params, request, response, "public", null, null);
505 498
                    return;
506
            	}
499
                }
507 500
            }
508 501
            
509 502
            Enumeration paramlist = request.getParameterNames();
510 503
            while (paramlist.hasMoreElements()) {
511

  
504
                
512 505
                name = (String) paramlist.nextElement();
513 506
                value = request.getParameterValues(name);
514

  
507
                
515 508
                // Decode the docid and mouse click information
516 509
                // THIS IS OBSOLETE -- I THINK -- REMOVE THIS BLOCK 4/12/2007 MBJ
517 510
                if (name.endsWith(".y")) {
......
522 515
                if (name.endsWith(".x")) {
523 516
                    name = "xpos";
524 517
                }
525

  
518
                
526 519
                params.put(name, value);
527 520
            }
528

  
521
            
529 522
            //handle param is emptpy
530 523
            if (params.isEmpty() || params == null) { return; }
531

  
524
            
532 525
            //if the user clicked on the input images, decode which image
533 526
            //was clicked then set the action.
534 527
            if(params.get("action") == null){
......
541 534
                out.close();
542 535
                return;
543 536
            }
544

  
537
            
545 538
            String action = ((String[]) params.get("action"))[0];
546 539
            logMetacat.info("Action is: " + action);
547

  
540
            
548 541
            // This block handles session management for the servlet
549 542
            // by looking up the current session information for all actions
550 543
            // other than "login" and "logout"
......
559 552
                PrintWriter out = response.getWriter();
560 553
                handleLoginAction(out, params, request, response);
561 554
                out.close();
562
        
555
                
563 556
                // handle logout action
564 557
            }   else if (action.equals("logout")) {
565 558
                PrintWriter out = response.getWriter();
566 559
                handleLogoutAction(out, params, request, response);
567 560
                out.close();
568

  
561
                
569 562
                // handle shrink DBConnection request
570 563
            } else if (action.equals("shrink")) {
571 564
                PrintWriter out = response.getWriter();
......
585 578
                }
586 579
                //close out put
587 580
                out.close();
588

  
581
                
589 582
                // aware of session expiration on every request
590 583
            } else {
591 584
                HttpSession sess = request.getSession(true);
......
597 590
                    username = "public";
598 591
                    sess.setAttribute("username", username);
599 592
                    sess_id = (String)sess.getId();
600
                              sess.setAttribute("sessionid", sess_id);
593
                    sess.setAttribute("sessionid", sess_id);
601 594
                    sessionHash.put(sess_id, sess);
602 595
                } else {
603 596
                    logMetacat.info("The session is either old or "
......
613 606
                                sess = (HttpSession) sessionHash.get(sess_id);
614 607
                            }
615 608
                        } else {
616
                          //this makes sure there is a session object for public sessions
617
                          sess_id = sess.getId();
618
                          sessionHash.put(sess_id, sess);
609
                            //this makes sure there is a session object for public sessions
610
                            sess_id = sess.getId();
611
                            sessionHash.put(sess_id, sess);
619 612
                        }
620 613
                    } catch (IllegalStateException ise) {
621 614
                        logMetacat.error(
......
623 616
                                + "happen: the session should be valid: "
624 617
                                + ise.getMessage());
625 618
                    }
626

  
619
                    
627 620
                    username = (String) sess.getAttribute("username");
628 621
                    logMetacat.info("The user name from session is: "
629 622
                            + username);
......
658 651
                    out.close();
659 652
                }
660 653
            } else if ( action.trim().equals("spatial_query")) {
661

  
662
              logMetacat.debug("******************* SPATIAL QUERY ********************");
663
              PrintWriter out = response.getWriter();
664
              handleSpatialQuery(out, params, response, username, groupnames, sess_id);
665
              out.close();
666
            
654
                
655
                logMetacat.debug("******************* SPATIAL QUERY ********************");
656
                PrintWriter out = response.getWriter();
657
                handleSpatialQuery(out, params, response, username, groupnames, sess_id);
658
                out.close();
659
                
667 660
            } else if (action.equals("export")) {
668

  
661
                
669 662
                handleExportAction(params, response, username,
670 663
                        groupnames, password);
671 664
            } else if (action.equals("read")) {
......
758 751
                out.println(username);
759 752
                out.println("\n</username>\n");
760 753
                if(name!=null){
761
                	out.println("\n<name>\n");
762
                	out.println(name);
763
                	out.println("\n</name>\n");
754
                    out.println("\n<name>\n");
755
                    out.println(name);
756
                    out.println("\n</name>\n");
764 757
                }
765 758
                if(MetaCatUtil.isAdministrator(username, groupnames)){
766
                	out.println("<isAdministrator></isAdministrator>\n");	
759
                    out.println("<isAdministrator></isAdministrator>\n");
767 760
                }
768 761
                if(MetaCatUtil.isModerator(username, groupnames)){
769
                	out.println("<isModerator></isModerator>\n");	
762
                    out.println("<isModerator></isModerator>\n");
770 763
                }
771 764
                out.println("\n</user>\n");
772 765
                out.close();
......
819 812
                    mue.printStackTrace(out);
820 813
                    out.close();
821 814
                }
822
                */
815
                 */
823 816
            } else {
824 817
                PrintWriter out = response.getWriter();
825 818
                out.println("<?xml version=\"1.0\"?>");
826 819
                out.println("<error>");
827 820
                out.println(
828
                     "Error: action not registered.  Please report this error.");
821
                        "Error: action not registered.  Please report this error.");
829 822
                out.println("</error>");
830 823
                out.close();
831 824
            }
832

  
825
            
833 826
            //util.closeConnections();
834 827
            // Close the stream to the client
835 828
            //out.close();
......
838 831
            scheduleSitemapGeneration(request);
839 832
        }
840 833
    }
841

  
834
    
842 835
    /////////////////////////////// METACAT SPATIAL ///////////////////////////
843

  
836
    
844 837
    /**
845
     * handles all spatial queries -- these queries may include any of the 
838
     * handles all spatial queries -- these queries may include any of the
846 839
     * queries supported by the WFS / WMS standards
847
     * 
840
     *
848 841
     * handleSQuery(out, params, response, username, groupnames,
849 842
     *                        sess_id);
850 843
     */
851
    private void handleSpatialQuery(PrintWriter out, Hashtable params, 
852
                                    HttpServletResponse response,
853
                                    String username, String[] groupnames, 
854
                                    String sess_id) {
855
      
844
    private void handleSpatialQuery(PrintWriter out, Hashtable params,
845
            HttpServletResponse response,
846
            String username, String[] groupnames,
847
            String sess_id) {
848
        
856 849
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
857

  
858
	if ( !MetaCatUtil.getOption("runSpatialOption").equals("true") ) {
859
        	response.setContentType("text/html");
860
        	out.println("<html> Metacat Spatial Option is turned off </html>");
861
        	out.close();
862
		return ;
863
	}		
864
      
865
        /* 
850
        
851
        if ( !MetaCatUtil.getOption("runSpatialOption").equals("true") ) {
852
            response.setContentType("text/html");
853
            out.println("<html> Metacat Spatial Option is turned off </html>");
854
            out.close();
855
            return ;
856
        }
857
        
858
        /*
866 859
         * Perform spatial query against spatial cache
867 860
         */
868 861
        float _xmax = Float.valueOf( ((String[]) params.get("xmax"))[0] ).floatValue();
......
873 866
        Vector docids = sq.filterByBbox( _xmin, _ymin, _xmax, _ymax );
874 867
        // logMetacat.info(" --- Spatial Query completed. Passing on the SQuery handler");
875 868
        // logMetacat.warn("\n\n ******* after spatial query, we've got " + docids.size() + " docids \n\n");
876

  
869
        
877 870
        /*
878 871
         * Create an array matching docids
879 872
         */
880 873
        String [] docidArray = new String[docids.size()];
881 874
        docids.toArray(docidArray);
882

  
875
        
883 876
        /*
884 877
         * Create squery string
885 878
         */
......
888 881
        String[] queryArray = new String[1];
889 882
        queryArray[0] = squery;
890 883
        params.put("query", queryArray);
891

  
884
        
892 885
        /*
893 886
         * Determine qformat
894 887
         */
......
902 895
            qformatArray[0] = "knp";
903 896
        }
904 897
        params.put("qformat", qformatArray);
905

  
898
        
906 899
        // change the action
907 900
        String[] actionArray = new String[1];
908 901
        actionArray[0] = "squery";
909 902
        params.put("action", actionArray);
910

  
903
        
911 904
        /*
912 905
         * Pass the docids to the DBQuery contructor
913 906
         */
......
915 908
        // Otherwise dbquery sees no docidOverrides and does a full % percent query
916 909
        if (docids.size() == 0)
917 910
            docids.add("");
918

  
911
        
919 912
        DBQuery queryobj = new DBQuery(docids);
920 913
        queryobj.findDocuments(response, out, params, username, groupnames, sess_id);
921

  
922
  }
923

  
914
        
915
    }
916
    
924 917
    // LOGIN & LOGOUT SECTION
925 918
    /**
926 919
     * Handle the login request. Create a new session object. Do user
927 920
     * authentication through the session.
928 921
     */
929 922
    private void handleLoginAction(PrintWriter out, Hashtable params,
930
            HttpServletRequest request, HttpServletResponse response)
931
    {
923
            HttpServletRequest request, HttpServletResponse response) {
932 924
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
933 925
        AuthSession sess = null;
934

  
926
        
935 927
        if(params.get("username") == null){
936 928
            response.setContentType("text/xml");
937 929
            out.println("<?xml version=\"1.0\"?>");
......
940 932
            out.println("</error>");
941 933
            return;
942 934
        }
943

  
935
        
944 936
        //}
945

  
937
        
946 938
        if(params.get("password") == null){
947 939
            response.setContentType("text/xml");
948 940
            out.println("<?xml version=\"1.0\"?>");
......
951 943
            out.println("</error>");
952 944
            return;
953 945
        }
954

  
946
        
955 947
        String un = ((String[]) params.get("username"))[0];
956 948
        logMetacat.info("user " + un + " is trying to login");
957 949
        String pw = ((String[]) params.get("password"))[0];
958

  
950
        
959 951
        String qformat = "xml";
960 952
        if(params.get("qformat") != null){
961 953
            qformat = ((String[]) params.get("qformat"))[0];
962 954
        }
963

  
955
        
964 956
        try {
965 957
            sess = new AuthSession();
966 958
        } catch (Exception e) {
......
970 962
            return;
971 963
        }
972 964
        boolean isValid = sess.authenticate(request, un, pw);
973

  
965
        
974 966
        //if it is authernticate is true, store the session
975 967
        if (isValid) {
976 968
            HttpSession session = sess.getSessions();
......
980 972
                    + " into hash in login method");
981 973
            sessionHash.put(id, session);
982 974
        }
983

  
975
        
984 976
        // format and transform the output
985 977
        if (qformat.equals("xml")) {
986 978
            response.setContentType("text/xml");
......
993 985
                        "-//NCEAS//login//EN", "-//W3C//HTML//EN", qformat,
994 986
                        out, null);
995 987
            } catch (Exception e) {
996

  
988
                
997 989
                logMetacat.error(
998 990
                        "Error in MetaCatServlet.handleLoginAction: "
999
                                + e.getMessage());
991
                        + e.getMessage());
1000 992
            }
1001 993
        }
1002 994
    }
1003

  
995
    
1004 996
    /**
1005 997
     * Handle the logout request. Close the connection.
1006 998
     */
1007 999
    private void handleLogoutAction(PrintWriter out, Hashtable params,
1008
            HttpServletRequest request, HttpServletResponse response)
1009
    {
1000
            HttpServletRequest request, HttpServletResponse response) {
1010 1001
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
1011 1002
        String qformat = "xml";
1012 1003
        if(params.get("qformat") != null){
1013 1004
            qformat = ((String[]) params.get("qformat"))[0];
1014 1005
        }
1015

  
1006
        
1016 1007
        // close the connection
1017 1008
        HttpSession sess = request.getSession(false);
1018 1009
        logMetacat.info("After get session in logout request");
1019 1010
        if (sess != null) {
1020 1011
            logMetacat.info("The session id " + sess.getId()
1021
                    + " will be invalidate in logout action");
1012
            + " will be invalidate in logout action");
1022 1013
            logMetacat.info("The session contains user "
1023 1014
                    + sess.getAttribute("username")
1024 1015
                    + " will be invalidate in logout action");
1025 1016
            sess.invalidate();
1026 1017
        }
1027

  
1018
        
1028 1019
        // produce output
1029 1020
        StringBuffer output = new StringBuffer();
1030 1021
        output.append("<?xml version=\"1.0\"?>");
1031 1022
        output.append("<logout>");
1032 1023
        output.append("User logged out");
1033 1024
        output.append("</logout>");
1034

  
1025
        
1035 1026
        //format and transform the output
1036 1027
        if (qformat.equals("xml")) {
1037 1028
            response.setContentType("text/xml");
......
1046 1037
            } catch (Exception e) {
1047 1038
                logMetacat.error(
1048 1039
                        "Error in MetaCatServlet.handleLogoutAction"
1049
                                + e.getMessage());
1040
                        + e.getMessage());
1050 1041
            }
1051 1042
        }
1052 1043
    }
1053

  
1044
    
1054 1045
    // END OF LOGIN & LOGOUT SECTION
1055

  
1046
    
1056 1047
    // SQUERY & QUERY SECTION
1057 1048
    /**
1058 1049
     * Retreive the squery xml, execute it and display it
......
1065 1056
     */
1066 1057
    private void handleSQuery(PrintWriter out, Hashtable params,
1067 1058
            HttpServletResponse response, String user, String[] groups,
1068
            String sessionid)
1069
    {
1059
            String sessionid) {
1070 1060
        double startTime = System.currentTimeMillis() / 1000;
1071 1061
        DBQuery queryobj = new DBQuery();
1072 1062
        queryobj.findDocuments(response, out, params, user, groups, sessionid);
......
1075 1065
        logMetacat.warn("Total search time for action 'squery': "
1076 1066
                + (outPutTime - startTime));
1077 1067
        MetaCatUtil.writeDebugToFile("---------------------------------------------------------------------------------"+
1078
        		"-------------------------------------------------------------------------------Total search time for "
1068
                "-------------------------------------------------------------------------------Total search time for "
1079 1069
                + (outPutTime - startTime));
1080 1070
        MetaCatUtil.writeDebugToDelimiteredFile(" "+ (outPutTime - startTime), true);
1081 1071
    }
1082

  
1072
    
1083 1073
    /**
1084 1074
     * Create the xml query, execute it and display the results.
1085 1075
     *
......
1090 1080
     */
1091 1081
    private void handleQuery(PrintWriter out, Hashtable params,
1092 1082
            HttpServletResponse response, String user, String[] groups,
1093
            String sessionid)
1094
    {
1083
            String sessionid) {
1095 1084
        //create the query and run it
1096 1085
        String xmlquery = DBQuery.createSQuery(params);
1097 1086
        String[] queryArray = new String[1];
......
1105 1094
        logMetacat.warn("Total search time for action 'query': "
1106 1095
                + (outPutTime - startTime));
1107 1096
        MetaCatUtil.writeDebugToFile("---------------------------------------------------------------------------------"+
1108
        		"-------------------------------------------------------------------------------Total search time is "
1097
                "-------------------------------------------------------------------------------Total search time is "
1109 1098
                + (outPutTime - startTime));
1110 1099
        MetaCatUtil.writeDebugToDelimiteredFile(" "+ (outPutTime - startTime), true);
1111

  
1100
        
1112 1101
        //handleSQuery(out, params, response,user, groups, sessionid);
1113 1102
    }
1114

  
1103
    
1115 1104
    // END OF SQUERY & QUERY SECTION
1116

  
1105
    
1117 1106
    //Exoport section
1118 1107
    /**
1119 1108
     * Handle the "export" request of data package from Metacat in zip format
......
1125 1114
     */
1126 1115
    private void handleExportAction(Hashtable params,
1127 1116
            HttpServletResponse response,
1128
            String user, String[] groups, String passWord)
1129
    {
1117
            String user, String[] groups, String passWord) {
1130 1118
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
1131 1119
        // Output stream
1132 1120
        ServletOutputStream out = null;
1133 1121
        // Zip output stream
1134 1122
        ZipOutputStream zOut = null;
1135 1123
        DBQuery queryObj = null;
1136

  
1124
        
1137 1125
        String[] docs = new String[10];
1138 1126
        String docId = "";
1139

  
1127
        
1140 1128
        try {
1141 1129
            // read the params
1142 1130
            if (params.containsKey("docid")) {
......
1163 1151
            // Get output stream
1164 1152
            out = response.getOutputStream();
1165 1153
            response.setContentType("application/zip"); //MIME type
1166
            response.setHeader("Content-Disposition", 
1167
            		"attachment; filename=" 
1168
            		+ docId + ".zip"); // Set the name of the zip file
1169
            		
1154
            response.setHeader("Content-Disposition",
1155
                    "attachment; filename="
1156
                    + docId + ".zip"); // Set the name of the zip file
1157
            
1170 1158
            zOut = new ZipOutputStream(out);
1171 1159
            zOut = queryObj
1172 1160
                    .getZippedPackage(docId, out, user, groups, passWord);
1173 1161
            zOut.finish(); //terminate the zip file
1174 1162
            zOut.close(); //close the zip stream
1175

  
1163
            
1176 1164
        } catch (Exception e) {
1177 1165
            try {
1178 1166
                response.setContentType("text/xml"); //MIME type
......
1197 1185
                        + "in MetacatServlet.handleExportAction: "
1198 1186
                        + ioe.getMessage());
1199 1187
            }
1200

  
1188
            
1201 1189
            logMetacat.error(
1202 1190
                    "Error in MetacatServlet.handleExportAction: "
1203
                            + e.getMessage());
1191
                    + e.getMessage());
1204 1192
            e.printStackTrace(System.out);
1205

  
1193
            
1206 1194
        }
1207

  
1195
        
1208 1196
    }
1209

  
1197
    
1210 1198
    /**
1211 1199
     * In eml2 document, the xml can have inline data and data was stripped off
1212 1200
     * and store in file system. This action can be used to read inline data
......
1219 1207
     */
1220 1208
    private void handleReadInlineDataAction(Hashtable params,
1221 1209
            HttpServletRequest request, HttpServletResponse response,
1222
            String user, String passWord, String[] groups)
1223
    {
1210
            String user, String passWord, String[] groups) {
1224 1211
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
1225 1212
        String[] docs = new String[10];
1226 1213
        String inlineDataId = null;
1227 1214
        String docId = "";
1228 1215
        ServletOutputStream out = null;
1229

  
1216
        
1230 1217
        try {
1231 1218
            // read the params
1232 1219
            if (params.containsKey("inlinedataid")) {
......
1237 1224
            // Make sure the client specify docid
1238 1225
            if (inlineDataId == null || inlineDataId.equals("")) {
1239 1226
                throw new Exception("You didn't specify requested inlinedataid"); }
1240

  
1227
            
1241 1228
            // check for permission
1242 1229
            docId = MetaCatUtil
1243 1230
                    .getDocIdWithoutRevFromInlineDataID(inlineDataId);
1244 1231
            PermissionController controller = new PermissionController(docId);
1245 1232
            // check top level read permission
1246 1233
            if (!controller.hasPermission(user, groups,
1247
                    AccessControlInterface.READSTRING))
1248
            {
1234
                    AccessControlInterface.READSTRING)) {
1249 1235
                throw new Exception("User " + user
1250 1236
                        + " doesn't have permission " + " to read document "
1251 1237
                        + docId);
1252
            }
1253
            else
1254
            {
1255
              //check data access level
1256
              try
1257
              {
1258
                Hashtable unReadableInlineDataList =
1259
                    PermissionController.getUnReadableInlineDataIdList(docId,
1260
                    user, groups, false);
1261
                if (unReadableInlineDataList.containsValue(
1262
                          MetaCatUtil.getInlineDataIdWithoutRev(inlineDataId)))
1263
                {
1264
                  throw new Exception("User " + user
1265
                       + " doesn't have permission " + " to read inlinedata "
1266
                       + inlineDataId);
1267

  
1268
                }//if
1269
              }//try
1270
              catch (Exception e)
1271
              {
1272
                throw e;
1273
              }//catch
1238
            } else {
1239
                //check data access level
1240
                try {
1241
                    Hashtable unReadableInlineDataList =
1242
                            PermissionController.getUnReadableInlineDataIdList(docId,
1243
                            user, groups, false);
1244
                    if (unReadableInlineDataList.containsValue(
1245
                            MetaCatUtil.getInlineDataIdWithoutRev(inlineDataId))) {
1246
                        throw new Exception("User " + user
1247
                                + " doesn't have permission " + " to read inlinedata "
1248
                                + inlineDataId);
1249
                        
1250
                    }//if
1251
                }//try
1252
                catch (Exception e) {
1253
                    throw e;
1254
                }//catch
1274 1255
            }//else
1275

  
1256
            
1276 1257
            // Get output stream
1277 1258
            out = response.getOutputStream();
1278 1259
            // read the inline data from the file
......
1286 1267
                bytes = input.read(buffer);
1287 1268
            }
1288 1269
            out.close();
1289

  
1270
            
1290 1271
            EventLog.getInstance().log(request.getRemoteAddr(), user,
1291 1272
                    inlineDataId, "readinlinedata");
1292 1273
        } catch (Exception e) {
......
1315 1296
            }
1316 1297
            logMetacat.error(
1317 1298
                    "Error in MetacatServlet.handleReadInlineDataAction: "
1318
                            + e.getMessage());
1299
                    + e.getMessage());
1319 1300
        }
1320 1301
    }
1321

  
1302
    
1322 1303
    /*
1323 1304
     * Get the nodeid from xml_nodes for the inlinedataid
1324 1305
     */
1325 1306
    private long getInlineDataNodeId(String inLineDataId, String docId)
1326
            throws SQLException
1327
    {
1307
    throws SQLException {
1328 1308
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
1329 1309
        long nodeId = 0;
1330 1310
        String INLINE = "inline";
......
1336 1316
                + "AND nodetype='TEXT' AND parentnodeid IN "
1337 1317
                + "(SELECT nodeid FROM xml_nodes WHERE docid=? AND "
1338 1318
                + "nodetype='ELEMENT' AND nodename='" + INLINE + "')";
1339

  
1319
        
1340 1320
        try {
1341 1321
            //check out DBConnection
1342 1322
            conn = DBConnectionPool
1343 1323
                    .getDBConnection("AccessControlList.isAllowFirst");
1344 1324
            serialNumber = conn.getCheckOutSerialNumber();
1345

  
1325
            
1346 1326
            pStmt = conn.prepareStatement(sql);
1347 1327
            //bind value
1348 1328
            pStmt.setString(1, docId);//docid
......
1356 1336
            if (hasRow) {
1357 1337
                nodeId = rs.getLong(1);
1358 1338
            }//if
1359

  
1339
            
1360 1340
        } catch (SQLException e) {
1361 1341
            throw e;
1362 1342
        } finally {
......
1370 1350
                + " is: " + nodeId);
1371 1351
        return nodeId;
1372 1352
    }
1373

  
1353
    
1374 1354
    /**
1375 1355
     * Handle the "read" request of metadata/data files from Metacat or any
1376 1356
     * files from Internet; transformed metadata XML document into HTML
......
1384 1364
     */
1385 1365
    private void handleReadAction(Hashtable params, HttpServletRequest request,
1386 1366
            HttpServletResponse response, String user, String passWord,
1387
            String[] groups)
1388
    {
1367
            String[] groups) {
1389 1368
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
1390 1369
        ServletOutputStream out = null;
1391 1370
        ZipOutputStream zout = null;
1392 1371
        PrintWriter pw = null;
1393 1372
        boolean zip = false;
1394 1373
        boolean withInlineData = true;
1395

  
1374
        
1396 1375
        try {
1397 1376
            String[] docs = new String[0];
1398 1377
            String docid = "";
1399 1378
            String qformat = "";
1400 1379
            String abstrpath = null;
1401

  
1380
            
1402 1381
            // read the params
1403 1382
            if (params.containsKey("docid")) {
1404 1383
                docs = (String[]) params.get("docid");
......
1409 1388
            // the param for only metadata (eml)
1410 1389
            // we don't support read a eml document without inline data now.
1411 1390
            /*if (params.containsKey("inlinedata")) {
1412

  
1391
             
1413 1392
                String inlineData = ((String[]) params.get("inlinedata"))[0];
1414 1393
                if (inlineData.equalsIgnoreCase("false")) {
1415 1394
                    withInlineData = false;
......
1424 1403
            // go through the list of docs to read
1425 1404
            for (int i = 0; i < docs.length; i++) {
1426 1405
                try {
1427

  
1406
                    
1428 1407
                    URL murl = new URL(docs[i]);
1429 1408
                    Hashtable murlQueryStr = MetaCatUtil.parseQuery(
1430 1409
                            murl.getQuery());
......
1440 1419
                                    abstrpath, user, groups, zip, zout,
1441 1420
                                    withInlineData, params);
1442 1421
                        }
1443

  
1422
                        
1444 1423
                        // case docid="http://.../filename"
1445 1424
                    } else {
1446 1425
                        docid = docs[i];
......
1450 1429
                            readFromURLConnection(response, docid);
1451 1430
                        }
1452 1431
                    }
1453

  
1432
                    
1454 1433
                } catch (MalformedURLException mue) {
1455 1434
                    docid = docs[i];
1456 1435
                    if (zip) {
......
1462 1441
                    }
1463 1442
                }
1464 1443
            }
1465

  
1444
            
1466 1445
            if (zip) {
1467 1446
                zout.finish(); //terminate the zip file
1468 1447
                zout.close(); //close the zip stream
1469 1448
            }
1470

  
1449
            
1471 1450
        } catch (McdbDocNotFoundException notFoundE) {
1472 1451
            // To handle doc not found exception
1473 1452
            // the docid which didn't be found
......
1487 1466
                if (out != null) {
1488 1467
                    out.close();
1489 1468
                }
1490

  
1469
                
1491 1470
            } catch (Exception exc) {
1492 1471
                logMetacat.error(
1493 1472
                        "Erorr in MetacatServlet.hanldReadAction: "
1494
                                + exc.getMessage());
1473
                        + exc.getMessage());
1495 1474
                try {
1496 1475
                    if (out != null) {
1497 1476
                        response.setContentType("text/xml");
......
1503 1482
                        pw.println("</error>");
1504 1483
                        pw.close();
1505 1484
                        out.close();
1506

  
1485
                        
1507 1486
                    } else {
1508 1487
                        response.setContentType("text/xml"); //MIME type
1509 1488
                        // Send back error message if out = null
......
1529 1508
            }
1530 1509
        } catch (Exception e) {
1531 1510
            try {
1532

  
1511
                
1533 1512
                if (out != null) {
1534 1513
                    response.setContentType("text/xml"); //MIME type
1535 1514
                    pw = new PrintWriter(out);
......
1550 1529
                    pw.println(e.getMessage());
1551 1530
                    pw.println("</error>");
1552 1531
                    pw.close();
1553

  
1532
                    
1554 1533
                }
1555 1534
                // Close zip output stream
1556 1535
                if (zout != null) {
1557 1536
                    zout.close();
1558 1537
                }
1559

  
1538
                
1560 1539
            } catch (IOException ioe) {
1561 1540
                logMetacat.error("Problem with the servlet output "
1562 1541
                        + "in MetacatServlet.handleReadAction: "
1563 1542
                        + ioe.getMessage());
1564 1543
                ioe.printStackTrace(System.out);
1565

  
1544
                
1566 1545
            }
1567

  
1546
            
1568 1547
            logMetacat.error(
1569 1548
                    "Error in MetacatServlet.handleReadAction: "
1570
                            + e.getMessage());
1549
                    + e.getMessage());
1571 1550
            //e.printStackTrace(System.out);
1572 1551
        }
1573 1552
    }
1574

  
1553
    
1575 1554
    /** read metadata or data from Metacat
1576 1555
     */
1577 1556
    private void readFromMetacat(HttpServletRequest request,
......
1579 1558
            String abstrpath, String user, String[] groups, boolean zip,
1580 1559
            ZipOutputStream zout, boolean withInlineData, Hashtable params)
1581 1560
            throws ClassNotFoundException, IOException, SQLException,
1582
            McdbException, Exception
1583
    {
1561
            McdbException, Exception {
1584 1562
        Logger logMetacat = Logger.getLogger(MetaCatServlet.class);
1585 1563
        try {
1586 1564
            
......
1591 1569
            // seperator here, if only one, we will append the rev in xml_documents
1592 1570
            // to the id.
1593 1571
            docid = appendRev(docid);
1594
         
1572
            
1595 1573
            DocumentImpl doc = new DocumentImpl(docid);
1596

  
1574
            
1597 1575
            //check the permission for read
1598 1576
            if (!DocumentImpl.hasReadPermission(user, groups, docid)) {
1599 1577
                Exception e = new Exception("User " + user
1600 1578
                        + " does not have permission"
1601 1579
                        + " to read the document with the docid " + docid);
1602

  
1580
                
1603 1581
                throw e;
1604 1582
            }
1605

  
1583
            
1606 1584
            if (doc.getRootNodeID() == 0) {
1607 1585
                // this is data file
1608 1586
                String filepath = MetaCatUtil.getOption("datafilepath");
......
1612 1590
                String filename = filepath + docid;
1613 1591
                FileInputStream fin = null;
1614 1592
                fin = new FileInputStream(filename);
1615

  
1593
                
1616 1594
                //MIME type
1617 1595
                String contentType = getServletContext().getMimeType(filename);
1618 1596
                if (contentType == null) {
......
1622 1600
                    logMetacat.info("Final contenttype is: "
1623 1601
                            + contentType);
1624 1602
                }
1625

  
1603
                
1626 1604
                response.setContentType(contentType);
1627 1605
                // if we decide to use "application/octet-stream" for all data
1628 1606
                // returns
1629 1607
                // response.setContentType("application/octet-stream");
1630

  
1631
                // Set the name of the data file to the entity name plus docid, 
1608
                
1609
                // Set the name of the data file to the entity name plus docid,
1632 1610
                // or if that is unavailable, use the docid alone
1633 1611
                String docname = doc.getDocname();
1634 1612
                if (docname == null || docname.equals("")) {
......
1636 1614
                } else {
1637 1615
                    docname = docid + "-" + docname;
1638 1616
                }
1639
                response.setHeader("Content-Disposition", 
1617
                response.setHeader("Content-Disposition",
1640 1618
                        "attachment; filename=" + docname);
1641 1619
                
1642 1620
                try {
......
1650 1628
                } finally {
1651 1629
                    if (fin != null) fin.close();
1652 1630
                }
1653

  
1631
                
1654 1632
            } else {
1655 1633
                // this is metadata doc
1656 1634
                if (qformat.equals("xml") || qformat.equals("")) {
......
1658 1636
                    // by default the document should be returned in xml format
1659 1637
                    // set content type first
1660 1638
                    response.setContentType("text/xml"); //MIME type
1661
                    response.setHeader("Content-Disposition", 
1639
                    response.setHeader("Content-Disposition",
1662 1640
                            "attachment; filename=" + docid + ".xml");
1663 1641
                    PrintWriter out = response.getWriter();
1664 1642
                    doc.toXml(out, user, groups, withInlineData);
1665 1643
                } else {
1644
                    //*** This is a metadata doc, to be returned in a skin/custom format.
1645
                    
1646
                    //*** Add param to indicate if public has read access or not.
1647
                    if (!user.equals("public")) {
1648
                        if (DocumentImpl.hasReadPermission("public", null, docid))
1649
                            params.put("publicRead", new String[] {"true"});
1650
                        else
1651
                            params.put("publicRead", new String[] {"false"});
1652
                    }
1653
                    
1666 1654
                    response.setContentType("text/html"); //MIME type
1667 1655
                    PrintWriter out = response.getWriter();
1668

  
1656
                    
1669 1657
                    // Look up the document type
1670 1658
                    String doctype = doc.getDoctype();
1671 1659
                    // Transform the document to the new doctype
......
1674 1662
                            withInlineData), doctype, "-//W3C//HTML//EN",
1675 1663
                            qformat, out, params);
1676 1664
                }
1677

  
1665
                
1678 1666
            }
1679 1667
            EventLog.getInstance().log(request.getRemoteAddr(), user,
1680 1668
                    docid, "read");
......
1682 1670
            throw except;
1683 1671
        }
1684 1672
    }
1685

  
1673
    
1686 1674
    /**
1687 1675
     * read data from URLConnection
1688 1676
     */
1689 1677
    private void readFromURLConnection(HttpServletResponse response,
1690
            String docid) throws IOException, MalformedURLException
1691
    {
1678
            String docid) throws IOException, MalformedURLException {
1692 1679
        ServletOutputStream out = response.getOutputStream();
1693 1680
        String contentType = getServletContext().getMimeType(docid); //MIME
1694
                                                                     // type
1681
        // type
1695 1682
        if (contentType == null) {
1696 1683
            if (docid.endsWith(".xml")) {
1697 1684
                contentType = "text/xml";
......
1715 1702
        response.setContentType(contentType);
1716 1703
        // if we decide to use "application/octet-stream" for all data returns
1717 1704
        // response.setContentType("application/octet-stream");
1718

  
1705
        
1719 1706
        // this is http url
1720 1707
        URL url = new URL(docid);
1721 1708
        BufferedInputStream bis = null;
......
1730 1717
        } finally {
1731 1718
            if (bis != null) bis.close();
1732 1719
        }
1733

  
1720
        
1734 1721
    }
1735

  
1722
    
1736 1723
    /**
1737 1724
     * read file/doc and write to ZipOutputStream
1738 1725
     *
......
1749 1736
    private void addDocToZip(HttpServletRequest request, String docid,
1750 1737
            ZipOutputStream zout, String user, String[] groups) throws
1751 1738
            ClassNotFoundException, IOException, SQLException, McdbException,
1752
            Exception
1753
    {
1739
            Exception {
1754 1740
        byte[] bytestring = null;
1755 1741
        ZipEntry zentry = null;
1756

  
1742
        
1757 1743
        try {
1758 1744
            URL url = new URL(docid);
1759

  
1745
            
1760 1746
            // this http url; read from URLConnection; add to zip
1761 1747
            zentry = new ZipEntry(docid);
1762 1748
            zout.putNextEntry(zentry);
......
1773 1759
                if (bis != null) bis.close();
1774 1760
            }
1775 1761
            zout.closeEntry();
1776

  
1762
            
1777 1763
        } catch (MalformedURLException mue) {
1778

  
1764
            
1779 1765
            // this is metacat doc (data file or metadata doc)
1780 1766
            try {
1781 1767
                DocumentImpl doc = new DocumentImpl(docid);
1782

  
1768
                
1783 1769
                //check the permission for read
1784 1770
                if (!DocumentImpl.hasReadPermission(user, groups, docid)) {
1785 1771
                    Exception e = new Exception("User " + user
......
1788 1774
                            + docid);
1789 1775
                    throw e;
1790 1776
                }
1791

  
1777
                
1792 1778
                if (doc.getRootNodeID() == 0) {
1793 1779
                    // this is data file; add file to zip
1794 1780
                    String filepath = MetaCatUtil.getOption("datafilepath");
......
1799 1785
                    FileInputStream fin = null;
1800 1786
                    fin = new FileInputStream(filename);
1801 1787
                    try {
1802

  
1788
                        
1803 1789
                        zentry = new ZipEntry(docid);
1804 1790
                        zout.putNextEntry(zentry);
1805 1791
                        byte[] buf = new byte[4 * 1024]; // 4K buffer
......
1812 1798
                        if (fin != null) fin.close();
1813 1799
                    }
1814 1800
                    zout.closeEntry();
1815

  
1801
                    
1816 1802
                } else {
1817 1803
                    // this is metadata doc; add doc to zip
1818 1804
                    bytestring = doc.toString().getBytes();
......
1829 1815
            }
... This diff was truncated because it exceeds the maximum size that can be displayed.

Also available in: Unified diff