Class HttpConnection
- java.lang.Object
-
- org.eclipse.jetty.io.AbstractConnection
-
- org.eclipse.jetty.server.HttpConnection
-
- All Implemented Interfaces:
java.io.Closeable
,java.lang.AutoCloseable
,java.lang.Runnable
,Connection
,Connection.UpgradeFrom
,Connection.UpgradeTo
,WriteFlusher.Listener
,HttpTransport
public class HttpConnection extends AbstractConnection implements java.lang.Runnable, HttpTransport, WriteFlusher.Listener, Connection.UpgradeFrom, Connection.UpgradeTo
A
Connection
that handles the HTTP protocol.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.eclipse.jetty.io.Connection
Connection.Listener, Connection.UpgradeFrom, Connection.UpgradeTo
-
-
Field Summary
Fields Modifier and Type Field Description static HttpField
CONNECTION_CLOSE
static java.lang.String
UPGRADE_CONNECTION_ATTRIBUTE
-
Constructor Summary
Constructors Constructor Description HttpConnection(HttpConfiguration config, Connector connector, EndPoint endPoint, HttpCompliance compliance, boolean recordComplianceViolations)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description void
abort(java.lang.Throwable failure)
Aborts this transport.void
asyncReadFillInterested()
void
blockingReadFailure(java.lang.Throwable e)
void
blockingReadFillInterested()
protected boolean
fillAndParseForContent()
Fill and parse data looking for contentlong
getBytesIn()
long
getBytesOut()
Connector
getConnector()
static HttpConnection
getCurrentConnection()
Get the current connection that this thread is dispatched to.HttpGenerator
getGenerator()
HttpChannel
getHttpChannel()
HttpCompliance
getHttpCompliance()
Deprecated.HttpConfiguration
getHttpConfiguration()
long
getMessagesIn()
long
getMessagesOut()
HttpParser
getParser()
java.nio.ByteBuffer
getRequestBuffer()
Server
getServer()
boolean
isOptimizedForDirectBuffers()
Is the underlying transport optimized for DirectBuffer usageboolean
isPushSupported()
boolean
isRecordHttpComplianceViolations()
boolean
isRequestBufferEmpty()
protected HttpChannelOverHttp
newHttpChannel()
protected HttpGenerator
newHttpGenerator()
protected HttpParser
newHttpParser(HttpCompliance compliance)
protected HttpParser.RequestHandler
newRequestHandler()
void
onClose()
Callback method invoked when this connection is closed.void
onCompleted()
Called to indicated the end of the current request/response cycle (which may be some time after the last content is sent).void
onFillable()
Callback method invoked when the endpoint is ready to be read.protected void
onFillInterestedFailed(java.lang.Throwable cause)
Callback method invoked when the endpoint failed to be ready to be read.void
onFlushed(long bytes)
Invoked when aWriteFlusher
flushed bytes in a non-blocking way, as part of a - possibly larger - write.void
onOpen()
Callback method invoked when this connection is opened.protected boolean
onReadTimeout(java.lang.Throwable timeout)
Callback method invoked when the endpoint failed to be ready to be read after a timeoutjava.nio.ByteBuffer
onUpgradeFrom()
Invoked during anupgrade
to produce a buffer containing bytes that have not been consumed by this connection, and that must be consumed by the upgrade-to connection.void
onUpgradeTo(java.nio.ByteBuffer buffer)
Invoked during anupgrade
to receive a buffer containing bytes that have not been consumed by the upgrade-from connection, and that must be consumed by this connection.void
push(MetaData.Request request)
void
run()
void
send(MetaData.Response info, boolean head, java.nio.ByteBuffer content, boolean lastContent, Callback callback)
Asynchronous call to send a response (or part) over the transportprotected static HttpConnection
setCurrentConnection(HttpConnection connection)
java.lang.String
toConnectionString()
-
Methods inherited from class org.eclipse.jetty.io.AbstractConnection
addListener, close, failedCallback, fillInterested, getCreatedTimeStamp, getEndPoint, getExecutor, getInputBufferSize, isFillInterested, onIdleExpired, removeListener, setInputBufferSize, toString, tryFillInterested, tryFillInterested
-
-
-
-
Field Detail
-
CONNECTION_CLOSE
public static final HttpField CONNECTION_CLOSE
-
UPGRADE_CONNECTION_ATTRIBUTE
public static final java.lang.String UPGRADE_CONNECTION_ATTRIBUTE
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
HttpConnection
public HttpConnection(HttpConfiguration config, Connector connector, EndPoint endPoint, HttpCompliance compliance, boolean recordComplianceViolations)
-
-
Method Detail
-
getCurrentConnection
public static HttpConnection getCurrentConnection()
Get the current connection that this thread is dispatched to. Note that a thread may be processing a request asynchronously and thus not be dispatched to the connection.- Returns:
- the current HttpConnection or null
- See Also:
for a more general way to access the HttpConnection
-
setCurrentConnection
protected static HttpConnection setCurrentConnection(HttpConnection connection)
-
getHttpCompliance
@Deprecated public HttpCompliance getHttpCompliance()
Deprecated.
-
getHttpConfiguration
public HttpConfiguration getHttpConfiguration()
-
isRecordHttpComplianceViolations
public boolean isRecordHttpComplianceViolations()
-
newHttpGenerator
protected HttpGenerator newHttpGenerator()
-
newHttpChannel
protected HttpChannelOverHttp newHttpChannel()
-
newHttpParser
protected HttpParser newHttpParser(HttpCompliance compliance)
-
newRequestHandler
protected HttpParser.RequestHandler newRequestHandler()
-
getServer
public Server getServer()
-
getConnector
public Connector getConnector()
-
getHttpChannel
public HttpChannel getHttpChannel()
-
getParser
public HttpParser getParser()
-
getGenerator
public HttpGenerator getGenerator()
-
isOptimizedForDirectBuffers
public boolean isOptimizedForDirectBuffers()
Description copied from interface:HttpTransport
Is the underlying transport optimized for DirectBuffer usage- Specified by:
isOptimizedForDirectBuffers
in interfaceHttpTransport
- Returns:
- True if direct buffers can be used optimally.
-
getMessagesIn
public long getMessagesIn()
- Specified by:
getMessagesIn
in interfaceConnection
- Overrides:
getMessagesIn
in classAbstractConnection
-
getMessagesOut
public long getMessagesOut()
- Specified by:
getMessagesOut
in interfaceConnection
- Overrides:
getMessagesOut
in classAbstractConnection
-
onUpgradeFrom
public java.nio.ByteBuffer onUpgradeFrom()
Description copied from interface:Connection.UpgradeFrom
Invoked during an
upgrade
to produce a buffer containing bytes that have not been consumed by this connection, and that must be consumed by the upgrade-to connection.- Specified by:
onUpgradeFrom
in interfaceConnection.UpgradeFrom
- Returns:
- a buffer of unconsumed bytes to pass to the upgrade-to connection. The buffer does not belong to any pool and should be discarded after having consumed its bytes. The returned buffer may be null if there are no unconsumed bytes.
-
onUpgradeTo
public void onUpgradeTo(java.nio.ByteBuffer buffer)
Description copied from interface:Connection.UpgradeTo
Invoked during an
upgrade
to receive a buffer containing bytes that have not been consumed by the upgrade-from connection, and that must be consumed by this connection.- Specified by:
onUpgradeTo
in interfaceConnection.UpgradeTo
- Parameters:
buffer
- a non-null buffer of unconsumed bytes received from the upgrade-from connection. The buffer does not belong to any pool and should be discarded after having consumed its bytes.
-
onFlushed
public void onFlushed(long bytes) throws java.io.IOException
Description copied from interface:WriteFlusher.Listener
Invoked when a
WriteFlusher
flushed bytes in a non-blocking way, as part of a - possibly larger - write.This method may be invoked multiple times, for example when writing a large buffer: a first flush of bytes, then the connection became TCP congested, and a subsequent flush of bytes when the connection became writable again.
This method is never invoked concurrently, but may be invoked by different threads, so implementations may not rely on thread-local variables.
Implementations may throw an
IOException
to signal that the write should fail, for example if the implementation enforces a minimum data rate.- Specified by:
onFlushed
in interfaceWriteFlusher.Listener
- Parameters:
bytes
- the number of bytes flushed- Throws:
java.io.IOException
- if the write should fail
-
getRequestBuffer
public java.nio.ByteBuffer getRequestBuffer()
-
isRequestBufferEmpty
public boolean isRequestBufferEmpty()
-
onFillable
public void onFillable()
Description copied from class:AbstractConnection
Callback method invoked when the endpoint is ready to be read.
- Specified by:
onFillable
in classAbstractConnection
- See Also:
AbstractConnection.fillInterested()
-
fillAndParseForContent
protected boolean fillAndParseForContent()
Fill and parse data looking for content- Returns:
- true if an
HttpParser.RequestHandler
method was called and it returned true;
-
onCompleted
public void onCompleted()
Description copied from interface:HttpTransport
Called to indicated the end of the current request/response cycle (which may be some time after the last content is sent).- Specified by:
onCompleted
in interfaceHttpTransport
-
onReadTimeout
protected boolean onReadTimeout(java.lang.Throwable timeout)
Description copied from class:AbstractConnection
Callback method invoked when the endpoint failed to be ready to be read after a timeout
- Overrides:
onReadTimeout
in classAbstractConnection
- Parameters:
timeout
- the cause of the read timeout- Returns:
- true to signal that the endpoint must be closed, false to keep the endpoint open
-
onFillInterestedFailed
protected void onFillInterestedFailed(java.lang.Throwable cause)
Description copied from class:AbstractConnection
Callback method invoked when the endpoint failed to be ready to be read.
- Overrides:
onFillInterestedFailed
in classAbstractConnection
- Parameters:
cause
- the exception that caused the failure
-
onOpen
public void onOpen()
Description copied from interface:Connection
Callback method invoked when this connection is opened.
Creators of the connection implementation are responsible for calling this method.
- Specified by:
onOpen
in interfaceConnection
- Overrides:
onOpen
in classAbstractConnection
-
onClose
public void onClose()
Description copied from interface:Connection
Callback method invoked when this connection is closed.
Creators of the connection implementation are responsible for calling this method.
- Specified by:
onClose
in interfaceConnection
- Overrides:
onClose
in classAbstractConnection
-
run
public void run()
- Specified by:
run
in interfacejava.lang.Runnable
-
send
public void send(MetaData.Response info, boolean head, java.nio.ByteBuffer content, boolean lastContent, Callback callback)
Description copied from interface:HttpTransport
Asynchronous call to send a response (or part) over the transport- Specified by:
send
in interfaceHttpTransport
- Parameters:
info
- The header info to send, or null if just sending more data. The first call to send for a response must have a non null info.head
- True if the response if for a HEAD request (and the data should not be sent).content
- A buffer of content to be sent.lastContent
- True if the content is the last content for the current response.callback
- The Callback instance that success or failure of the send is notified on
-
abort
public void abort(java.lang.Throwable failure)
Description copied from interface:HttpTransport
Aborts this transport.This method should terminate the transport in a way that can indicate an abnormal response to the client, for example by abruptly close the connection.
This method is called when an error response needs to be sent, but the response is already committed, or when a write failure is detected. If abort is called,
HttpTransport.onCompleted()
is not called- Specified by:
abort
in interfaceHttpTransport
- Parameters:
failure
- the failure that caused the abort.
-
isPushSupported
public boolean isPushSupported()
- Specified by:
isPushSupported
in interfaceHttpTransport
- Returns:
- true if responses can be pushed over this transport
-
push
public void push(MetaData.Request request)
- Specified by:
push
in interfaceHttpTransport
- Parameters:
request
- A request to use as the basis for generating a pushed response.
-
asyncReadFillInterested
public void asyncReadFillInterested()
-
blockingReadFillInterested
public void blockingReadFillInterested()
-
blockingReadFailure
public void blockingReadFailure(java.lang.Throwable e)
-
getBytesIn
public long getBytesIn()
- Specified by:
getBytesIn
in interfaceConnection
- Overrides:
getBytesIn
in classAbstractConnection
-
getBytesOut
public long getBytesOut()
- Specified by:
getBytesOut
in interfaceConnection
- Overrides:
getBytesOut
in classAbstractConnection
-
toConnectionString
public java.lang.String toConnectionString()
- Overrides:
toConnectionString
in classAbstractConnection
-
-