/*
* Copyright © 2008, 2012 Pedro Agulló Soliveres.
*
* This file is part of DirectJNgine.
*
* DirectJNgine 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, either version 3 of the License.
*
* Commercial use is permitted to the extent that the code/component(s)
* do NOT become part of another Open Source or Commercially developed
* licensed development library or toolkit without explicit permission.
*
* DirectJNgine 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 DirectJNgine. If not, see <http://www.gnu.org/licenses/>.
*
* This software uses the ExtJs library (http://extjs.com), which is
* distributed under the GPL v3 license (see http://extjs.com/license).
*/
package com.softwarementors.extjs.djn.router.processor.standard.form.simple;
import java.io.IOException;
import java.io.Reader;
import java.io.Writer;
import java.util.HashMap;
import java.util.Map;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.io.IOUtils;
import org.apache.log4j.Logger;
import com.softwarementors.extjs.djn.api.Registry;
import com.softwarementors.extjs.djn.config.GlobalConfiguration;
import com.softwarementors.extjs.djn.router.dispatcher.Dispatcher;
import com.softwarementors.extjs.djn.router.processor.RequestProcessorUtils;
import com.softwarementors.extjs.djn.router.processor.standard.form.FormPostRequestProcessorBase;
import edu.umd.cs.findbugs.annotations.NonNull;
public class SimpleFormPostRequestProcessor extends FormPostRequestProcessorBase {
@NonNull
private static final Logger logger = Logger.getLogger(SimpleFormPostRequestProcessor.class);
public SimpleFormPostRequestProcessor(Registry registry, Dispatcher dispatcher, GlobalConfiguration globalConfiguration) {
super( registry, dispatcher, globalConfiguration);
}
public void process(Reader reader, Writer writer) throws IOException {
String requestString = IOUtils.toString(reader);
if( logger.isDebugEnabled() ) {
logger.debug( "Request data (SIMPLE FORM)=>" + requestString );
}
Map<String, String> formParameters;
formParameters = RequestProcessorUtils.getDecodedRequestParameters(requestString);
String result = process(formParameters, new HashMap<String,FileItem>());
writer.write( result );
if( logger.isDebugEnabled() ) {
logger.debug( "ResponseData data (SIMPLE FORM)=>" + result );
}
}
}