/*******************************************************************************
* Copyright (c) 2009 MATERNA Information & Communications. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html. For further
* project-related information visit http://www.ws4d.org. The most recent
* version of the JMEDS framework can be obtained from
* http://sourceforge.net/projects/ws4d-javame.
******************************************************************************/
package org.ws4d.java.communication.protocol.http.server;
import java.io.IOException;
import java.io.InputStream;
import org.ws4d.java.communication.ProtocolData;
import org.ws4d.java.communication.monitor.MonitoringContext;
import org.ws4d.java.communication.protocol.http.HTTPResponse;
import org.ws4d.java.communication.protocol.http.header.HTTPRequestHeader;
import org.ws4d.java.types.URI;
/**
* HTTP handler interface.
* <p>
* A HTTP handler can be registered to a HTTP server and will handle incoming
* HTTP requests.
* </p>
* <p>
* A HTTP request is represented by {@link DefaultHTTPExchange}.
* </p>
*/
public interface HTTPRequestHandler {
/**
* Handles a HTTP request.
*
* @param exchange the HTTP request represented by the
* {@link DefaultHTTPExchange}.
* @param protocolData transport/addressing related information attached to
* the request
* @throws IOException
*/
public HTTPResponse handle(URI request, HTTPRequestHeader header, InputStream body, ProtocolData protocolData, MonitoringContext context) throws IOException;
}