org.webpieces.http2client.impl.Http2SocketImpl Maven / Gradle / Ivy
package org.webpieces.http2client.impl;
import java.net.InetSocketAddress;
import org.webpieces.util.HostWithPort;
import org.webpieces.util.futures.XFuture;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.webpieces.http2client.api.Http2Socket;
import org.webpieces.http2client.api.Http2SocketListener;
import org.webpieces.http2client.api.dto.FullRequest;
import org.webpieces.http2client.api.dto.FullResponse;
import com.webpieces.http2.api.streaming.RequestStreamHandle;
import com.webpieces.http2engine.api.client.Http2ClientEngine;
import com.webpieces.http2engine.api.client.Http2ClientEngineFactory;
public class Http2SocketImpl implements Http2Socket {
private static final Logger log = LoggerFactory.getLogger(Http2SocketImpl.class);
private Layer1Incoming incoming;
private Layer3Outgoing outgoing;
public Http2SocketImpl(Http2ChannelProxy channel, Http2ClientEngineFactory factory, Http2SocketListener socketListener) {
outgoing = new Layer3Outgoing(channel, this);
Http2ClientEngine parseLayer = factory.createClientParser(""+channel, outgoing);
incoming = new Layer1Incoming(parseLayer, socketListener, this);
}
public XFuture connect(HostWithPort addr) {
if(addr == null)
throw new IllegalArgumentException("addr cannot be null");
return outgoing.connect(addr, incoming)
.thenCompose(c -> incoming.sendInitialFrames()) //make sure 'sending' initial frames is part of connecting
.thenApply(f -> {
log.info("connecting complete as initial frames sent");
return null;
});
}
/**
* @deprecated
*/
@Deprecated
@Override
public XFuture connect(InetSocketAddress addr) {
if(addr == null)
throw new IllegalArgumentException("addr cannot be null");
return outgoing.connect(addr, incoming)
.thenCompose(c -> incoming.sendInitialFrames()) //make sure 'sending' initial frames is part of connecting
.thenApply(f -> {
log.info("connecting complete as initial frames sent");
return null;
});
}
@Override
public XFuture close() {
//TODO: For http/2, please send GOAWAY first(crap, do we need reason in the close method?...probably)
return outgoing.close();
}
/**
* Can't specifically backpressure with this method(ie. On the other method, if you do not ack, eventually
* with too many bytes, the channelmanager disregisters and stops reading from the socket placing backpressure
* on the socket)
*/
@Override
public XFuture send(FullRequest request) {
return new ResponseCacher(() -> openStream()).run(request);
}
@Override
public RequestStreamHandle openStream() {
return incoming.openStream();
}
@Override
public XFuture sendPing() {
return incoming.sendPing();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy