
swim.io.http.HttpServerModem Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of swim-io-http Show documentation
Show all versions of swim-io-http Show documentation
Uploads all artifacts belonging to configuration ':swim-io-http:archives'
The newest version!
// Copyright 2015-2019 SWIM.AI inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package swim.io.http;
import java.net.InetSocketAddress;
import java.security.Principal;
import java.security.cert.Certificate;
import java.util.Collection;
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
import swim.codec.Decoder;
import swim.codec.Utf8;
import swim.collections.FingerTrieSeq;
import swim.http.Http;
import swim.http.HttpRequest;
import swim.http.HttpResponse;
import swim.io.FlowControl;
import swim.io.FlowModifier;
import swim.io.IpModem;
import swim.io.IpModemContext;
import swim.io.IpSocket;
public class HttpServerModem implements IpModem, HttpResponse>>, HttpServerContext {
protected final HttpServer server;
protected final HttpSettings httpSettings;
volatile HttpServerResponder> requesting;
volatile FingerTrieSeq> responders;
protected IpModemContext, HttpResponse>> context;
public HttpServerModem(HttpServer server, HttpSettings httpSettings) {
this.server = server;
this.httpSettings = httpSettings;
this.responders = FingerTrieSeq.empty();
}
@Override
public IpModemContext, HttpResponse>> ipModemContext() {
return this.context;
}
@Override
public void setIpModemContext(IpModemContext, HttpResponse>> context) {
this.context = context;
this.server.setHttpServerContext(this);
}
@Override
public long idleTimeout() {
return this.server.idleTimeout();
}
@Override
public void doRead() {
// nop
}
@Override
public void didRead(HttpRequest> request) {
if (REQUESTING.get(this) == null) {
willRequest(request);
} else {
didRequest(request);
}
}
@Override
public void doWrite() {
// nop
}
@Override
public void didWrite(HttpResponse> response) {
didRespond(response);
}
@Override
public void willConnect() {
// nop
}
@Override
public void didConnect() {
this.server.didConnect();
}
@Override
public void willSecure() {
this.server.willSecure();
}
@Override
public void didSecure() {
this.server.didSecure();
}
@Override
public void willBecome(IpSocket socket) {
this.server.willBecome(socket);
}
@Override
public void didBecome(IpSocket socket) {
this.server.didBecome(socket);
}
@Override
public void didTimeout() {
for (HttpServerResponder> responderContext : RESPONDERS.get(this)) {
responderContext.didTimeout();
}
this.server.didTimeout();
}
@Override
public void didDisconnect() {
do {
final FingerTrieSeq> oldResponders = RESPONDERS.get(this);
final FingerTrieSeq> newResponders = FingerTrieSeq.empty();
if (oldResponders != newResponders) {
if (RESPONDERS.compareAndSet(this, oldResponders, newResponders)) {
for (HttpServerResponder> responderContext : oldResponders) {
responderContext.didDisconnect();
}
break;
}
} else {
break;
}
} while (true);
server.didDisconnect();
close();
}
@Override
public void didFail(Throwable error) {
do {
final FingerTrieSeq> oldResponders = RESPONDERS.get(this);
final FingerTrieSeq> newResponders = FingerTrieSeq.empty();
if (oldResponders != newResponders) {
if (RESPONDERS.compareAndSet(this, oldResponders, newResponders)) {
for (HttpServerResponder> responderContext : oldResponders) {
responderContext.didFail(error);
}
break;
}
} else {
break;
}
} while (true);
server.didFail(error);
close();
}
@Override
public boolean isConnected() {
final IpModemContext, HttpResponse>> context = this.context;
return context != null && context.isConnected();
}
@Override
public boolean isClient() {
return false;
}
@Override
public boolean isServer() {
return true;
}
@Override
public boolean isSecure() {
final IpModemContext, HttpResponse>> context = this.context;
return context != null && context.isSecure();
}
@Override
public String securityProtocol() {
return this.context.securityProtocol();
}
@Override
public String cipherSuite() {
return this.context.cipherSuite();
}
@Override
public InetSocketAddress localAddress() {
return this.context.localAddress();
}
@Override
public Principal localPrincipal() {
return this.context.localPrincipal();
}
@Override
public Collection localCertificates() {
return this.context.localCertificates();
}
@Override
public InetSocketAddress remoteAddress() {
return this.context.remoteAddress();
}
@Override
public Principal remotePrincipal() {
return this.context.remotePrincipal();
}
@Override
public Collection remoteCertificates() {
return this.context.remoteCertificates();
}
@Override
public FlowControl flowControl() {
return this.context.flowControl();
}
@Override
public void flowControl(FlowControl flowControl) {
this.context.flowControl(flowControl);
}
@Override
public FlowControl flowControl(FlowModifier flowModifier) {
return this.context.flowControl(flowModifier);
}
@Override
public HttpSettings httpSettings() {
return this.httpSettings;
}
@Override
public void readRequest() {
doReadRequestMessage();
}
@Override
public void become(IpSocket socket) {
this.context.become(socket);
}
@Override
public void close() {
this.context.close();
}
void doReadRequestMessage() {
this.context.read(Utf8.decodedParser(Http.standardParser().requestParser()));
}
void doReadRequestEntity(Decoder> entityDecoder) {
if (entityDecoder.isCont()) {
this.context.read(entityDecoder);
} else {
didRead(entityDecoder.bind());
}
}
@SuppressWarnings("unchecked")
void willRequest(HttpRequest> request) {
final HttpResponder> responder = this.server.doRequest(request);
final HttpServerResponder> responderContext = new HttpServerResponder
© 2015 - 2025 Weber Informatics LLC | Privacy Policy