diff options
author | Max Romanov <max.romanov@nginx.com> | 2019-08-16 00:56:38 +0300 |
---|---|---|
committer | Max Romanov <max.romanov@nginx.com> | 2019-08-16 00:56:38 +0300 |
commit | 29911538ea91705fcdcbcf0e271cfbc5c8ed674b (patch) | |
tree | a3a63b97f073cfe67e1b31d2f8c87fdfad4e3520 /src/nxt_router.c | |
parent | caea9d3c07543fecf9035ff2b406c190b714989e (diff) | |
download | unit-29911538ea91705fcdcbcf0e271cfbc5c8ed674b.tar.gz unit-29911538ea91705fcdcbcf0e271cfbc5c8ed674b.tar.bz2 |
Improving response header fields processing.
Fields are filtered one by one before being added to fields list.
This avoids adding and then skipping connection-specific fields.
Diffstat (limited to 'src/nxt_router.c')
-rw-r--r-- | src/nxt_router.c | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/src/nxt_router.c b/src/nxt_router.c index f09779bc..509f487a 100644 --- a/src/nxt_router.c +++ b/src/nxt_router.c @@ -3483,7 +3483,13 @@ nxt_router_response_ready_handler(nxt_task_t *task, nxt_port_recv_msg_t *msg, goto fail; } + field = NULL; + for (f = resp->fields; f < resp->fields + resp->fields_count; f++) { + if (f->skip) { + continue; + } + field = nxt_list_add(r->resp.fields); if (nxt_slow_path(field == NULL)) { @@ -3491,26 +3497,30 @@ nxt_router_response_ready_handler(nxt_task_t *task, nxt_port_recv_msg_t *msg, } field->hash = f->hash; - field->skip = f->skip; + field->skip = 0; field->name_length = f->name_length; field->value_length = f->value_length; field->name = nxt_unit_sptr_get(&f->name); field->value = nxt_unit_sptr_get(&f->value); - nxt_debug(task, "header: %*s: %*s", + ret = nxt_http_field_process(field, &nxt_response_fields_hash, r); + if (nxt_slow_path(ret != NXT_OK)) { + goto fail; + } + + nxt_debug(task, "header%s: %*s: %*s", + (field->skip ? " skipped" : ""), (size_t) field->name_length, field->name, (size_t) field->value_length, field->value); + + if (field->skip) { + r->resp.fields->last->nelts--; + } } r->status = resp->status; - ret = nxt_http_fields_process(r->resp.fields, - &nxt_response_fields_hash, r); - if (nxt_slow_path(ret != NXT_OK)) { - goto fail; - } - if (resp->piggyback_content_length != 0) { b->mem.pos = nxt_unit_sptr_get(&resp->piggyback_content); b->mem.free = b->mem.pos + resp->piggyback_content_length; |