nghttpx: Call upstream_writecb when underlying bufferevent buffer gets empty
This commit is contained in:
parent
dfbea797bd
commit
16497d91c1
|
@ -67,12 +67,15 @@ void upstream_writecb(bufferevent *bev, void *arg)
|
||||||
}
|
}
|
||||||
if(handler->get_should_close_after_write()) {
|
if(handler->get_should_close_after_write()) {
|
||||||
delete handler;
|
delete handler;
|
||||||
} else {
|
return;
|
||||||
auto upstream = handler->get_upstream();
|
}
|
||||||
int rv = upstream->on_write();
|
auto upstream = handler->get_upstream();
|
||||||
if(rv != 0) {
|
if(!upstream) {
|
||||||
delete handler;
|
return;
|
||||||
}
|
}
|
||||||
|
int rv = upstream->on_write();
|
||||||
|
if(rv != 0) {
|
||||||
|
delete handler;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // namespace
|
} // namespace
|
||||||
|
@ -232,6 +235,17 @@ void tls_raw_readcb(evbuffer *buffer, const evbuffer_cb_info *info, void *arg)
|
||||||
}
|
}
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
void tls_raw_writecb(evbuffer *buffer, const evbuffer_cb_info *info, void *arg)
|
||||||
|
{
|
||||||
|
auto handler = static_cast<ClientHandler*>(arg);
|
||||||
|
// upstream_writecb() is called when external bufferevent
|
||||||
|
// handler->bev's output buffer gets empty. But the underlying
|
||||||
|
// bufferevent may have pending output buffer.
|
||||||
|
upstream_writecb(handler->get_bev(), handler);
|
||||||
|
}
|
||||||
|
} // namespace
|
||||||
|
|
||||||
ClientHandler::ClientHandler(bufferevent *bev, int fd, SSL *ssl,
|
ClientHandler::ClientHandler(bufferevent *bev, int fd, SSL *ssl,
|
||||||
const char *ipaddr)
|
const char *ipaddr)
|
||||||
: ipaddr_(ipaddr),
|
: ipaddr_(ipaddr),
|
||||||
|
@ -258,6 +272,8 @@ ClientHandler::ClientHandler(bufferevent *bev, int fd, SSL *ssl,
|
||||||
set_bev_cb(nullptr, upstream_writecb, upstream_eventcb);
|
set_bev_cb(nullptr, upstream_writecb, upstream_eventcb);
|
||||||
auto input = bufferevent_get_input(bufferevent_get_underlying(bev_));
|
auto input = bufferevent_get_input(bufferevent_get_underlying(bev_));
|
||||||
evbuffer_add_cb(input, tls_raw_readcb, this);
|
evbuffer_add_cb(input, tls_raw_readcb, this);
|
||||||
|
auto output = bufferevent_get_output(bufferevent_get_underlying(bev_));
|
||||||
|
evbuffer_add_cb(output, tls_raw_writecb, this);
|
||||||
} else {
|
} else {
|
||||||
// For non-TLS version, first create HttpsUpstream. It may be
|
// For non-TLS version, first create HttpsUpstream. It may be
|
||||||
// upgraded to HTTP/2.0 through HTTP Upgrade or direct HTTP/2.0
|
// upgraded to HTTP/2.0 through HTTP Upgrade or direct HTTP/2.0
|
||||||
|
|
Loading…
Reference in New Issue