MINOR: filters: Do not reset stream analyzers if the client is gone

When all callbacks have been called for all filters registered on a stream, if
we are waiting for the next HTTP request, we must reset stream analyzers. But it
is useless to do so if the client has already closed the connection.
This commit is contained in:
Christopher Faulet 2015-12-22 12:01:29 +01:00 committed by Willy Tarreau
parent d7c9196ae5
commit 02c7b22267

View File

@ -687,13 +687,19 @@ flt_end_analyze(struct stream *s, struct channel *chn, unsigned int an_bit)
end: end:
ret = handle_analyzer_result(s, chn, an_bit, ret); ret = handle_analyzer_result(s, chn, an_bit, ret);
if (!(s->req.analysers & AN_FLT_END) &&
!(s->res.analysers & AN_FLT_END) && /* Check if 'channel_end_analyze' callback has been called for the
s->txn && (s->txn->flags & TX_WAIT_NEXT_RQ)) { * request and the response. */
if (!(s->req.analysers & AN_FLT_END) && !(s->res.analysers & AN_FLT_END)) {
struct filter *filter, *back; struct filter *filter, *back;
s->req.analysers = strm_li(s) ? strm_li(s)->analysers : 0; /* When we are waiting for a new request, so we must reset
s->res.analysers = 0; * stream analyzers. The input must not be closed the request
* channel, else it is useless to wait. */
if (s->txn && (s->txn->flags & TX_WAIT_NEXT_RQ) && !channel_input_closed(&s->req)) {
s->req.analysers = strm_li(s) ? strm_li(s)->analysers : 0;
s->res.analysers = 0;
}
list_for_each_entry_safe(filter, back, &s->strm_flt.filters, list) { list_for_each_entry_safe(filter, back, &s->strm_flt.filters, list) {
if (filter->is_backend_filter) { if (filter->is_backend_filter) {