org.xsocket.connection.http.server.HttpProtocolAdapter Maven / Gradle / Ivy
/*
* Copyright (c) xsocket.org, 2006 - 2008. All rights reserved.
*
* This library 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 2.1 of the License, or (at your option) any later version.
*
* This library 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 this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Please refer to the LGPL license at: http://www.gnu.org/copyleft/lesser.txt
* The latest copy of this software may be found on http://www.xsocket.org/
*/
package org.xsocket.connection.http.server;
import java.io.IOException;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.xsocket.Execution;
import org.xsocket.ILifeCycle;
import org.xsocket.Resource;
import org.xsocket.connection.IConnectHandler;
import org.xsocket.connection.IConnectionScoped;
import org.xsocket.connection.INonBlockingConnection;
import org.xsocket.connection.IServer;
import org.xsocket.connection.http.IHttpConnectHandler;
import org.xsocket.connection.http.IHttpDisconnectHandler;
import org.xsocket.connection.http.IHttpHandler;
import org.xsocket.connection.http.server.ServerUtils.HttpHandlerInfo;
/**
* The http protocol adapter. The protocol adapter implements the {@link IConnectHandler} interface, and
* "maps" each incoming connection into a {@link HttpServerConnection}.
* HttpProtcol adapter is required, if the {@link HttpServer} will not be used.
*
* Example:
*
*
* // establishing a http server based on a mutliplexed tcp connection
* // for multiplexex connections see http://xsocket.sourceforge.net/multiplexed/tutorial/V2/TutorialMultiplexed.htm
*
* IRequestHandler hdl = new MyRequestHandler();
* IConnectHandler httpAdapter = new HttpProtocolAdapter(hdl);
*
*
* IServer mutliplexedHttpServer = new Server(port, new MultiplexedProtocolAdapter(httpAdapter)));
* ConnectionUtils.start(mutliplexedHttpServer);
* ...
*
*
*
* @author grro
*/
@Execution(Execution.NONTHREADED)
public final class HttpProtocolAdapter implements IConnectHandler, ILifeCycle {
private static final Logger LOG = Logger.getLogger(HttpProtocolAdapter.class.getName());
@Resource
private IServer server = null;
private IHttpHandler handler = null;
private HttpHandlerInfo httpHandlerInfo = null;
private Integer requestTimeoutSec = null;
private boolean isCloseOnSendingError = false;
// keep alive support
private Integer maxTransactions = null;
// static {
// System.setProperty("org.xsocket.connection.dispatcher.unregisteredWriteAllowed", "true");
// }
/**
* constructor
*
* @param handler the handler (supported: {@link IHttpRequestHandler}, {@link IHttpRequestTimeoutHandler}, {@link IHttpConnectHandler}, {@link IHttpDisconnectHandler}, {@link ILifeCycle})
*/
public HttpProtocolAdapter(IHttpHandler handler) {
this.handler = handler;
this.httpHandlerInfo = ServerUtils.getHttpHandlerInfo(handler);
}
/**
* sets the message receive timeout
*
* @param request the message receive timeout
*/
public void setRequestTimeoutSec(int requesttimeout) {
this.requestTimeoutSec = requesttimeout;
}
/**
* returns the message request timeout
*
* @return the message request timeout
*/
public int getRequestTimeoutSec() {
return requestTimeoutSec;
}
/**
* set is if the server-side connection will closed, if an error message is sent
*
* @param isCloseOnSendingError if the connection will closed, if an error message is sent
*/
public void setCloseOnSendingError(boolean isCloseOnSendingError) {
this.isCloseOnSendingError = isCloseOnSendingError;
}
/**
* returns if the server-side connection will closed, if an error message will be sent
* @return true, if the connection will closed by sending an error message
*/
public boolean isCloseOnSendingError() {
return isCloseOnSendingError;
}
/**
* set the max transactions per connection. Setting this filed causes that
* a keep-alive response header will be added
*
* @param maxTransactions the max transactions
*/
public void setMaxTransactions(int maxTransactions) {
this.maxTransactions = maxTransactions;
}
/**
* {@inheritDoc}
*/
public Object getAdaptee() {
return handler;
}
/**
* {@inheritDoc}
*/
public void onInit() {
server.setStartUpLogMessage(server.getStartUpLogMessage() + "; http " + ServerUtils.getVersionInfo());
ServerUtils.injectServerField(handler, server);
ServerUtils.injectProtocolAdapter(handler, this);
if (httpHandlerInfo.isLifeCycle()) {
((ILifeCycle) handler).onInit();
}
}
/**
* {@inheritDoc}
*/
public void onDestroy() {
if (httpHandlerInfo.isLifeCycle()) {
try {
((ILifeCycle) handler).onDestroy();
} catch (IOException ioe) {
if (LOG.isLoggable(Level.FINE)) {
LOG.fine("exception occured by destroying " + handler + " " + ioe.toString());
}
}
}
}
/**
* {@inheritDoc}
*/
public boolean onConnect(INonBlockingConnection connection) throws IOException {
HttpServerConnection httpCon = null;
if (httpHandlerInfo.isConnectionScoped()) {
try {
IHttpRequestHandler handlerCopy = (IHttpRequestHandler) ((IConnectionScoped) handler).clone();
httpCon = new HttpServerConnection(connection, httpHandlerInfo, handlerCopy, isCloseOnSendingError);
} catch (CloneNotSupportedException clne) {
throw new RuntimeException("couldn't clone handler " + handler + " " + clne.toString());
}
} else {
httpCon = new HttpServerConnection(connection, httpHandlerInfo, handler, isCloseOnSendingError);
}
if (maxTransactions != null) {
httpCon.setMaxTransactions(maxTransactions);
}
if (requestTimeoutSec != null) {
httpCon.setRequestTimeoutSec(requestTimeoutSec);
}
return true;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy