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

org.simpleframework.http.resource.Index Maven / Gradle / Ivy

Go to download

Simple is a high performance asynchronous HTTP server for Java

There is a newer version: 5.1.6
Show newest version
/*
 * Index.java December 2005
 *
 * Copyright (C) 2005, Niall Gallagher 
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General 
 * Public License along with this library; if not, write to the 
 * Free Software Foundation, Inc., 59 Temple Place, Suite 330, 
 * Boston, MA  02111-1307  USA
 */
 
package org.simpleframework.http.resource;

import java.io.File;

import org.simpleframework.http.Path;

/**
 * The Index object is used to represent the properties 
 * a URI can contain. This is used so that properties relating to a
 * file can be quickly extracted from an Indexer. This
 * will contain all necessary meta data for a file or resource. With
 * this the File reference to a resource as well as the
 * locale, MIME type, name  and other such data can be accessed.
 * 
 * @author Niall Gallagher
 *
 * @see org.simpleframework.http.resource.Indexer
 */ 
public interface Index {

   /**
    * This allows the name for this object to be acquired. The
    * name usually refers to the last entry in the path. So if
    * the index target path was "/usr/bin/" the name is "bin".
    *
    * @return this returns the name of this index target
    */         
   public String getName();
   
   /**
    * This allows the MIME type of this Index to
    * be acquired. The MIME type of a file is retrieved by the
    * Context.getContentType method for a specific
    * request URI. This should have a value and perhaps some
    * parameters like the charset, "text/html; charset=UTF-8".
    *
    * @return the MIME type this object has been set to
    */    
   public String getContentType();

   /**
    * This is used to get the path that this object refers to. 
    * This should be the fully qualified normalized path. This
    * refers to the OS system specific path that this represents.
    *
    * @return this returns the OS specific path for the target
    */    
   public String getRealPath();

   /**
    * This is used to acquire the normalized URI style path for
    * the index target. This allows the path to be used within
    * the Mapper and other such objects that need
    * a normalized URI style path to resolve resources.
    *
    * @return this returns the normalized path for the target
    */ 
   public String getRequestPath();

   /**
    * This is used to acquire the File directory
    * for the index target. This is typically rooted at a
    * base path, for instance the Context root
    * is typically used. This allows resources within the 
    * same directory to be acquired easily.
    *
    * @return this returns the OS file for the directory
    */ 
   public File getDirectory();
   
   /**
    * This is used to acquire the File reference
    * for the index target. This is typically rooted at a
    * base path, for instance the Context root
    * is typically used. This allows the file to be opened,
    * deleted, or read should the need arise in a service.
    *
    * @return this returns the OS file for the resource
    */ 
   public File getFile();

   /**
    * This is used to acquire the Path object that 
    * exposes various parts of the URI path. This can be used 
    * to extract the individual path segments as strings as 
    * well as the file extension and various other details.
    *
    * @return this returns a path object with various details
    */ 
   public Path getPath();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy