MAJOR: filters: Remove code relying on the legacy HTTP mode
This commit breaks the compatibility with filters still relying on the legacy
HTTP code. The legacy callbacks were removed (http_data, http_chunk_trailers and
http_forward_data).
For now, the filters must still set the flag FLT_CFG_FL_HTX to be used on HTX
streams.
diff --git a/include/proto/filters.h b/include/proto/filters.h
index 18cbddb..256270f 100644
--- a/include/proto/filters.h
+++ b/include/proto/filters.h
@@ -114,10 +114,6 @@
int flt_http_payload(struct stream *s, struct http_msg *msg, unsigned int len);
int flt_http_end(struct stream *s, struct http_msg *msg);
-int flt_http_data(struct stream *s, struct http_msg *msg);
-int flt_http_chunk_trailers(struct stream *s, struct http_msg *msg);
-int flt_http_forward_data(struct stream *s, struct http_msg *msg, unsigned int len);
-
void flt_http_reset(struct stream *s, struct http_msg *msg);
void flt_http_reply(struct stream *s, short status, const struct buffer *msg);
diff --git a/include/types/filters.h b/include/types/filters.h
index 1dd3398..c91eeae 100644
--- a/include/types/filters.h
+++ b/include/types/filters.h
@@ -123,14 +123,6 @@
* - http_payload : Called when some data can be consumed.
* Returns a negative value if an error occurs, else
* the number of forwarded bytes.
- * - http_data : Called when unparsed body data are available.
- * Returns a negative value if an error occurs, else
- * the number of consumed bytes. [DEPRECATED]
- * - http_chunk_trailers : Called when part of trailer headers of a
- * chunk-encoded request/response are ready to be
- * processed.
- * Returns a negative value if an error occurs, any
- * other value otherwise. [DEPRECATED]
* - http_end : Called when all the request/response has been
* processed and all body data has been forwarded.
* Returns a negative value if an error occurs, 0 if
@@ -146,9 +138,6 @@
* to the client (mainly, when an error or a redirect
* occur).
* Returns nothing.
- * - http_forward_data : Called when some data can be consumed.
- * Returns a negative value if an error occurs, else
- * the number of forwarded bytes. [DEPRECATED]
* - tcp_data : Called when unparsed data are available.
* Returns a negative value if an error occurs, else
* the number of consumed bytes.
@@ -189,10 +178,6 @@
int (*http_payload) (struct stream *s, struct filter *f, struct http_msg *msg,
unsigned int offset, unsigned int len);
int (*http_end) (struct stream *s, struct filter *f, struct http_msg *msg);
- int (*http_data) (struct stream *s, struct filter *f, struct http_msg *msg); // DEPRECATED
- int (*http_chunk_trailers)(struct stream *s, struct filter *f, struct http_msg *msg); // DEPRECATED
- int (*http_forward_data) (struct stream *s, struct filter *f, struct http_msg *msg, // DEPRECATED
- unsigned int len);
void (*http_reset) (struct stream *s, struct filter *f, struct http_msg *msg);
void (*http_reply) (struct stream *s, struct filter *f, short status,
diff --git a/src/filters.c b/src/filters.c
index ff78075..c68319b 100644
--- a/src/filters.c
+++ b/src/filters.c
@@ -529,111 +529,6 @@
return 0;
}
-/*
- * Calls 'http_data' callback for all "data" filters attached to a stream. This
- * function is called when incoming data are available (excluding chunks
- * envelope for chunked messages) in the AN_REQ_HTTP_XFER_BODY and
- * AN_RES_HTTP_XFER_BODY analyzers. It takes care to update the next offset of
- * filters and adjusts available data to be sure that a filter cannot parse more
- * data than its predecessors. A filter can choose to not consume all available
- * data. Returns -1 if an error occurs, the number of consumed bytes otherwise.
- *
- * DEPRECATED FUNCTION - CALLED FROM LEGACY HTTP ANALYZERS
- */
-int
-flt_http_data(struct stream *s, struct http_msg *msg)
-{
- struct filter *filter;
- unsigned int buf_i;
- int delta = 0, ret = 0;
-
- /* Save buffer state */
- buf_i = ci_data(msg->chn);
-
- list_for_each_entry(filter, &strm_flt(s)->filters, list) {
- unsigned int *nxt;
-
- /* Call "data" filters only */
- if (!IS_DATA_FILTER(filter, msg->chn))
- continue;
-
- /* If the HTTP parser is ahead, we update the next offset of the
- * current filter. This happens for chunked messages, at the
- * beginning of a new chunk. */
- nxt = &FLT_NXT(filter, msg->chn);
- if (msg->next > *nxt)
- *nxt = msg->next;
-
- if (FLT_OPS(filter)->http_data) {
- unsigned int i = ci_data(msg->chn);
-
- ret = FLT_OPS(filter)->http_data(s, filter, msg);
- if (ret < 0)
- break;
- delta += (int)(ci_data(msg->chn) - i);
-
- /* Update the next offset of the current filter */
- *nxt += ret;
-
- /* And set this value as the bound for the next
- * filter. It will not able to parse more data than this
- * one. */
- b_set_data(&msg->chn->buf, co_data(msg->chn) + *nxt);
- }
- else {
- /* Consume all available data and update the next offset
- * of the current filter. buf->i is untouched here. */
- ret = MIN(msg->chunk_len + msg->next, ci_data(msg->chn)) - *nxt;
- *nxt += ret;
- }
- }
-
- /* Restore the original buffer state */
- b_set_data(&msg->chn->buf, co_data(msg->chn) + buf_i + delta);
-
- return ret;
-}
-
-/*
- * Calls 'http_chunk_trailers' callback for all "data" filters attached to a
- * stream. This function is called for chunked messages only when a part of the
- * trailers was parsed in the AN_REQ_HTTP_XFER_BODY and AN_RES_HTTP_XFER_BODY
- * analyzers. Filters can know how much data were parsed by the HTTP parsing
- * until the last call with the msg->sol value. Returns a negative value if an
- * error occurs, any other value otherwise.
- *
- * DEPRECATED FUNCTION - CALLED FROM LEGACY HTTP ANALYZERS
- */
-int
-flt_http_chunk_trailers(struct stream *s, struct http_msg *msg)
-{
- struct filter *filter;
- int ret = 1;
-
- list_for_each_entry(filter, &strm_flt(s)->filters, list) {
- unsigned int *nxt;
-
- /* Call "data" filters only */
- if (!IS_DATA_FILTER(filter, msg->chn))
- continue;
-
- /* Be sure to set the next offset of the filter at the right
- * place. This is really useful when the first part of the
- * trailers was parsed. */
- nxt = &FLT_NXT(filter, msg->chn);
- *nxt = msg->next;
-
- if (FLT_OPS(filter)->http_chunk_trailers) {
- ret = FLT_OPS(filter)->http_chunk_trailers(s, filter, msg);
- if (ret < 0)
- break;
- }
- /* Update the next offset of the current filter. Here all data
- * are always consumed. */
- *nxt += msg->sol;
- }
- return ret;
-}
/*
* Calls 'http_end' callback for all filters attached to a stream. All filters
@@ -641,10 +536,6 @@
* functions is called when all data were parsed and forwarded. 'http_end'
* callback is resumable, so this function returns a negative value if an error
* occurs, 0 if it needs to wait for some reason, any other value otherwise.
- *
- * Be carefull, this function can be called from the HTTP legacy analyzers or
- * from HTX analyzers. If your filter is compatible with the two modes, use
- * IS_HTX_STRM macro on the stream.
*/
int
flt_http_end(struct stream *s, struct http_msg *msg)
@@ -665,10 +556,6 @@
/*
* Calls 'http_reset' callback for all filters attached to a stream. This
* happens when a 100-continue response is received.
- *
- * Be carefull, this function can be called from the HTTP legacy analyzers or
- * from HTX analyzers. If your filter is compatible with the two modes, use
- * IS_HTX_STRM macro on the stream.
*/
void
flt_http_reset(struct stream *s, struct http_msg *msg)
@@ -684,10 +571,6 @@
/*
* Calls 'http_reply' callback for all filters attached to a stream when HA
* decides to stop the HTTP message processing.
- *
- * Be carefull, this function can be called from the HTTP legacy analyzers or
- * from HTX analyzers. If your filter is compatible with the two modes, use
- * IS_HTX_STRM macro on the stream.
*/
void
flt_http_reply(struct stream *s, short status, const struct buffer *msg)
@@ -701,70 +584,6 @@
}
/*
- * Calls 'http_forward_data' callback for all "data" filters attached to a HTTP
- * legacy stream. This function is called when some data can be forwarded in the
- * AN_REQ_HTTP_XFER_BODY and AN_RES_HTTP_XFER_BODY analyzers. It takes care to
- * update the forward offset of filters and adjusts "forwardable" data to be
- * sure that a filter cannot forward more data than its predecessors. A filter
- * can choose to not forward all parsed data. Returns a negative value if an
- * error occurs, else the number of forwarded bytes.
- *
- * DEPRECATED FUNCTION - CALLED FROM LEGACY HTTP ANALYZERS
- */
-int
-flt_http_forward_data(struct stream *s, struct http_msg *msg, unsigned int len)
-{
- struct filter *filter;
- int ret = len;
-
- list_for_each_entry(filter, &strm_flt(s)->filters, list) {
- unsigned int *nxt, *fwd;
-
- /* Call "data" filters only */
- if (!IS_DATA_FILTER(filter, msg->chn))
- continue;
-
- /* If the HTTP parser is ahead, we update the next offset of the
- * current filter. This happens for chunked messages, when the
- * chunk envelope is parsed. */
- nxt = &FLT_NXT(filter, msg->chn);
- fwd = &FLT_FWD(filter, msg->chn);
- if (msg->next > *nxt)
- *nxt = msg->next;
-
- if (FLT_OPS(filter)->http_forward_data) {
- /* Remove bytes that the current filter considered as
- * forwarded */
- ret = FLT_OPS(filter)->http_forward_data(s, filter, msg, ret - *fwd);
- if (ret < 0)
- goto end;
- }
-
- /* Adjust bytes that the current filter considers as
- * forwarded */
- *fwd += ret;
-
- /* And set this value as the bound for the next filter. It will
- * not able to forward more data than the current one. */
- ret = *fwd;
- }
-
- if (!ret)
- goto end;
-
- /* Finally, adjust filters offsets by removing data that HAProxy will
- * forward. */
- list_for_each_entry(filter, &strm_flt(s)->filters, list) {
- if (!IS_DATA_FILTER(filter, msg->chn))
- continue;
- FLT_NXT(filter, msg->chn) -= ret;
- FLT_FWD(filter, msg->chn) -= ret;
- }
- end:
- return ret;
-}
-
-/*
* Calls 'http_payload' callback for all "data" filters attached to a
* stream. This function is called when some data can be forwarded in the
* AN_REQ_HTTP_XFER_BODY and AN_RES_HTTP_XFER_BODY analyzers. It takes care to
@@ -772,10 +591,6 @@
* forward more data than its predecessors. A filter can choose to not forward
* all data. Returns a negative value if an error occurs, else the number of
* forwarded bytes.
- *
- * Be carefull, this callback is only called from HTX analyzers. So the
- * channel's buffer must be considered as an HTX structured. Of course, your
- * filter must support HTX streams.
*/
int
flt_http_payload(struct stream *s, struct http_msg *msg, unsigned int len)
@@ -907,15 +722,10 @@
* This function is the AN_REQ/RES_FLT_HTTP_HDRS analyzer, used to filter HTTP
* headers or a request or a response. Returns 0 if an error occurs or if it
* needs to wait, any other value otherwise.
- *
- * Be carefull, this function can be called from the HTTP legacy analyzers or
- * from HTX analyzers. If your filter is compatible with the two modes, use
- * IS_HTX_STRM macro on the stream.
*/
int
flt_analyze_http_headers(struct stream *s, struct channel *chn, unsigned int an_bit)
{
- struct filter *filter;
struct http_msg *msg;
int ret = 1;
@@ -927,21 +737,7 @@
BREAK_EXECUTION(s, chn, check_result);
}
} RESUME_FILTER_END;
-
- if (IS_HTX_STRM(s))
- channel_htx_fwd_headers(chn, htxbuf(&chn->buf));
- else {
- /* We increase next offset of all "data" filters after all processing on
- * headers because any filter can alter them. So the definitive size of
- * headers (msg->sov) is only known when all filters have been
- * called. */
- list_for_each_entry(filter, &strm_flt(s)->filters, list) {
- /* Handle "data" filters only */
- if (!IS_DATA_FILTER(filter, chn))
- continue;
- FLT_NXT(filter, chn) = msg->sov;
- }
- }
+ channel_htx_fwd_headers(chn, htxbuf(&chn->buf));
check_result:
return handle_analyzer_result(s, chn, an_bit, ret);
@@ -1003,10 +799,6 @@
s->req.analysers &= ~AN_REQ_FLT_END;
s->res.analysers &= ~AN_RES_FLT_END;
- /* Clean up the HTTP transaction if needed */
- if (s->txn && (s->txn->flags & TX_WAIT_CLEANUP))
- http_end_txn_clean_session(s);
-
/* Remove backend filters from the list */
flt_stream_release(s, 1);
}
@@ -1219,13 +1011,13 @@
/* FIXME: incr counters */
}
- if (s->txn) {
+ if (IS_HTX_STRM(s)) {
/* Do not do that when we are waiting for the next request */
if (s->txn->status)
- http_reply_and_close(s, s->txn->status, NULL);
+ htx_reply_and_close(s, s->txn->status, NULL);
else {
s->txn->status = 400;
- http_reply_and_close(s, 400, http_error_message(s));
+ htx_reply_and_close(s, 400, htx_error_message(s));
}
}