- java.lang.Object
-
- swim.io.http.AbstractHttpServer
-
- All Implemented Interfaces:
FlowContext
,HttpServer
,IpContext
- Direct Known Subclasses:
AbstractWsServer
public abstract class AbstractHttpServer extends Object implements HttpServer, IpContext, FlowContext
-
-
Field Summary
Fields Modifier and Type Field Description protected HttpServerContext
context
-
Constructor Summary
Constructors Constructor Description AbstractHttpServer()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description void
become(IpSocket socket)
String
cipherSuite()
Returns the cryptographic cipher suite used by the underlying network connection.void
close()
void
didBecome(IpSocket socket)
void
didConnect()
void
didDisconnect()
void
didFail(Throwable error)
void
didRequest(HttpRequest<?> request)
void
didRespond(HttpResponse<?> response)
void
didSecure()
void
didTimeout()
abstract HttpResponder<?>
doRequest(HttpRequest<?> request)
FlowControl
flowControl()
Returns the currentFlowControl
state of the underlying network channel.void
flowControl(FlowControl flowControl)
Enqueues an atomic replacement of the underlying network channel's flow control state with a newflowControl
.FlowControl
flowControl(FlowModifier flowModifier)
Enqueues an atomic modification to the underlying network channel's flow control state by applying aflowModifier
delta.HttpServerContext
httpServerContext()
HttpSettings
httpSettings()
long
idleTimeout()
boolean
isClient()
Returnstrue
if the underlying network channel initiated an outgoing connection.boolean
isConnected()
Returnstrue
if the underlying network channel is currently connected.boolean
isSecure()
Returnstrue
if the underlying network transport is encrypted.boolean
isServer()
Returnstrue
if the underlying network channel accepted an incoming connection.InetSocketAddress
localAddress()
Returns the IP address and port of the local endpoint of the underlying network connection.Collection<Certificate>
localCertificates()
Returns the certificate chain used to authenticate the local endpoint of the underlying network connection.Principal
localPrincipal()
Returns the authenticated identity of the local endpoint of the underlying network connection.void
readRequest()
InetSocketAddress
remoteAddress()
Returns the IP address and port of the remote endpoint of the underlying network connection.Collection<Certificate>
remoteCertificates()
Returns the certificate chain used to authenticate the remote endpoint of the underlying network connection.Principal
remotePrincipal()
Returns the authenticated identity of the remote endpoint of the underlying network connection.String
securityProtocol()
Returns the name of the transport-layer security protocol used by the underlying network connection.void
setHttpServerContext(HttpServerContext context)
void
willBecome(IpSocket socket)
void
willRequest(HttpRequest<?> request)
void
willRespond(HttpResponse<?> response)
void
willSecure()
-
-
-
Field Detail
-
context
protected HttpServerContext context
-
-
Method Detail
-
httpServerContext
public HttpServerContext httpServerContext()
- Specified by:
httpServerContext
in interfaceHttpServer
-
setHttpServerContext
public void setHttpServerContext(HttpServerContext context)
- Specified by:
setHttpServerContext
in interfaceHttpServer
-
idleTimeout
public long idleTimeout()
- Specified by:
idleTimeout
in interfaceHttpServer
-
doRequest
public abstract HttpResponder<?> doRequest(HttpRequest<?> request)
- Specified by:
doRequest
in interfaceHttpServer
-
willRequest
public void willRequest(HttpRequest<?> request)
- Specified by:
willRequest
in interfaceHttpServer
-
didRequest
public void didRequest(HttpRequest<?> request)
- Specified by:
didRequest
in interfaceHttpServer
-
willRespond
public void willRespond(HttpResponse<?> response)
- Specified by:
willRespond
in interfaceHttpServer
-
didRespond
public void didRespond(HttpResponse<?> response)
- Specified by:
didRespond
in interfaceHttpServer
-
didConnect
public void didConnect()
- Specified by:
didConnect
in interfaceHttpServer
-
willSecure
public void willSecure()
- Specified by:
willSecure
in interfaceHttpServer
-
didSecure
public void didSecure()
- Specified by:
didSecure
in interfaceHttpServer
-
willBecome
public void willBecome(IpSocket socket)
- Specified by:
willBecome
in interfaceHttpServer
-
didBecome
public void didBecome(IpSocket socket)
- Specified by:
didBecome
in interfaceHttpServer
-
didTimeout
public void didTimeout()
- Specified by:
didTimeout
in interfaceHttpServer
-
didDisconnect
public void didDisconnect()
- Specified by:
didDisconnect
in interfaceHttpServer
-
didFail
public void didFail(Throwable error)
- Specified by:
didFail
in interfaceHttpServer
-
isConnected
public boolean isConnected()
Description copied from interface:IpContext
Returnstrue
if the underlying network channel is currently connected.- Specified by:
isConnected
in interfaceIpContext
-
isClient
public boolean isClient()
Description copied from interface:IpContext
Returnstrue
if the underlying network channel initiated an outgoing connection.
-
isServer
public boolean isServer()
Description copied from interface:IpContext
Returnstrue
if the underlying network channel accepted an incoming connection.
-
isSecure
public boolean isSecure()
Description copied from interface:IpContext
Returnstrue
if the underlying network transport is encrypted.
-
securityProtocol
public String securityProtocol()
Description copied from interface:IpContext
Returns the name of the transport-layer security protocol used by the underlying network connection. Returnsnull
if the underlying network channel is not currently connected, or if the underlying network connection is not secure.- Specified by:
securityProtocol
in interfaceIpContext
-
cipherSuite
public String cipherSuite()
Description copied from interface:IpContext
Returns the cryptographic cipher suite used by the underlying network connection. Returnsnull
if the underlying network channel is not currently connected, or if the underlying network connection is not secure.- Specified by:
cipherSuite
in interfaceIpContext
-
localAddress
public InetSocketAddress localAddress()
Description copied from interface:IpContext
Returns the IP address and port of the local endpoint of the underlying network connection. Returnsnull
if the underlying network channel is not currently connected.- Specified by:
localAddress
in interfaceIpContext
-
localPrincipal
public Principal localPrincipal()
Description copied from interface:IpContext
Returns the authenticated identity of the local endpoint of the underlying network connection. Returnsnull
if the underlying network channel is not currently connected, or if the underlying network connection is not authenticated.- Specified by:
localPrincipal
in interfaceIpContext
-
localCertificates
public Collection<Certificate> localCertificates()
Description copied from interface:IpContext
Returns the certificate chain used to authenticate the local endpoint of the underlying network connection. Returnsnull
if the underlying network channel is not currently connected, or if the underlying network connection is not authenticated.- Specified by:
localCertificates
in interfaceIpContext
-
remoteAddress
public InetSocketAddress remoteAddress()
Description copied from interface:IpContext
Returns the IP address and port of the remote endpoint of the underlying network connection. Returnsnull
if the underlying network channel is not currently connected.- Specified by:
remoteAddress
in interfaceIpContext
-
remotePrincipal
public Principal remotePrincipal()
Description copied from interface:IpContext
Returns the authenticated identity of the remote endpoint of the underlying network connection. Returnsnull
if the underlying network channel is not currently connected, or if the underlying network connection is not authenticated.- Specified by:
remotePrincipal
in interfaceIpContext
-
remoteCertificates
public Collection<Certificate> remoteCertificates()
Description copied from interface:IpContext
Returns the certificate chain used to authenticate the remote endpoint of the underlying network connection. Returnsnull
if the underlying network channel is not currently connected, or if the underlying network connection is not authenticated.- Specified by:
remoteCertificates
in interfaceIpContext
-
flowControl
public FlowControl flowControl()
Description copied from interface:FlowContext
Returns the currentFlowControl
state of the underlying network channel.- Specified by:
flowControl
in interfaceFlowContext
-
flowControl
public void flowControl(FlowControl flowControl)
Description copied from interface:FlowContext
Enqueues an atomic replacement of the underlying network channel's flow control state with a newflowControl
.- Specified by:
flowControl
in interfaceFlowContext
-
flowControl
public FlowControl flowControl(FlowModifier flowModifier)
Description copied from interface:FlowContext
Enqueues an atomic modification to the underlying network channel's flow control state by applying aflowModifier
delta.- Specified by:
flowControl
in interfaceFlowContext
-
httpSettings
public HttpSettings httpSettings()
-
readRequest
public void readRequest()
-
become
public void become(IpSocket socket)
-
close
public void close()
-
-