All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.com.ibm.as400.util.html.FileListRenderer Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: FileListRenderer.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2001 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.util.html;

import com.ibm.as400.access.Trace;
import com.ibm.as400.access.IFSJavaFile;                    // $B4A
import com.ibm.as400.util.servlet.ListMetaData;             // $B4A
import com.ibm.as400.util.servlet.ListRowData;              // $B4A
import com.ibm.as400.util.servlet.RowMetaDataType;     // $B4A
import com.ibm.as400.util.servlet.RowDataException;     // $B4A

import java.io.File;
import java.text.Collator;                                 // $B4A
import java.util.Date;                                      // $B4A
import java.util.Vector;                                   // $B4A
import java.text.SimpleDateFormat;                  // $B4A
import java.beans.PropertyVetoException;        // $B4A
import javax.servlet.http.HttpServletRequest;


/**
*  The FileListRenderer class renders the name field for directories and files
*  in a FileListElement.
*  

* If the behavior of the default FileListRenderer is not desired, subclass * FileListRenderer and override the appropriate methods until the * FileListElement achieves the desired behavior. *

* Subclassing FileListRenderer will allow your servlet to include/exclude * or change the action of any directory or file in the FileListElement. * For example, if a servlet did not want users to see any *.exe files, * A subclass of FileListRenderer would be created and the new class * would override the getFileName() method to figure out if the File object * passed to it was a *.exe file, if it is, null could be returned, which * would indicate that the file should not be displayed. * *

Overriding the getRowData method will allow the addition * of columns in the row data and also enable the reordering of the * columns. * *

* This example creates an FileListElement object with a renderer: * *

*   // Create a FileListElement.
*  FileListElement fileList = new FileListElement(sys, httpservletrequest);
*  
*  // Set the renderer specific to this servlet, which extends
*  // FileListRenderer and overrides applicable methods.
*  fileList.setRenderer(new myFileListRenderer(request));
*  
**/ public class FileListRenderer implements java.io.Serializable { private String uri_; private String reqPath_; private StringBuffer sharePath_; // @B1A private StringBuffer shareName_; // @B1A private SimpleDateFormat formatter_ = new SimpleDateFormat("MM/dd/yyyy hh:mm:ss a"); // @B4A // Handles loading the appropriate resource bundle private static ResourceBundleLoader_h loader_; // @A5A //$B4A // The FileListElement default column headers. private static String name = loader_.getText("PROP_FLE_NAME_NAME"); // @A5A //$B4A private static String size = loader_.getText("PROP_FLE_NAME_SIZE"); // @A5A //$B4A private static String type = loader_.getText("PROP_FLE_NAME_TYPE"); // @A5A //$B4A private static String modified = loader_.getText("PROP_FLE_NAME_MODIFIED"); // @A5A //$B4A /** * Constructs a FileListRenderer with the specified request. * * @param request The Http servlet request. **/ public FileListRenderer(HttpServletRequest request) { if (request == null) throw new NullPointerException("request"); /* @B2A According to the JSDK, HttpServletRequest.getServletPath() should return the path to the servlet as a root relative path so that it can be used to generate self-referencing URLs. This is equivalent to the CGI environment variable SCRIPT_NAME. However, some webservers only return the servlet name preceded by a slash (/) when your appliation server has a path other than slash (/) configured. (Note that the only application server that can have slash (/) for a path is the default application server.) request.getServletPath(); should return: /servlet/name vs. /name What follows is a circumvention to accomplish the same thing. The following code strips the path information from the request URI. */ uri_ = request.getRequestURI(); // @B2A String servletPath = request.getServletPath(); // @B3A int i = uri_.indexOf(servletPath); // @B3A uri_ = uri_.substring(0, i + servletPath.length()); // @B3C reqPath_ = request.getPathInfo(); } /** * Constructs a FileListRenderer with the specified request, NetServer sharePath, * and the NetServer shareName. * * @param request The Http servlet request. * @param shareName The NetServer share name. * @param sharePath The NetServer share path. **/ public FileListRenderer(HttpServletRequest request, String shareName, String sharePath) { this(request); if (sharePath == null) // @B1A throw new NullPointerException("sharePath"); // @B1A if (shareName == null) // @B1A throw new NullPointerException("shareName"); // @B1A sharePath_ = new StringBuffer(sharePath); // @B1A shareName_ = new StringBuffer(shareName); // @B1A if (Trace.isTraceOn()) // @B1A { // @B1A Trace.log(Trace.INFORMATION, "Renderer sharePath: " + shareName_); // @B1A Trace.log(Trace.INFORMATION, "Renderer shareName: " + sharePath_); // @B1A } // @B1A } /** * Return the directory name string. A link to the calling servlet with the * directory included in the path info by default. If the directory should * not be added to the FileListElement, a null string should be returned. * * @param file The File. * * @return The directory name string. **/ public String getDirectoryName(File file) { if (file == null) throw new NullPointerException("file"); String name = file.getName(); StringBuffer buffer = new StringBuffer(""); buffer.append(name); buffer.append(""); return buffer.toString(); } /** * Return the file name string. The file name will be returned by default. * If the file should not be displayed in the FileListElement, a null string * should be returned. * * @param file The File. * * @return The file name string. **/ public String getFileName(File file) { if (file == null) throw new NullPointerException("file"); return file.getName(); } /** * Return the parent directory name string. A link to the calling servlet with the * parent directory included in the path info will be returned by default. If the * parent should not be display in the FileListElement, a null string should be returned. * * @param file The File. * * @return The parent name string. **/ public String getParentName(File file) { if (file == null) throw new NullPointerException("file"); String parent = file.getParent(); if (parent != null) // @A2A { if (sharePath_ != null) // @B1A { // @B1A try // @B1A { parent = shareName_.append(parent.substring(sharePath_.length(), parent.length())).toString(); // @B1A } // This exception will get thrown when the parent is the only directory in the // @B1A // path. Thus we know that we are at the beginning of the share. // @B1A catch (StringIndexOutOfBoundsException e) // @B1A { // @B1A // If the parent directory length is shorter than the share path // @B1A // then don't display the parent of the share. // @B1A if (parent.length() < sharePath_.length()) // @B1A return null; // @B1A } // @B1A } // @B1A // @B1A if (Trace.isTraceOn()) // @B1A Trace.log(Trace.INFORMATION, "Renderer parent: " + parent); // @B1A StringBuffer buffer = new StringBuffer("../ (Parent Directory)"); return buffer.toString(); } else // @A2A return null; // @A2A } // $B4A /** * Return the row data to be displayed in the FileListElement. * * @param file The File. * @param sort true if the elements are sorted; false otherwise. * The default is true. * @param collator The Collator. * * @return ListRowData The row data. * * @exception RowDataException If a row data error occurs. **/ public ListRowData getRowData(File file, boolean sort, Collator collator) throws RowDataException { // This method used to be in the FileListElement class but was moved into the // the rederer class so that the user could have more control over the columns // by being able to add, and reorder the columns (just to name a few). ListMetaData metaData = new ListMetaData(4); metaData.setColumnName(0, "Name"); metaData.setColumnLabel(0, name); metaData.setColumnType(0, RowMetaDataType.STRING_DATA_TYPE); metaData.setColumnName(1, "Size"); // @A3C metaData.setColumnLabel(1, size); // @A3C @A5C metaData.setColumnType(1, RowMetaDataType.INTEGER_DATA_TYPE); // @A3C metaData.setColumnName(2, "Type"); metaData.setColumnLabel(2, type); // @A5C metaData.setColumnType(2, RowMetaDataType.STRING_DATA_TYPE); metaData.setColumnName(3, "Modified"); // @A3C metaData.setColumnLabel(3, modified); // @A3C @A5C metaData.setColumnType(3, RowMetaDataType.STRING_DATA_TYPE); // @A3C ListRowData rowData = new ListRowData(); try { rowData.setMetaData(metaData); } catch (PropertyVetoException e) { /* Ignore */ } // Get the string to display from the renderer. This allows // @A4A // the servlet more flexibility as to which files to display // @A4A // and how to display them. // @A4A String parentName = getParentName(file); // @A4A $B4C if (parentName != null) // @A4A { Object[] row = new Object[4]; row[0] = parentName.replace('\\','/'); // @A4C row[1] = ""; row[2] = ""; row[3] = ""; rowData.addRow(row); } File[] dirList = null; // @B3A File[] fileList = null; // @B3A if (file instanceof IFSJavaFile) //$A1A { // @B3A // When we are using IFSJavaFile objects, we can use // the listFiles() method becuase it is not dependant on any // JDK1.2 code. Using listFiles() will also cache information // like if it is a directory, so we don't flow another call to the // system to find that out. We can then build both the // directory and file list at the same time. File[] filesAndDirs = ((IFSJavaFile) file).listFiles(); // @B3A // The vector of directories. Vector dv = new Vector(); // @B3A // The vector of files. Vector fv = new Vector(); // @B3A for (int i=0; i




© 2015 - 2025 Weber Informatics LLC | Privacy Policy