annotate src/http/ngx_http_request_body.c @ 692:6db6e93f55ee NGINX_1_3_9

nginx 1.3.9 *) Feature: support for chunked transfer encoding while reading client request body. *) Feature: the $request_time and $msec variables can now be used not only in the "log_format" directive. *) Bugfix: cache manager and cache loader processes might not be able to start if more than 512 listen sockets were used. *) Bugfix: in the ngx_http_dav_module.
author Igor Sysoev <http://sysoev.ru>
date Tue, 27 Nov 2012 00:00:00 +0400
parents f41d4b305d22
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
660
d0f7a625f27c nginx 1.1.14
Igor Sysoev <http://sysoev.ru>
parents: 636
diff changeset
4 * Copyright (C) Nginx, Inc.
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5 */
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10 #include <ngx_http.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
13 static void ngx_http_read_client_request_body_handler(ngx_http_request_t *r);
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
14 static ngx_int_t ngx_http_do_read_client_request_body(ngx_http_request_t *r);
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
15 static ngx_int_t ngx_http_write_request_body(ngx_http_request_t *r);
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
16 static ngx_int_t ngx_http_read_discarded_request_body(ngx_http_request_t *r);
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
17 static ngx_int_t ngx_http_discard_request_body_filter(ngx_http_request_t *r,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
18 ngx_buf_t *b);
438
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
19 static ngx_int_t ngx_http_test_expect(ngx_http_request_t *r);
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
20
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
21 static ngx_int_t ngx_http_request_body_filter(ngx_http_request_t *r,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
22 ngx_chain_t *in);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
23 static ngx_int_t ngx_http_request_body_length_filter(ngx_http_request_t *r,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
24 ngx_chain_t *in);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
25 static ngx_int_t ngx_http_request_body_chunked_filter(ngx_http_request_t *r,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
26 ngx_chain_t *in);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
27 static ngx_int_t ngx_http_request_body_save_filter(ngx_http_request_t *r,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
28 ngx_chain_t *in);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
29
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
30
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
31 ngx_int_t
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
32 ngx_http_read_client_request_body(ngx_http_request_t *r,
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
33 ngx_http_client_body_handler_pt post_handler)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34 {
212
56688ed172c8 nginx 0.3.53
Igor Sysoev <http://sysoev.ru>
parents: 186
diff changeset
35 size_t preread;
56688ed172c8 nginx 0.3.53
Igor Sysoev <http://sysoev.ru>
parents: 186
diff changeset
36 ssize_t size;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
37 ngx_int_t rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
38 ngx_chain_t out;
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
39 ngx_http_request_body_t *rb;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
40 ngx_http_core_loc_conf_t *clcf;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
41
518
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 438
diff changeset
42 r->main->count++;
86dad910eeb6 nginx 0.8.11
Igor Sysoev <http://sysoev.ru>
parents: 438
diff changeset
43
86
962c43960644 nginx 0.1.43
Igor Sysoev <http://sysoev.ru>
parents: 76
diff changeset
44 if (r->request_body || r->discard_body) {
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
45 post_handler(r);
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
46 return NGX_OK;
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
47 }
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
48
438
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
49 if (ngx_http_test_expect(r) != NGX_OK) {
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
50 rc = NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
51 goto done;
438
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
52 }
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
53
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
54 rb = ngx_pcalloc(r->pool, sizeof(ngx_http_request_body_t));
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
55 if (rb == NULL) {
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
56 rc = NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
57 goto done;
238
a528ae0fe909 nginx 0.4.4
Igor Sysoev <http://sysoev.ru>
parents: 230
diff changeset
58 }
a528ae0fe909 nginx 0.4.4
Igor Sysoev <http://sysoev.ru>
parents: 230
diff changeset
59
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
60 /*
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
61 * set by ngx_pcalloc():
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
62 *
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
63 * rb->bufs = NULL;
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
64 * rb->buf = NULL;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
65 * rb->free = NULL;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
66 * rb->busy = NULL;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
67 * rb->chunked = NULL;
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
68 */
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
69
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
70 rb->rest = -1;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
71 rb->post_handler = post_handler;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
72
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
73 r->request_body = rb;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
74
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
75 if (r->headers_in.content_length_n < 0 && !r->headers_in.chunked) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
76 post_handler(r);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
77 return NGX_OK;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
78 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
79
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
80 preread = r->header_in->last - r->header_in->pos;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
82 if (preread) {
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84 /* there is the pre-read part of the request body */
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
85
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
86 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
87 "http client request body preread %uz", preread);
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
88
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
89 out.buf = r->header_in;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
90 out.next = NULL;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
91
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
92 rc = ngx_http_request_body_filter(r, &out);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
93
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
94 if (rc != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
95 goto done;
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
96 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
97
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
98 r->request_length += preread - (r->header_in->last - r->header_in->pos);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
99
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
100 if (!r->headers_in.chunked
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
101 && rb->rest > 0
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
102 && rb->rest <= (off_t) (r->header_in->end - r->header_in->last))
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
103 {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
104 /* the whole request body may be placed in r->header_in */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
105
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
106 rb->buf = r->header_in;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
107 r->read_event_handler = ngx_http_read_client_request_body_handler;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
108 r->write_event_handler = ngx_http_request_empty_handler;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
109
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
110 rc = ngx_http_do_read_client_request_body(r);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
111 goto done;
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
112 }
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
113
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
114 } else {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
115 /* set rb->rest */
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
116
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
117 if (ngx_http_request_body_filter(r, NULL) != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
118 rc = NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
119 goto done;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
120 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
121 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
122
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
123 if (rb->rest == 0) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
124 /* the whole request body was pre-read */
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
125
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
126 if (r->request_body_in_file_only) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
127 if (ngx_http_write_request_body(r) != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
128 rc = NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
129 goto done;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
130 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
131 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
132
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
133 post_handler(r);
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
134
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
135 return NGX_OK;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
136 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
137
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
138 if (rb->rest < 0) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
139 ngx_log_error(NGX_LOG_ALERT, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
140 "negative request body rest");
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
141 rc = NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
142 goto done;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
143 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
144
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
145 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
146
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
147 size = clcf->client_body_buffer_size;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
148 size += size >> 2;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
149
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
150 /* TODO: honor r->request_body_in_single_buf */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
151
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
152 if (!r->headers_in.chunked && rb->rest < size) {
212
56688ed172c8 nginx 0.3.53
Igor Sysoev <http://sysoev.ru>
parents: 186
diff changeset
153 size = (ssize_t) rb->rest;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
154
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
155 if (r->request_body_in_single_buf) {
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
156 size += preread;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
157 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
158
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
159 } else {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
160 size = clcf->client_body_buffer_size;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
161 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
162
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
163 rb->buf = ngx_create_temp_buf(r->pool, size);
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
164 if (rb->buf == NULL) {
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
165 rc = NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
166 goto done;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
167 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
168
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
169 r->read_event_handler = ngx_http_read_client_request_body_handler;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
170 r->write_event_handler = ngx_http_request_empty_handler;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
171
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
172 rc = ngx_http_do_read_client_request_body(r);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
173
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
174 done:
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
175
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
176 if (rc >= NGX_HTTP_SPECIAL_RESPONSE) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
177 r->main->count--;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
178 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
179
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
180 return rc;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
181 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
182
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
183
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
184 static void
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
185 ngx_http_read_client_request_body_handler(ngx_http_request_t *r)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
186 {
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
187 ngx_int_t rc;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
188
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
189 if (r->connection->read->timedout) {
126
df17fbafec8f nginx 0.3.10
Igor Sysoev <http://sysoev.ru>
parents: 122
diff changeset
190 r->connection->timedout = 1;
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 276
diff changeset
191 ngx_http_finalize_request(r, NGX_HTTP_REQUEST_TIME_OUT);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
192 return;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
193 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
194
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
195 rc = ngx_http_do_read_client_request_body(r);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
196
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
197 if (rc >= NGX_HTTP_SPECIAL_RESPONSE) {
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 276
diff changeset
198 ngx_http_finalize_request(r, rc);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
199 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
200 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
201
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
202
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
203 static ngx_int_t
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
204 ngx_http_do_read_client_request_body(ngx_http_request_t *r)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
205 {
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
206 off_t rest;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
207 size_t size;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
208 ssize_t n;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
209 ngx_int_t rc;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
210 ngx_buf_t *b;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
211 ngx_chain_t *cl, out;
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
212 ngx_connection_t *c;
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
213 ngx_http_request_body_t *rb;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
214 ngx_http_core_loc_conf_t *clcf;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
215
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
216 c = r->connection;
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
217 rb = r->request_body;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
218
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
219 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, c->log, 0,
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
220 "http read client request body");
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
221
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
222 for ( ;; ) {
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
223 for ( ;; ) {
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
224 if (rb->buf->last == rb->buf->end) {
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
225
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
226 /* pass buffer to request body filter chain */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
227
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
228 out.buf = rb->buf;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
229 out.next = NULL;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
230
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
231 rc = ngx_http_request_body_filter(r, &out);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
232
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
233 if (rc != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
234 return rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
235 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
236
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
237 /* write to file */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
238
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
239 if (ngx_http_write_request_body(r) != NGX_OK) {
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
240 return NGX_HTTP_INTERNAL_SERVER_ERROR;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
241 }
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
242
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
243 /* update chains */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
244
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
245 rc = ngx_http_request_body_filter(r, NULL);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
246
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
247 if (rc != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
248 return rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
249 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
250
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
251 if (rb->busy != NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
252 return NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
253 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
254
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
255 rb->buf->pos = rb->buf->start;
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
256 rb->buf->last = rb->buf->start;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
257 }
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
258
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
259 size = rb->buf->end - rb->buf->last;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
260 rest = rb->rest - (rb->buf->last - rb->buf->pos);
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
261
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
262 if ((off_t) size > rest) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
263 size = (size_t) rest;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
264 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
265
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
266 n = c->recv(c, rb->buf->last, size);
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
267
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
268 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
269 "http client request body recv %z", n);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
270
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
271 if (n == NGX_AGAIN) {
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
272 break;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
273 }
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
274
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
275 if (n == 0) {
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
276 ngx_log_error(NGX_LOG_INFO, c->log, 0,
672
f41d4b305d22 nginx 1.2.0
Igor Sysoev <http://sysoev.ru>
parents: 660
diff changeset
277 "client prematurely closed connection");
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
278 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
279
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
280 if (n == 0 || n == NGX_ERROR) {
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
281 c->error = 1;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
282 return NGX_HTTP_BAD_REQUEST;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
283 }
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
284
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
285 rb->buf->last += n;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
286 r->request_length += n;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
287
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
288 if (n == rest) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
289 /* pass buffer to request body filter chain */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
290
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
291 out.buf = rb->buf;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
292 out.next = NULL;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
293
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
294 rc = ngx_http_request_body_filter(r, &out);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
295
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
296 if (rc != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
297 return rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
298 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
299 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
300
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
301 if (rb->rest == 0) {
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
302 break;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
303 }
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
304
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
305 if (rb->buf->last < rb->buf->end) {
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
306 break;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
307 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
308 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
309
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
310 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
286
5bef04fc3fd5 nginx 0.5.13
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
311 "http client request body rest %O", rb->rest);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
312
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
313 if (rb->rest == 0) {
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
314 break;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
315 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
316
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
317 if (!c->read->ready) {
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
318 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
319 ngx_add_timer(c->read, clcf->client_body_timeout);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
320
430
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 406
diff changeset
321 if (ngx_handle_read_event(c->read, 0) != NGX_OK) {
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
322 return NGX_HTTP_INTERNAL_SERVER_ERROR;
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
323 }
122
d25a1d6034f1 nginx 0.3.8
Igor Sysoev <http://sysoev.ru>
parents: 86
diff changeset
324
256
2e9c57a5e50a nginx 0.4.13
Igor Sysoev <http://sysoev.ru>
parents: 238
diff changeset
325 return NGX_AGAIN;
122
d25a1d6034f1 nginx 0.3.8
Igor Sysoev <http://sysoev.ru>
parents: 86
diff changeset
326 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
327 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
328
122
d25a1d6034f1 nginx 0.3.8
Igor Sysoev <http://sysoev.ru>
parents: 86
diff changeset
329 if (c->read->timer_set) {
d25a1d6034f1 nginx 0.3.8
Igor Sysoev <http://sysoev.ru>
parents: 86
diff changeset
330 ngx_del_timer(c->read);
d25a1d6034f1 nginx 0.3.8
Igor Sysoev <http://sysoev.ru>
parents: 86
diff changeset
331 }
d25a1d6034f1 nginx 0.3.8
Igor Sysoev <http://sysoev.ru>
parents: 86
diff changeset
332
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
333 if (rb->temp_file || r->request_body_in_file_only) {
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
334
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
335 /* save the last part */
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
336
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
337 if (ngx_http_write_request_body(r) != NGX_OK) {
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
338 return NGX_HTTP_INTERNAL_SERVER_ERROR;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
339 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
340
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
341 cl = ngx_chain_get_free_buf(r->pool, &rb->free);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
342 if (cl == NULL) {
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
343 return NGX_HTTP_INTERNAL_SERVER_ERROR;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
344 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
345
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
346 b = cl->buf;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
347
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
348 ngx_memzero(b, sizeof(ngx_buf_t));
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
349
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
350 b->in_file = 1;
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
351 b->file_last = rb->temp_file->file.offset;
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
352 b->file = &rb->temp_file->file;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
353
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
354 rb->bufs = cl;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
355 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
356
636
943566b4d82e nginx 1.1.2
Igor Sysoev <http://sysoev.ru>
parents: 634
diff changeset
357 r->read_event_handler = ngx_http_block_reading;
943566b4d82e nginx 1.1.2
Igor Sysoev <http://sysoev.ru>
parents: 634
diff changeset
358
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 24
diff changeset
359 rb->post_handler(r);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
360
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
361 return NGX_OK;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
362 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
363
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
364
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
365 static ngx_int_t
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
366 ngx_http_write_request_body(ngx_http_request_t *r)
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
367 {
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
368 ssize_t n;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
369 ngx_chain_t *cl;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
370 ngx_temp_file_t *tf;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
371 ngx_http_request_body_t *rb;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
372 ngx_http_core_loc_conf_t *clcf;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
373
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
374 rb = r->request_body;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
375
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
376 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
377 "http write client request body, bufs %p", rb->bufs);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
378
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
379 if (rb->temp_file == NULL) {
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
380 tf = ngx_pcalloc(r->pool, sizeof(ngx_temp_file_t));
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
381 if (tf == NULL) {
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
382 return NGX_ERROR;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
383 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
384
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
385 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
386
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
387 tf->file.fd = NGX_INVALID_FILE;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
388 tf->file.log = r->connection->log;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
389 tf->path = clcf->client_body_temp_path;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
390 tf->pool = r->pool;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
391 tf->warn = "a client request body is buffered to a temporary file";
186
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
392 tf->log_level = r->request_body_file_log_level;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
393 tf->persistent = r->request_body_in_persistent_file;
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 276
diff changeset
394 tf->clean = r->request_body_in_clean_file;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
395
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
396 if (r->request_body_file_group_access) {
276
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 256
diff changeset
397 tf->access = 0660;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
398 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
399
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
400 rb->temp_file = tf;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
401
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
402 if (rb->bufs == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
403 /* empty body with r->request_body_in_file_only */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
404
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
405 if (ngx_create_temp_file(&tf->file, tf->path, tf->pool,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
406 tf->persistent, tf->clean, tf->access)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
407 != NGX_OK)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
408 {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
409 return NGX_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
410 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
411
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
412 return NGX_OK;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
413 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
414 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
415
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
416 if (rb->bufs == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
417 return NGX_OK;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
418 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
419
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
420 n = ngx_write_chain_to_temp_file(rb->temp_file, rb->bufs);
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
421
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
422 /* TODO: n == 0 or not complete and level event */
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
423
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
424 if (n == NGX_ERROR) {
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
425 return NGX_ERROR;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
426 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
427
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
428 rb->temp_file->offset += n;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
429
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
430 /* mark all buffers as written */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
431
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
432 for (cl = rb->bufs; cl; cl = cl->next) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
433 cl->buf->pos = cl->buf->last;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
434 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
435
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
436 rb->bufs = NULL;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
437
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
438 return NGX_OK;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
439 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
440
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
441
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
442 ngx_int_t
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
443 ngx_http_discard_request_body(ngx_http_request_t *r)
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
444 {
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
445 ssize_t size;
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
446 ngx_int_t rc;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
447 ngx_event_t *rev;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
448
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
449 if (r != r->main || r->discard_body || r->request_body) {
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
450 return NGX_OK;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
451 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
452
438
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
453 if (ngx_http_test_expect(r) != NGX_OK) {
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
454 return NGX_HTTP_INTERNAL_SERVER_ERROR;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
455 }
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
456
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
457 rev = r->connection->read;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
458
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
459 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, rev->log, 0, "http set discard body");
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
460
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
461 if (rev->timer_set) {
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
462 ngx_del_timer(rev);
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
463 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
464
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
465 if (r->headers_in.content_length_n <= 0 && !r->headers_in.chunked) {
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
466 return NGX_OK;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
467 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
468
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
469 size = r->header_in->last - r->header_in->pos;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
470
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
471 if (size || r->headers_in.chunked) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
472 rc = ngx_http_discard_request_body_filter(r, r->header_in);
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
473
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
474 if (rc != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
475 return rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
476 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
477
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
478 if (r->headers_in.content_length_n == 0) {
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
479 return NGX_OK;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
480 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
481 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
482
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
483 rc = ngx_http_read_discarded_request_body(r);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
484
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
485 if (rc == NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
486 r->lingering_close = 0;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
487 return NGX_OK;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
488 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
489
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
490 if (rc >= NGX_HTTP_SPECIAL_RESPONSE) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
491 return rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
492 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
493
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
494 /* rc == NGX_AGAIN */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
495
538
1dcf6adad484 nginx 0.8.21
Igor Sysoev <http://sysoev.ru>
parents: 532
diff changeset
496 r->read_event_handler = ngx_http_discarded_request_body_handler;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
497
430
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 406
diff changeset
498 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
499 return NGX_HTTP_INTERNAL_SERVER_ERROR;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
500 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
501
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
502 r->count++;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
503 r->discard_body = 1;
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
504
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
505 return NGX_OK;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
506 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
507
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
508
538
1dcf6adad484 nginx 0.8.21
Igor Sysoev <http://sysoev.ru>
parents: 532
diff changeset
509 void
1dcf6adad484 nginx 0.8.21
Igor Sysoev <http://sysoev.ru>
parents: 532
diff changeset
510 ngx_http_discarded_request_body_handler(ngx_http_request_t *r)
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
511 {
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
512 ngx_int_t rc;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
513 ngx_msec_t timer;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
514 ngx_event_t *rev;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
515 ngx_connection_t *c;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
516 ngx_http_core_loc_conf_t *clcf;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
517
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
518 c = r->connection;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
519 rev = c->read;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
520
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
521 if (rev->timedout) {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
522 c->timedout = 1;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
523 c->error = 1;
538
1dcf6adad484 nginx 0.8.21
Igor Sysoev <http://sysoev.ru>
parents: 532
diff changeset
524 ngx_http_finalize_request(r, NGX_ERROR);
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
525 return;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
526 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
527
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
528 if (r->lingering_time) {
346
05693816539c nginx 0.6.17
Igor Sysoev <http://sysoev.ru>
parents: 342
diff changeset
529 timer = (ngx_msec_t) (r->lingering_time - ngx_time());
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
530
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
531 if (timer <= 0) {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
532 r->discard_body = 0;
532
f7ec98e3caeb nginx 0.8.18
Igor Sysoev <http://sysoev.ru>
parents: 530
diff changeset
533 r->lingering_close = 0;
538
1dcf6adad484 nginx 0.8.21
Igor Sysoev <http://sysoev.ru>
parents: 532
diff changeset
534 ngx_http_finalize_request(r, NGX_ERROR);
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
535 return;
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
536 }
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
537
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
538 } else {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
539 timer = 0;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
540 }
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
541
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
542 rc = ngx_http_read_discarded_request_body(r);
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
543
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
544 if (rc == NGX_OK) {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
545 r->discard_body = 0;
532
f7ec98e3caeb nginx 0.8.18
Igor Sysoev <http://sysoev.ru>
parents: 530
diff changeset
546 r->lingering_close = 0;
538
1dcf6adad484 nginx 0.8.21
Igor Sysoev <http://sysoev.ru>
parents: 532
diff changeset
547 ngx_http_finalize_request(r, NGX_DONE);
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
548 return;
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
549 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
550
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
551 if (rc >= NGX_HTTP_SPECIAL_RESPONSE) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
552 c->error = 1;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
553 ngx_http_finalize_request(r, NGX_ERROR);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
554 return;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
555 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
556
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
557 /* rc == NGX_AGAIN */
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
558
430
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 406
diff changeset
559 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
332
3a91bfeffaba nginx 0.6.10
Igor Sysoev <http://sysoev.ru>
parents: 330
diff changeset
560 c->error = 1;
538
1dcf6adad484 nginx 0.8.21
Igor Sysoev <http://sysoev.ru>
parents: 532
diff changeset
561 ngx_http_finalize_request(r, NGX_ERROR);
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
562 return;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
563 }
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
564
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
565 if (timer) {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
566
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
567 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
568
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
569 timer *= 1000;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
570
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
571 if (timer > clcf->lingering_timeout) {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
572 timer = clcf->lingering_timeout;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
573 }
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
574
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
575 ngx_add_timer(rev, timer);
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
576 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
577 }
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
578
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
579
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
580 static ngx_int_t
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
581 ngx_http_read_discarded_request_body(ngx_http_request_t *r)
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
582 {
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
583 size_t size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
584 ssize_t n;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
585 ngx_int_t rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
586 ngx_buf_t b;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
587 u_char buffer[NGX_HTTP_DISCARD_BUFFER_SIZE];
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
588
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
589 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
590 "http read discarded body");
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
591
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
592 ngx_memzero(&b, sizeof(ngx_buf_t));
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
593
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
594 b.temporary = 1;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
595
530
4c5d2c627a6c nginx 0.8.17
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
596 for ( ;; ) {
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
597 if (r->headers_in.content_length_n == 0) {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
598 r->read_event_handler = ngx_http_block_reading;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
599 return NGX_OK;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
600 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
601
530
4c5d2c627a6c nginx 0.8.17
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
602 if (!r->connection->read->ready) {
4c5d2c627a6c nginx 0.8.17
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
603 return NGX_AGAIN;
4c5d2c627a6c nginx 0.8.17
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
604 }
4c5d2c627a6c nginx 0.8.17
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
605
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
606 size = (size_t) ngx_min(r->headers_in.content_length_n,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
607 NGX_HTTP_DISCARD_BUFFER_SIZE);
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
608
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
609 n = r->connection->recv(r->connection, buffer, size);
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
610
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
611 if (n == NGX_ERROR) {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
612 r->connection->error = 1;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
613 return NGX_OK;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
614 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
615
326
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
616 if (n == NGX_AGAIN) {
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
617 return NGX_AGAIN;
9fc4ab6673f9 nginx 0.6.7
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
618 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
619
330
5e3b425174f6 nginx 0.6.9
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
620 if (n == 0) {
5e3b425174f6 nginx 0.6.9
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
621 return NGX_OK;
5e3b425174f6 nginx 0.6.9
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
622 }
5e3b425174f6 nginx 0.6.9
Igor Sysoev <http://sysoev.ru>
parents: 326
diff changeset
623
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
624 b.pos = buffer;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
625 b.last = buffer + n;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
626
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
627 rc = ngx_http_discard_request_body_filter(r, &b);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
628
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
629 if (rc != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
630 return rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
631 }
530
4c5d2c627a6c nginx 0.8.17
Igor Sysoev <http://sysoev.ru>
parents: 524
diff changeset
632 }
182
13710a1813ad nginx 0.3.38
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
633 }
438
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
634
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
635
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
636 static ngx_int_t
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
637 ngx_http_discard_request_body_filter(ngx_http_request_t *r, ngx_buf_t *b)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
638 {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
639 size_t size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
640 ngx_int_t rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
641 ngx_http_request_body_t *rb;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
642
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
643 if (r->headers_in.chunked) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
644
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
645 rb = r->request_body;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
646
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
647 if (rb == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
648
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
649 rb = ngx_pcalloc(r->pool, sizeof(ngx_http_request_body_t));
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
650 if (rb == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
651 return NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
652 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
653
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
654 rb->chunked = ngx_pcalloc(r->pool, sizeof(ngx_http_chunked_t));
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
655 if (rb->chunked == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
656 return NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
657 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
658
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
659 r->request_body = rb;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
660 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
661
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
662 for ( ;; ) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
663
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
664 rc = ngx_http_parse_chunked(r, b, rb->chunked);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
665
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
666 if (rc == NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
667
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
668 /* a chunk has been parsed successfully */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
669
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
670 size = b->last - b->pos;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
671
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
672 if ((off_t) size > rb->chunked->size) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
673 b->pos += rb->chunked->size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
674 rb->chunked->size = 0;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
675
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
676 } else {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
677 rb->chunked->size -= size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
678 b->pos = b->last;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
679 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
680
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
681 continue;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
682 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
683
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
684 if (rc == NGX_DONE) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
685
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
686 /* a whole response has been parsed successfully */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
687
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
688 r->headers_in.content_length_n = 0;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
689 break;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
690 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
691
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
692 if (rc == NGX_AGAIN) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
693
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
694 /* set amount of data we want to see next time */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
695
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
696 r->headers_in.content_length_n = rb->chunked->length;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
697 break;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
698 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
699
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
700 /* invalid */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
701
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
702 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
703 "client sent invalid chunked body");
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
704
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
705 return NGX_HTTP_BAD_REQUEST;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
706 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
707
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
708 } else {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
709 size = b->last - b->pos;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
710
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
711 if ((off_t) size > r->headers_in.content_length_n) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
712 b->pos += r->headers_in.content_length_n;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
713 r->headers_in.content_length_n = 0;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
714
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
715 } else {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
716 b->pos = b->last;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
717 r->headers_in.content_length_n -= size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
718 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
719 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
720
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
721 return NGX_OK;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
722 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
723
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
724
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
725 static ngx_int_t
438
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
726 ngx_http_test_expect(ngx_http_request_t *r)
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
727 {
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
728 ngx_int_t n;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
729 ngx_str_t *expect;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
730
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
731 if (r->expect_tested
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
732 || r->headers_in.expect == NULL
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
733 || r->http_version < NGX_HTTP_VERSION_11)
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
734 {
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
735 return NGX_OK;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
736 }
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
737
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
738 r->expect_tested = 1;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
739
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
740 expect = &r->headers_in.expect->value;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
741
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
742 if (expect->len != sizeof("100-continue") - 1
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
743 || ngx_strncasecmp(expect->data, (u_char *) "100-continue",
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
744 sizeof("100-continue") - 1)
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
745 != 0)
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
746 {
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
747 return NGX_OK;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
748 }
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
749
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
750 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
751 "send 100 Continue");
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
752
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
753 n = r->connection->send(r->connection,
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
754 (u_char *) "HTTP/1.1 100 Continue" CRLF CRLF,
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
755 sizeof("HTTP/1.1 100 Continue" CRLF CRLF) - 1);
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
756
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
757 if (n == sizeof("HTTP/1.1 100 Continue" CRLF CRLF) - 1) {
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
758 return NGX_OK;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
759 }
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
760
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
761 /* we assume that such small packet should be send successfully */
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
762
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
763 return NGX_ERROR;
ce4f9ff90bfa nginx 0.7.31
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
764 }
692
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
765
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
766
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
767 static ngx_int_t
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
768 ngx_http_request_body_filter(ngx_http_request_t *r, ngx_chain_t *in)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
769 {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
770 if (r->headers_in.chunked) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
771 return ngx_http_request_body_chunked_filter(r, in);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
772
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
773 } else {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
774 return ngx_http_request_body_length_filter(r, in);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
775 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
776 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
777
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
778
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
779 static ngx_int_t
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
780 ngx_http_request_body_length_filter(ngx_http_request_t *r, ngx_chain_t *in)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
781 {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
782 size_t size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
783 ngx_int_t rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
784 ngx_buf_t *b;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
785 ngx_chain_t *cl, *tl, *out, **ll;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
786 ngx_http_request_body_t *rb;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
787
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
788 rb = r->request_body;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
789
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
790 if (rb->rest == -1) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
791 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
792 "http request body content length filter");
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
793
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
794 rb->rest = r->headers_in.content_length_n;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
795 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
796
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
797 out = NULL;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
798 ll = &out;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
799
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
800 for (cl = in; cl; cl = cl->next) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
801
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
802 tl = ngx_chain_get_free_buf(r->pool, &rb->free);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
803 if (tl == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
804 return NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
805 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
806
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
807 b = tl->buf;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
808
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
809 ngx_memzero(b, sizeof(ngx_buf_t));
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
810
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
811 b->temporary = 1;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
812 b->tag = (ngx_buf_tag_t) &ngx_http_read_client_request_body;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
813 b->start = cl->buf->start;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
814 b->pos = cl->buf->pos;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
815 b->last = cl->buf->last;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
816 b->end = cl->buf->end;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
817
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
818 size = cl->buf->last - cl->buf->pos;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
819
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
820 if ((off_t) size < rb->rest) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
821 cl->buf->pos = cl->buf->last;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
822 rb->rest -= size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
823
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
824 } else {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
825 cl->buf->pos += rb->rest;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
826 rb->rest = 0;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
827 b->last = cl->buf->pos;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
828 b->last_buf = 1;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
829 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
830
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
831 *ll = tl;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
832 ll = &tl->next;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
833 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
834
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
835 rc = ngx_http_request_body_save_filter(r, out);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
836
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
837 ngx_chain_update_chains(r->pool, &rb->free, &rb->busy, &out,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
838 (ngx_buf_tag_t) &ngx_http_read_client_request_body);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
839
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
840 return rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
841 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
842
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
843
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
844 static ngx_int_t
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
845 ngx_http_request_body_chunked_filter(ngx_http_request_t *r, ngx_chain_t *in)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
846 {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
847 size_t size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
848 ngx_int_t rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
849 ngx_buf_t *b;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
850 ngx_chain_t *cl, *out, *tl, **ll;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
851 ngx_http_request_body_t *rb;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
852 ngx_http_core_loc_conf_t *clcf;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
853
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
854 rb = r->request_body;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
855
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
856 if (rb->rest == -1) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
857
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
858 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
859 "http request body chunked filter");
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
860
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
861 rb->chunked = ngx_pcalloc(r->pool, sizeof(ngx_http_chunked_t));
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
862 if (rb->chunked == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
863 return NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
864 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
865
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
866 r->headers_in.content_length_n = 0;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
867 rb->rest = 3;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
868 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
869
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
870 out = NULL;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
871 ll = &out;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
872
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
873 for (cl = in; cl; cl = cl->next) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
874
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
875 for ( ;; ) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
876
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
877 ngx_log_debug7(NGX_LOG_DEBUG_EVENT, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
878 "http body chunked buf "
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
879 "t:%d f:%d %p, pos %p, size: %z file: %O, size: %z",
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
880 cl->buf->temporary, cl->buf->in_file,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
881 cl->buf->start, cl->buf->pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
882 cl->buf->last - cl->buf->pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
883 cl->buf->file_pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
884 cl->buf->file_last - cl->buf->file_pos);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
885
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
886 rc = ngx_http_parse_chunked(r, cl->buf, rb->chunked);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
887
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
888 if (rc == NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
889
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
890 /* a chunk has been parsed successfully */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
891
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
892 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
893
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
894 if (clcf->client_max_body_size
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
895 && clcf->client_max_body_size
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
896 < r->headers_in.content_length_n + rb->chunked->size)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
897 {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
898 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
899 "client intended to send too large chunked "
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
900 "body: %O bytes",
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
901 r->headers_in.content_length_n
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
902 + rb->chunked->size);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
903
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
904 r->lingering_close = 1;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
905
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
906 return NGX_HTTP_REQUEST_ENTITY_TOO_LARGE;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
907 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
908
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
909 tl = ngx_chain_get_free_buf(r->pool, &rb->free);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
910 if (tl == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
911 return NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
912 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
913
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
914 b = tl->buf;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
915
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
916 ngx_memzero(b, sizeof(ngx_buf_t));
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
917
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
918 b->temporary = 1;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
919 b->tag = (ngx_buf_tag_t) &ngx_http_read_client_request_body;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
920 b->start = cl->buf->start;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
921 b->pos = cl->buf->pos;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
922 b->last = cl->buf->last;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
923 b->end = cl->buf->end;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
924
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
925 *ll = tl;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
926 ll = &tl->next;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
927
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
928 size = cl->buf->last - cl->buf->pos;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
929
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
930 if ((off_t) size > rb->chunked->size) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
931 cl->buf->pos += rb->chunked->size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
932 r->headers_in.content_length_n += rb->chunked->size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
933 rb->chunked->size = 0;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
934
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
935 } else {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
936 rb->chunked->size -= size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
937 r->headers_in.content_length_n += size;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
938 cl->buf->pos = cl->buf->last;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
939 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
940
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
941 b->last = cl->buf->pos;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
942
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
943 continue;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
944 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
945
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
946 if (rc == NGX_DONE) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
947
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
948 /* a whole response has been parsed successfully */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
949
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
950 rb->rest = 0;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
951
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
952 tl = ngx_chain_get_free_buf(r->pool, &rb->free);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
953 if (tl == NULL) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
954 return NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
955 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
956
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
957 b = tl->buf;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
958
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
959 ngx_memzero(b, sizeof(ngx_buf_t));
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
960
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
961 b->last_buf = 1;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
962
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
963 *ll = tl;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
964 ll = &tl->next;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
965
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
966 break;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
967 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
968
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
969 if (rc == NGX_AGAIN) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
970
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
971 /* set rb->rest, amount of data we want to see next time */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
972
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
973 rb->rest = rb->chunked->length;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
974
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
975 break;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
976 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
977
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
978 /* invalid */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
979
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
980 ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
981 "client sent invalid chunked body");
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
982
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
983 return NGX_HTTP_BAD_REQUEST;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
984 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
985 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
986
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
987 rc = ngx_http_request_body_save_filter(r, out);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
988
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
989 ngx_chain_update_chains(r->pool, &rb->free, &rb->busy, &out,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
990 (ngx_buf_tag_t) &ngx_http_read_client_request_body);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
991
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
992 return rc;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
993 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
994
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
995
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
996 static ngx_int_t
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
997 ngx_http_request_body_save_filter(ngx_http_request_t *r, ngx_chain_t *in)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
998 {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
999 #if (NGX_DEBUG)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1000 ngx_chain_t *cl;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1001 #endif
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1002 ngx_http_request_body_t *rb;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1003
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1004 rb = r->request_body;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1005
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1006 #if (NGX_DEBUG)
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1007
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1008 for (cl = rb->bufs; cl; cl = cl->next) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1009 ngx_log_debug7(NGX_LOG_DEBUG_EVENT, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1010 "http body old buf t:%d f:%d %p, pos %p, size: %z "
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1011 "file: %O, size: %z",
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1012 cl->buf->temporary, cl->buf->in_file,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1013 cl->buf->start, cl->buf->pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1014 cl->buf->last - cl->buf->pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1015 cl->buf->file_pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1016 cl->buf->file_last - cl->buf->file_pos);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1017 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1018
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1019 for (cl = in; cl; cl = cl->next) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1020 ngx_log_debug7(NGX_LOG_DEBUG_EVENT, r->connection->log, 0,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1021 "http body new buf t:%d f:%d %p, pos %p, size: %z "
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1022 "file: %O, size: %z",
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1023 cl->buf->temporary, cl->buf->in_file,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1024 cl->buf->start, cl->buf->pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1025 cl->buf->last - cl->buf->pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1026 cl->buf->file_pos,
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1027 cl->buf->file_last - cl->buf->file_pos);
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1028 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1029
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1030 #endif
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1031
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1032 /* TODO: coalesce neighbouring buffers */
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1033
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1034 if (ngx_chain_add_copy(r->pool, &rb->bufs, in) != NGX_OK) {
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1035 return NGX_HTTP_INTERNAL_SERVER_ERROR;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1036 }
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1037
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1038 return NGX_OK;
6db6e93f55ee nginx 1.3.9
Igor Sysoev <http://sysoev.ru>
parents: 672
diff changeset
1039 }