
swim.io.http.HttpClientModem 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 HttpClientModem implements IpModem, HttpRequest>>, HttpClientContext {
protected final HttpClient client;
protected final HttpSettings httpSettings;
volatile FingerTrieSeq> requesters;
volatile FingerTrieSeq> responders;
volatile HttpClientRequester> responding;
protected IpModemContext, HttpRequest>> context;
public HttpClientModem(HttpClient client, HttpSettings httpSettings) {
this.client = client;
this.httpSettings = httpSettings;
this.requesters = FingerTrieSeq.empty();
this.responders = FingerTrieSeq.empty();
}
@Override
public IpModemContext, HttpRequest>> ipModemContext() {
return this.context;
}
@Override
public void setIpModemContext(IpModemContext, HttpRequest>> context) {
this.context = context;
this.client.setHttpClientContext(this);
}
@Override
public long idleTimeout() {
return this.client.idleTimeout();
}
@Override
public void doRead() {
// nop
}
@Override
public void didRead(HttpResponse> response) {
if (RESPONDING.get(this) == null) {
willRespond(response);
} else {
didRespond(response);
}
}
@Override
public void doWrite() {
// nop
}
@Override
public void didWrite(HttpRequest> request) {
didRequest(request);
}
@Override
public void willConnect() {
this.client.willConnect();
}
@Override
public void didConnect() {
this.client.didConnect();
}
@Override
public void willSecure() {
this.client.willSecure();
}
@Override
public void didSecure() {
this.client.didSecure();
}
@Override
public void willBecome(IpSocket socket) {
this.client.willBecome(socket);
}
@Override
public void didBecome(IpSocket socket) {
this.client.didBecome(socket);
}
@Override
public void didTimeout() {
for (HttpClientRequester> responderContext : RESPONDERS.get(this)) {
responderContext.didTimeout();
}
this.client.didTimeout();
}
@Override
public void didDisconnect() {
REQUESTERS.set(this, FingerTrieSeq.>empty());
do {
final FingerTrieSeq> oldResponders = RESPONDERS.get(this);
final FingerTrieSeq> newResponders = FingerTrieSeq.empty();
if (oldResponders != newResponders) {
if (RESPONDERS.compareAndSet(this, oldResponders, newResponders)) {
for (HttpClientRequester> responderContext : oldResponders) {
responderContext.didDisconnect();
}
break;
}
} else {
break;
}
} while (true);
this.client.didDisconnect();
close();
}
@Override
public void didFail(Throwable error) {
REQUESTERS.set(this, FingerTrieSeq.>empty());
do {
final FingerTrieSeq> oldResponders = RESPONDERS.get(this);
final FingerTrieSeq> newResponders = FingerTrieSeq.empty();
if (oldResponders != newResponders) {
if (RESPONDERS.compareAndSet(this, oldResponders, newResponders)) {
for (HttpClientRequester> responderContext : oldResponders) {
responderContext.didFail(error);
}
break;
}
} else {
break;
}
} while (true);
this.client.didFail(error);
close();
}
@Override
public boolean isConnected() {
final IpModemContext, HttpRequest>> context = this.context;
return context != null && context.isConnected();
}
@Override
public boolean isClient() {
return true;
}
@Override
public boolean isServer() {
return false;
}
@Override
public boolean isSecure() {
final IpModemContext, HttpRequest>> 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;
}
@SuppressWarnings("unchecked")
@Override
public void doRequest(HttpRequester> requester) {
final HttpClientRequester> requesterContext = new HttpClientRequester
© 2015 - 2025 Weber Informatics LLC | Privacy Policy