Forwarded HttpParser.EventHandler methods from the inner class to the outer class (AbstractHttpConnection itself)
to allow other protocols such as SPDY to fake the emission of HTTP events by calling the EventHandler methods.
This commit is contained in:
parent
9781a734bd
commit
b0119e4d62
|
@ -117,6 +117,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
|
||||
private int _version = UNKNOWN;
|
||||
|
||||
private String _charset;
|
||||
private boolean _expect = false;
|
||||
private boolean _expect100Continue = false;
|
||||
private boolean _expect102Processing = false;
|
||||
|
@ -137,9 +138,6 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/** Constructor
|
||||
*
|
||||
*/
|
||||
public AbstractHttpConnection(Connector connector, EndPoint endpoint, Server server)
|
||||
{
|
||||
super(endpoint);
|
||||
|
@ -250,28 +248,26 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
|
||||
/* ------------------------------------------------------------ */
|
||||
/**
|
||||
* @return The result of calling {@link #getConnector}.{@link Connector#isConfidential(Request) isCondidential}(request), or false
|
||||
* if there is no connector.
|
||||
* Find out if the request supports CONFIDENTIAL security.
|
||||
* @param request the incoming HTTP request
|
||||
* @return the result of calling {@link Connector#isConfidential(Request)}, or false
|
||||
* if there is no connector
|
||||
*/
|
||||
public boolean isConfidential(Request request)
|
||||
{
|
||||
if (_connector!=null)
|
||||
return _connector.isConfidential(request);
|
||||
return false;
|
||||
return _connector != null && _connector.isConfidential(request);
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/**
|
||||
* Find out if the request is INTEGRAL security.
|
||||
* @param request
|
||||
* @return <code>true</code> if there is a {@link #getConnector() connector} and it considers <code>request</code>
|
||||
* to be {@link Connector#isIntegral(Request) integral}
|
||||
* Find out if the request supports INTEGRAL security.
|
||||
* @param request the incoming HTTP request
|
||||
* @return the result of calling {@link Connector#isIntegral(Request)}, or false
|
||||
* if there is no connector
|
||||
*/
|
||||
public boolean isIntegral(Request request)
|
||||
{
|
||||
if (_connector!=null)
|
||||
return _connector.isIntegral(request);
|
||||
return false;
|
||||
return _connector != null && _connector.isIntegral(request);
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
|
@ -311,6 +307,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
*
|
||||
* @return The input stream for this connection.
|
||||
* The stream will be created if it does not already exist.
|
||||
* @throws IOException if the input stream cannot be retrieved
|
||||
*/
|
||||
public ServletInputStream getInputStream() throws IOException
|
||||
{
|
||||
|
@ -346,6 +343,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
|
||||
/* ------------------------------------------------------------ */
|
||||
/**
|
||||
* @param encoding the PrintWriter encoding
|
||||
* @return A {@link PrintWriter} wrapping the {@link #getOutputStream output stream}. The writer is created if it
|
||||
* does not already exist.
|
||||
*/
|
||||
|
@ -556,10 +554,6 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
_generator.setPersistent(false);
|
||||
_generator.completeHeader(_responseFields, last);
|
||||
}
|
||||
catch(IOException io)
|
||||
{
|
||||
throw io;
|
||||
}
|
||||
catch(RuntimeException e)
|
||||
{
|
||||
LOG.warn("header full: " + e);
|
||||
|
@ -587,10 +581,6 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
{
|
||||
_generator.completeHeader(_responseFields, Generator.LAST);
|
||||
}
|
||||
catch(IOException io)
|
||||
{
|
||||
throw io;
|
||||
}
|
||||
catch(RuntimeException e)
|
||||
{
|
||||
LOG.warn("header full: "+e);
|
||||
|
@ -701,20 +691,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
_requests);
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/* ------------------------------------------------------------ */
|
||||
/* ------------------------------------------------------------ */
|
||||
private class RequestHandler extends HttpParser.EventHandler
|
||||
{
|
||||
private String _charset;
|
||||
|
||||
/*
|
||||
*
|
||||
* @see org.eclipse.jetty.server.server.HttpParser.EventHandler#startRequest(org.eclipse.io.Buffer,
|
||||
* org.eclipse.io.Buffer, org.eclipse.io.Buffer)
|
||||
*/
|
||||
@Override
|
||||
public void startRequest(Buffer method, Buffer uri, Buffer version) throws IOException
|
||||
protected void startRequest(Buffer method, Buffer uri, Buffer version) throws IOException
|
||||
{
|
||||
uri=uri.asImmutableBuffer();
|
||||
|
||||
|
@ -773,11 +750,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* @see org.eclipse.jetty.server.server.HttpParser.EventHandler#parsedHeaderValue(org.eclipse.io.Buffer)
|
||||
*/
|
||||
@Override
|
||||
public void parsedHeader(Buffer name, Buffer value)
|
||||
protected void parsedHeader(Buffer name, Buffer value) throws IOException
|
||||
{
|
||||
int ho = HttpHeaders.CACHE.getOrdinal(name);
|
||||
switch (ho)
|
||||
|
@ -838,11 +811,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
_requestFields.add(name, value);
|
||||
}
|
||||
|
||||
/*
|
||||
* @see org.eclipse.jetty.server.server.HttpParser.EventHandler#headerComplete()
|
||||
*/
|
||||
@Override
|
||||
public void headerComplete() throws IOException
|
||||
protected void headerComplete() throws IOException
|
||||
{
|
||||
_requests++;
|
||||
_generator.setVersion(_version);
|
||||
|
@ -854,7 +823,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
_generator.setHead(_head);
|
||||
if (_parser.isPersistent())
|
||||
{
|
||||
_responseFields.add(HttpHeaders.CONNECTION_BUFFER,HttpHeaderValues.KEEP_ALIVE_BUFFER);
|
||||
_responseFields.add(HttpHeaders.CONNECTION_BUFFER, HttpHeaderValues.KEEP_ALIVE_BUFFER);
|
||||
_generator.setPersistent(true);
|
||||
}
|
||||
else if (HttpMethods.CONNECT.equals(_request.getMethod()))
|
||||
|
@ -912,6 +881,58 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
_delayedHandling=true;
|
||||
}
|
||||
|
||||
protected void content(Buffer buffer) throws IOException
|
||||
{
|
||||
if (_delayedHandling)
|
||||
{
|
||||
_delayedHandling=false;
|
||||
handleRequest();
|
||||
}
|
||||
}
|
||||
|
||||
public void messageComplete(long contentLength) throws IOException
|
||||
{
|
||||
if (_delayedHandling)
|
||||
{
|
||||
_delayedHandling=false;
|
||||
handleRequest();
|
||||
}
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/* ------------------------------------------------------------ */
|
||||
/* ------------------------------------------------------------ */
|
||||
private class RequestHandler extends HttpParser.EventHandler
|
||||
{
|
||||
/*
|
||||
*
|
||||
* @see org.eclipse.jetty.server.server.HttpParser.EventHandler#startRequest(org.eclipse.io.Buffer,
|
||||
* org.eclipse.io.Buffer, org.eclipse.io.Buffer)
|
||||
*/
|
||||
@Override
|
||||
public void startRequest(Buffer method, Buffer uri, Buffer version) throws IOException
|
||||
{
|
||||
AbstractHttpConnection.this.startRequest(method, uri, version);
|
||||
}
|
||||
|
||||
/*
|
||||
* @see org.eclipse.jetty.server.server.HttpParser.EventHandler#parsedHeaderValue(org.eclipse.io.Buffer)
|
||||
*/
|
||||
@Override
|
||||
public void parsedHeader(Buffer name, Buffer value) throws IOException
|
||||
{
|
||||
AbstractHttpConnection.this.parsedHeader(name, value);
|
||||
}
|
||||
|
||||
/*
|
||||
* @see org.eclipse.jetty.server.server.HttpParser.EventHandler#headerComplete()
|
||||
*/
|
||||
@Override
|
||||
public void headerComplete() throws IOException
|
||||
{
|
||||
AbstractHttpConnection.this.headerComplete();
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/*
|
||||
* @see org.eclipse.jetty.server.server.HttpParser.EventHandler#content(int, org.eclipse.io.Buffer)
|
||||
|
@ -919,11 +940,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
@Override
|
||||
public void content(Buffer ref) throws IOException
|
||||
{
|
||||
if (_delayedHandling)
|
||||
{
|
||||
_delayedHandling=false;
|
||||
handleRequest();
|
||||
}
|
||||
AbstractHttpConnection.this.content(ref);
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
|
@ -935,11 +952,7 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
@Override
|
||||
public void messageComplete(long contentLength) throws IOException
|
||||
{
|
||||
if (_delayedHandling)
|
||||
{
|
||||
_delayedHandling=false;
|
||||
handleRequest();
|
||||
}
|
||||
AbstractHttpConnection.this.messageComplete(contentLength);
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
|
@ -955,10 +968,8 @@ public abstract class AbstractHttpConnection extends AbstractConnection
|
|||
if (LOG.isDebugEnabled())
|
||||
LOG.debug("Bad request!: "+version+" "+status+" "+reason);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* ------------------------------------------------------------ */
|
||||
/* ------------------------------------------------------------ */
|
||||
/* ------------------------------------------------------------ */
|
||||
|
|
Loading…
Reference in New Issue