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    }