/*
* FileUploadRequest.java
*
* Version: $Revision: 1.1 $
*
* Date: $Date: 2006/12/18 21:43:14 $
*
* Copyright (c) 2002-2005, Hewlett-Packard Company and Massachusetts
* Institute of Technology. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* - Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* - Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* - Neither the name of the Hewlett-Packard Company nor the name of the
* Massachusetts Institute of Technology nor the names of their
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
* USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*/
package org.ariadne_eu.utils;
import java.io.File;
import java.io.IOException;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
import org.ariadne.config.PropertiesManager;
import com.oreilly.servlet.MultipartRequest;
/**
* Based on the com.oreilly.servlet.MultipartWrapper object, this is an HTTP
* request wrapper for multi-part (MIME) POSTs. It uses DSpace configuration
* properties to determine the temporary directory to use and the maximum
* allowable upload size.
*
* @author Robert Tansley
* @version $Revision: 1.1 $
*/
public class FileUploadRequest extends HttpServletRequestWrapper
{
/** Multipart request */
private MultipartRequest mreq = null;
/** Original request */
private HttpServletRequest original = null;
/**
* Wraps a multipart request and extracts the files
*
* @param req
* the original request
*/
public FileUploadRequest(HttpServletRequest req) throws IOException
{
super(req);
original = req;
String tempDir = PropertiesManager.getInstance().getProperty("upload.temp.dir");
if (tempDir == null)
tempDir = "/tmp";
int maxSize = 536870912; //512Mb
mreq = new MultipartRequest(req, tempDir, maxSize, "UTF-8");
}
// Methods to replace HSR methods
public Enumeration getParameterNames()
{
return mreq.getParameterNames();
}
public String getParameter(String name)
{
return mreq.getParameter(name);
}
public String[] getParameterValues(String name)
{
return mreq.getParameterValues(name);
}
public Map getParameterMap()
{
Map map = new HashMap();
Enumeration eNum = getParameterNames();
while (eNum.hasMoreElements())
{
String name = (String) eNum.nextElement();
map.put(name, mreq.getParameterValues(name));
}
return map;
}
// Methods only in MultipartRequest
public Enumeration getFileNames()
{
return mreq.getFileNames();
}
public String getFilesystemName(String name)
{
return mreq.getFilesystemName(name);
}
public String getContentType(String name)
{
return mreq.getContentType(name);
}
public File getFile(String name)
{
return mreq.getFile(name);
}
/**
* Get back the original HTTP request object
*
* @return the original HTTP request
*/
public HttpServletRequest getOriginalRequest()
{
return original;
}
}