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.GlobalConfiguration;
035    import com.softwarementors.extjs.djn.config.Registry;
036    
037    public class SimpleFormPostRequestProcessor extends FormPostRequestProcessorBase {
038    
039      private static final Logger logger = Logger.getLogger(SimpleFormPostRequestProcessor.class);
040      
041      public SimpleFormPostRequestProcessor(Registry registry, Dispatcher dispatcher, GlobalConfiguration globalConfiguration) {
042        super( registry, dispatcher, globalConfiguration);
043      }
044    
045      public void process(Reader reader, Writer writer) throws IOException {
046        String requestString = IOUtils.toString(reader);
047        if( logger.isDebugEnabled() ) {
048          logger.debug( "Request data (SIMPLE FORM)=>" + requestString );
049        }
050        Map<String, String> formParameters;
051        formParameters = getDecodedRequestParameters(requestString);    
052        String result = process(formParameters, new HashMap<String,FileItem>());
053        writer.write( result );
054        if( logger.isDebugEnabled() ) {
055          logger.debug( "Response data (SIMPLE FORM)=>" + result );
056        }
057      }
058    
059    }