001 /* 002 * Copyright © 2008, 2009 Pedro Agulló Soliveres. 003 * 004 * This file is part of DirectJNgine. 005 * 006 * DirectJNgine is free software: you can redistribute it and/or modify 007 * it under the terms of the GNU General Public License as published by 008 * the Free Software Foundation, either version 3 of the License. 009 * 010 * DirectJNgine is distributed in the hope that it will be useful, 011 * but WITHOUT ANY WARRANTY; without even the implied warranty of 012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 013 * GNU General Public License for more details. 014 * 015 * You should have received a copy of the GNU General Public License 016 * along with DirectJNgine. If not, see <http://www.gnu.org/licenses/>. 017 * 018 * This software uses the ExtJs library (http://extjs.com), which is 019 * distributed under the GPL v3 license (see http://extjs.com/license). 020 */ 021 022 package com.softwarementors.extjs.djn.router; 023 024 import java.io.IOException; 025 import java.io.Reader; 026 import java.io.Writer; 027 import java.util.HashMap; 028 import java.util.Map; 029 030 import org.apache.commons.fileupload.FileItem; 031 import org.apache.commons.io.IOUtils; 032 import org.apache.log4j.Logger; 033 034 import com.softwarementors.extjs.djn.config.Registry; 035 036 public class SimpleFormPostRequestProcessor extends FormPostRequestProcessorBase { 037 038 private static final Logger logger = Logger.getLogger(SimpleFormPostRequestProcessor.class); 039 040 public SimpleFormPostRequestProcessor(Registry registry, Dispatcher dispatcher, boolean debugMode) { 041 super( registry, dispatcher, debugMode); 042 } 043 044 public void process(Reader reader, Writer writer) throws IOException { 045 String requestString = IOUtils.toString(reader); 046 logger.debug( "request=>" + requestString ); 047 Map<String, String> formParameters; 048 formParameters = getDecodedRequestParameters(requestString); 049 String result = process(formParameters, new HashMap<String,FileItem>()); 050 writer.write( result ); 051 logger.debug( "response=>" + result ); 052 } 053 054 }