annotate src/http/ngx_http_request.c @ 5091:d3e256c67d6d

SSL: do not treat SSL handshake as request. The request object will not be created until SSL handshake is complete. This simplifies adding another connection handler that does not need request object right after handshake (e.g., SPDY). There are also a few more intentional effects: - the "client_header_buffer_size" directive will be taken from the server configuration that was negotiated by SNI; - SSL handshake errors and timeouts are not logged into access log as bad requests; - ngx_ssl_create_connection() is not called until the first byte of ClientHello message was received. This also decreases memory consumption if plain HTTP request is sent to SSL socket.
author Valentin Bartenev <vbart@nginx.com>
date Wed, 27 Feb 2013 17:21:21 +0000
parents 9db95b275755
children c4d3310574e0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1
441
da8c5707af39 nginx-0.1.0-2004-09-28-12:34:51 import; set copyright and remove unused files
Igor Sysoev <igor@sysoev.ru>
parents: 439
diff changeset
2 /*
444
42d11f017717 nginx-0.1.0-2004-09-29-20:00:49 import; remove years from copyright
Igor Sysoev <igor@sysoev.ru>
parents: 441
diff changeset
3 * Copyright (C) Igor Sysoev
4412
d620f497c50f Copyright updated.
Maxim Konovalov <maxim@nginx.com>
parents: 4313
diff changeset
4 * Copyright (C) Nginx, Inc.
441
da8c5707af39 nginx-0.1.0-2004-09-28-12:34:51 import; set copyright and remove unused files
Igor Sysoev <igor@sysoev.ru>
parents: 439
diff changeset
5 */
da8c5707af39 nginx-0.1.0-2004-09-28-12:34:51 import; set copyright and remove unused files
Igor Sysoev <igor@sysoev.ru>
parents: 439
diff changeset
6
da8c5707af39 nginx-0.1.0-2004-09-28-12:34:51 import; set copyright and remove unused files
Igor Sysoev <igor@sysoev.ru>
parents: 439
diff changeset
7
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
9 #include <ngx_core.h>
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
10 #include <ngx_http.h>
8
708f8bb772ec nginx-0.0.1-2002-09-02-18:48:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 7
diff changeset
11
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
12
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
13 static void ngx_http_init_request(ngx_event_t *ev);
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
14 static void ngx_http_process_request_line(ngx_event_t *rev);
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
15 static void ngx_http_process_request_headers(ngx_event_t *rev);
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
16 static ssize_t ngx_http_read_request_header(ngx_http_request_t *r);
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
17 static ngx_int_t ngx_http_alloc_large_header_buffer(ngx_http_request_t *r,
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
18 ngx_uint_t request_line);
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
19
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
20 static ngx_int_t ngx_http_process_header_line(ngx_http_request_t *r,
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
21 ngx_table_elt_t *h, ngx_uint_t offset);
523
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
22 static ngx_int_t ngx_http_process_unique_header_line(ngx_http_request_t *r,
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
23 ngx_table_elt_t *h, ngx_uint_t offset);
5084
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
24 static ngx_int_t ngx_http_process_multi_header_lines(ngx_http_request_t *r,
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
25 ngx_table_elt_t *h, ngx_uint_t offset);
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
26 static ngx_int_t ngx_http_process_host(ngx_http_request_t *r,
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
27 ngx_table_elt_t *h, ngx_uint_t offset);
1467
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
28 static ngx_int_t ngx_http_process_connection(ngx_http_request_t *r,
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
29 ngx_table_elt_t *h, ngx_uint_t offset);
2004
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
30 static ngx_int_t ngx_http_process_user_agent(ngx_http_request_t *r,
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
31 ngx_table_elt_t *h, ngx_uint_t offset);
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
32
356
2e3cbc1bbe3c nginx-0.0.7-2004-06-16-19:32:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 346
diff changeset
33 static ngx_int_t ngx_http_process_request_header(ngx_http_request_t *r);
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
34 static void ngx_http_process_request(ngx_http_request_t *r);
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
35 static ngx_int_t ngx_http_validate_host(ngx_str_t *host, ngx_pool_t *pool,
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
36 ngx_uint_t alloc);
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
37 static ngx_int_t ngx_http_set_virtual_server(ngx_http_request_t *r,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
38 ngx_str_t *host);
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
39 static ngx_int_t ngx_http_find_virtual_server(ngx_connection_t *c,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
40 ngx_http_virtual_names_t *virtual_names, ngx_str_t *host,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
41 ngx_http_request_t *r, ngx_http_core_srv_conf_t **cscfp);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
42
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
43 static void ngx_http_request_handler(ngx_event_t *ev);
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
44 static void ngx_http_terminate_request(ngx_http_request_t *r, ngx_int_t rc);
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
45 static void ngx_http_terminate_handler(ngx_http_request_t *r);
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
46 static void ngx_http_finalize_connection(ngx_http_request_t *r);
525
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
47 static ngx_int_t ngx_http_set_write_handler(ngx_http_request_t *r);
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
48 static void ngx_http_writer(ngx_http_request_t *r);
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
49 static void ngx_http_request_finalizer(ngx_http_request_t *r);
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
50
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
51 static void ngx_http_set_keepalive(ngx_http_request_t *r);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
52 static void ngx_http_keepalive_handler(ngx_event_t *ev);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
53 static void ngx_http_set_lingering_close(ngx_http_request_t *r);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
54 static void ngx_http_lingering_close_handler(ngx_event_t *ev);
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
55 static ngx_int_t ngx_http_post_action(ngx_http_request_t *r);
531
c3bd8cdabb8f nginx-0.1.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 527
diff changeset
56 static void ngx_http_close_request(ngx_http_request_t *r, ngx_int_t error);
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
57 static void ngx_http_free_request(ngx_http_request_t *r, ngx_int_t error);
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
58 static void ngx_http_log_request(ngx_http_request_t *r);
531
c3bd8cdabb8f nginx-0.1.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 527
diff changeset
59 static void ngx_http_close_connection(ngx_connection_t *c);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
60
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
61 static u_char *ngx_http_log_error(ngx_log_t *log, u_char *buf, size_t len);
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
62 static u_char *ngx_http_log_error_handler(ngx_http_request_t *r,
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
63 ngx_http_request_t *sr, u_char *buf, size_t len);
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
64
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 537
diff changeset
65 #if (NGX_HTTP_SSL)
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 537
diff changeset
66 static void ngx_http_ssl_handshake(ngx_event_t *rev);
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
67 static void ngx_http_ssl_handshake_handler(ngx_connection_t *c);
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 537
diff changeset
68 #endif
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 537
diff changeset
69
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
70
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
71 static char *ngx_http_client_errors[] = {
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
72
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
73 /* NGX_HTTP_PARSE_INVALID_METHOD */
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
74 "client sent invalid method",
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
75
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
76 /* NGX_HTTP_PARSE_INVALID_REQUEST */
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
77 "client sent invalid request",
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
78
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
79 /* NGX_HTTP_PARSE_INVALID_09_METHOD */
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
80 "client sent invalid method in HTTP/0.9 request"
7
b5481d6fbbd4 nginx-0.0.1-2002-08-29-20:59:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 6
diff changeset
81 };
b5481d6fbbd4 nginx-0.0.1-2002-08-29-20:59:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 6
diff changeset
82
b5481d6fbbd4 nginx-0.0.1-2002-08-29-20:59:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 6
diff changeset
83
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
84 ngx_http_header_t ngx_http_headers_in[] = {
2193
1d37b13ef004 fix $r->header_in() for "User-Agent", "Connection", and "Host"
Igor Sysoev <igor@sysoev.ru>
parents: 2137
diff changeset
85 { ngx_string("Host"), offsetof(ngx_http_headers_in_t, host),
1d37b13ef004 fix $r->header_in() for "User-Agent", "Connection", and "Host"
Igor Sysoev <igor@sysoev.ru>
parents: 2137
diff changeset
86 ngx_http_process_host },
1d37b13ef004 fix $r->header_in() for "User-Agent", "Connection", and "Host"
Igor Sysoev <igor@sysoev.ru>
parents: 2137
diff changeset
87
1d37b13ef004 fix $r->header_in() for "User-Agent", "Connection", and "Host"
Igor Sysoev <igor@sysoev.ru>
parents: 2137
diff changeset
88 { ngx_string("Connection"), offsetof(ngx_http_headers_in_t, connection),
1d37b13ef004 fix $r->header_in() for "User-Agent", "Connection", and "Host"
Igor Sysoev <igor@sysoev.ru>
parents: 2137
diff changeset
89 ngx_http_process_connection },
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
90
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
91 { ngx_string("If-Modified-Since"),
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
92 offsetof(ngx_http_headers_in_t, if_modified_since),
1434
0f0ce9a8eee9 If-Modified-Since should be unique header line
Igor Sysoev <igor@sysoev.ru>
parents: 1427
diff changeset
93 ngx_http_process_unique_header_line },
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
94
3814
e6e453203bae "If-Unmodified-Since" support
Igor Sysoev <igor@sysoev.ru>
parents: 3674
diff changeset
95 { ngx_string("If-Unmodified-Since"),
e6e453203bae "If-Unmodified-Since" support
Igor Sysoev <igor@sysoev.ru>
parents: 3674
diff changeset
96 offsetof(ngx_http_headers_in_t, if_unmodified_since),
e6e453203bae "If-Unmodified-Since" support
Igor Sysoev <igor@sysoev.ru>
parents: 3674
diff changeset
97 ngx_http_process_unique_header_line },
e6e453203bae "If-Unmodified-Since" support
Igor Sysoev <igor@sysoev.ru>
parents: 3674
diff changeset
98
4744
5b93a9ac60ed Entity tags: basic support in not modified filter.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4739
diff changeset
99 { ngx_string("If-Match"),
5b93a9ac60ed Entity tags: basic support in not modified filter.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4739
diff changeset
100 offsetof(ngx_http_headers_in_t, if_match),
5b93a9ac60ed Entity tags: basic support in not modified filter.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4739
diff changeset
101 ngx_http_process_unique_header_line },
5b93a9ac60ed Entity tags: basic support in not modified filter.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4739
diff changeset
102
5b93a9ac60ed Entity tags: basic support in not modified filter.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4739
diff changeset
103 { ngx_string("If-None-Match"),
5b93a9ac60ed Entity tags: basic support in not modified filter.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4739
diff changeset
104 offsetof(ngx_http_headers_in_t, if_none_match),
5b93a9ac60ed Entity tags: basic support in not modified filter.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4739
diff changeset
105 ngx_http_process_unique_header_line },
5b93a9ac60ed Entity tags: basic support in not modified filter.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4739
diff changeset
106
2193
1d37b13ef004 fix $r->header_in() for "User-Agent", "Connection", and "Host"
Igor Sysoev <igor@sysoev.ru>
parents: 2137
diff changeset
107 { ngx_string("User-Agent"), offsetof(ngx_http_headers_in_t, user_agent),
1d37b13ef004 fix $r->header_in() for "User-Agent", "Connection", and "Host"
Igor Sysoev <igor@sysoev.ru>
parents: 2137
diff changeset
108 ngx_http_process_user_agent },
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
109
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
110 { ngx_string("Referer"), offsetof(ngx_http_headers_in_t, referer),
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
111 ngx_http_process_header_line },
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
112
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
113 { ngx_string("Content-Length"),
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
114 offsetof(ngx_http_headers_in_t, content_length),
523
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
115 ngx_http_process_unique_header_line },
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
116
479
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
117 { ngx_string("Content-Type"),
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
118 offsetof(ngx_http_headers_in_t, content_type),
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
119 ngx_http_process_header_line },
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
120
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
121 { ngx_string("Range"), offsetof(ngx_http_headers_in_t, range),
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
122 ngx_http_process_header_line },
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
123
1630
9706372f8916 If-Range support
Igor Sysoev <igor@sysoev.ru>
parents: 1585
diff changeset
124 { ngx_string("If-Range"),
9706372f8916 If-Range support
Igor Sysoev <igor@sysoev.ru>
parents: 1585
diff changeset
125 offsetof(ngx_http_headers_in_t, if_range),
9706372f8916 If-Range support
Igor Sysoev <igor@sysoev.ru>
parents: 1585
diff changeset
126 ngx_http_process_unique_header_line },
9706372f8916 If-Range support
Igor Sysoev <igor@sysoev.ru>
parents: 1585
diff changeset
127
581
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
128 { ngx_string("Transfer-Encoding"),
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
129 offsetof(ngx_http_headers_in_t, transfer_encoding),
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
130 ngx_http_process_header_line },
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
131
2067
5657037448d1 the "Expect" header support
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
132 { ngx_string("Expect"),
5657037448d1 the "Expect" header support
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
133 offsetof(ngx_http_headers_in_t, expect),
5657037448d1 the "Expect" header support
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
134 ngx_http_process_unique_header_line },
5657037448d1 the "Expect" header support
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
135
5072
7fa7e60a7f66 Proxy: support for connection upgrade (101 Switching Protocols).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4930
diff changeset
136 { ngx_string("Upgrade"),
7fa7e60a7f66 Proxy: support for connection upgrade (101 Switching Protocols).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4930
diff changeset
137 offsetof(ngx_http_headers_in_t, upgrade),
7fa7e60a7f66 Proxy: support for connection upgrade (101 Switching Protocols).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4930
diff changeset
138 ngx_http_process_header_line },
7fa7e60a7f66 Proxy: support for connection upgrade (101 Switching Protocols).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4930
diff changeset
139
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
140 #if (NGX_HTTP_GZIP)
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
141 { ngx_string("Accept-Encoding"),
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
142 offsetof(ngx_http_headers_in_t, accept_encoding),
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
143 ngx_http_process_header_line },
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
144
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
145 { ngx_string("Via"), offsetof(ngx_http_headers_in_t, via),
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
146 ngx_http_process_header_line },
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
147 #endif
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
148
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
149 { ngx_string("Authorization"),
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
150 offsetof(ngx_http_headers_in_t, authorization),
523
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
151 ngx_http_process_unique_header_line },
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
152
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
153 { ngx_string("Keep-Alive"), offsetof(ngx_http_headers_in_t, keep_alive),
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
154 ngx_http_process_header_line },
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
155
4697
09187f9b0950 Fixed compile-time conditionals used to detect if X-Forwarded-For support
Ruslan Ermilov <ru@nginx.com>
parents: 4675
diff changeset
156 #if (NGX_HTTP_X_FORWARDED_FOR)
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
157 { ngx_string("X-Forwarded-For"),
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
158 offsetof(ngx_http_headers_in_t, x_forwarded_for),
5084
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
159 ngx_http_process_multi_header_lines },
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
160 #endif
479
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
161
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
162 #if (NGX_HTTP_REALIP)
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
163 { ngx_string("X-Real-IP"),
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
164 offsetof(ngx_http_headers_in_t, x_real_ip),
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
165 ngx_http_process_header_line },
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
166 #endif
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
167
489
45a460f82aec nginx-0.1.19-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 483
diff changeset
168 #if (NGX_HTTP_HEADERS)
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
169 { ngx_string("Accept"), offsetof(ngx_http_headers_in_t, accept),
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
170 ngx_http_process_header_line },
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
171
489
45a460f82aec nginx-0.1.19-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 483
diff changeset
172 { ngx_string("Accept-Language"),
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
173 offsetof(ngx_http_headers_in_t, accept_language),
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
174 ngx_http_process_header_line },
489
45a460f82aec nginx-0.1.19-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 483
diff changeset
175 #endif
45a460f82aec nginx-0.1.19-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 483
diff changeset
176
637
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
177 #if (NGX_HTTP_DAV)
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
178 { ngx_string("Depth"), offsetof(ngx_http_headers_in_t, depth),
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
179 ngx_http_process_header_line },
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
180
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
181 { ngx_string("Destination"), offsetof(ngx_http_headers_in_t, destination),
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
182 ngx_http_process_header_line },
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
183
1059
bff1312b84ed the "Overwrite" header line
Igor Sysoev <igor@sysoev.ru>
parents: 992
diff changeset
184 { ngx_string("Overwrite"), offsetof(ngx_http_headers_in_t, overwrite),
bff1312b84ed the "Overwrite" header line
Igor Sysoev <igor@sysoev.ru>
parents: 992
diff changeset
185 ngx_http_process_header_line },
bff1312b84ed the "Overwrite" header line
Igor Sysoev <igor@sysoev.ru>
parents: 992
diff changeset
186
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
187 { ngx_string("Date"), offsetof(ngx_http_headers_in_t, date),
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
188 ngx_http_process_header_line },
637
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
189 #endif
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
190
5084
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
191 { ngx_string("Cookie"), offsetof(ngx_http_headers_in_t, cookies),
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
192 ngx_http_process_multi_header_lines },
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
193
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
194 { ngx_null_string, 0, NULL }
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
195 };
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
196
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
197
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
198 void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
199 ngx_http_init_connection(ngx_connection_t *c)
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
200 {
5085
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
201 ngx_uint_t i;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
202 ngx_event_t *rev;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
203 struct sockaddr_in *sin;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
204 ngx_http_port_t *port;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
205 ngx_http_in_addr_t *addr;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
206 ngx_http_log_ctx_t *ctx;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
207 ngx_http_connection_t *hc;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
208 #if (NGX_HAVE_INET6)
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
209 struct sockaddr_in6 *sin6;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
210 ngx_http_in6_addr_t *addr6;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
211 #endif
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
212
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
213 hc = ngx_pcalloc(c->pool, sizeof(ngx_http_connection_t));
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
214 if (hc == NULL) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
215 ngx_http_close_connection(c);
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
216 return;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
217 }
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
218
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
219 c->data = hc;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
220
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
221 /* find the server configuration for the address:port */
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
222
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
223 port = c->listening->servers;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
224
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
225 if (port->naddrs > 1) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
226
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
227 /*
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
228 * there are several addresses on this port and one of them
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
229 * is an "*:port" wildcard so getsockname() in ngx_http_server_addr()
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
230 * is required to determine a server address
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
231 */
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
232
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
233 if (ngx_connection_local_sockaddr(c, NULL, 0) != NGX_OK) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
234 ngx_http_close_connection(c);
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
235 return;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
236 }
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
237
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
238 switch (c->local_sockaddr->sa_family) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
239
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
240 #if (NGX_HAVE_INET6)
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
241 case AF_INET6:
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
242 sin6 = (struct sockaddr_in6 *) c->local_sockaddr;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
243
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
244 addr6 = port->addrs;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
245
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
246 /* the last address is "*" */
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
247
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
248 for (i = 0; i < port->naddrs - 1; i++) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
249 if (ngx_memcmp(&addr6[i].addr6, &sin6->sin6_addr, 16) == 0) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
250 break;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
251 }
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
252 }
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
253
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
254 hc->addr_conf = &addr6[i].conf;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
255
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
256 break;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
257 #endif
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
258
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
259 default: /* AF_INET */
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
260 sin = (struct sockaddr_in *) c->local_sockaddr;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
261
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
262 addr = port->addrs;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
263
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
264 /* the last address is "*" */
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
265
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
266 for (i = 0; i < port->naddrs - 1; i++) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
267 if (addr[i].addr == sin->sin_addr.s_addr) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
268 break;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
269 }
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
270 }
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
271
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
272 hc->addr_conf = &addr[i].conf;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
273
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
274 break;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
275 }
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
276
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
277 } else {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
278
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
279 switch (c->local_sockaddr->sa_family) {
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
280
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
281 #if (NGX_HAVE_INET6)
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
282 case AF_INET6:
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
283 addr6 = port->addrs;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
284 hc->addr_conf = &addr6[0].conf;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
285 break;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
286 #endif
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
287
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
288 default: /* AF_INET */
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
289 addr = port->addrs;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
290 hc->addr_conf = &addr[0].conf;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
291 break;
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
292 }
7f1cbcc71327 The default server lookup is now done only once per connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5084
diff changeset
293 }
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
294
5089
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
295 /* the default server configuration for the address:port */
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
296 hc->conf_ctx = hc->addr_conf->default_server->ctx;
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
297
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
298 ctx = ngx_palloc(c->pool, sizeof(ngx_http_log_ctx_t));
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
299 if (ctx == NULL) {
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
300 ngx_http_close_connection(c);
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
301 return;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
302 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
303
1810
755e09d5c271 log server address
Igor Sysoev <igor@sysoev.ru>
parents: 1805
diff changeset
304 ctx->connection = c;
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
305 ctx->request = NULL;
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
306 ctx->current_request = NULL;
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
307
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
308 c->log->connection = c->number;
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
309 c->log->handler = ngx_http_log_error;
191
71ce40b3c37b nginx-0.0.1-2003-11-19-19:26:41 import
Igor Sysoev <igor@sysoev.ru>
parents: 189
diff changeset
310 c->log->data = ctx;
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
311 c->log->action = "reading client request line";
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
312
256
8e39cab6abd5 nginx-0.0.2-2004-02-10-19:23:38 import
Igor Sysoev <igor@sysoev.ru>
parents: 253
diff changeset
313 c->log_error = NGX_ERROR_INFO;
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
314
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
315 rev = c->read;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
316 rev->handler = ngx_http_init_request;
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
317 c->write->handler = ngx_http_empty_handler;
253
b6793bc5034b nginx-0.0.2-2004-02-09-10:46:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 247
diff changeset
318
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
319 #if (NGX_HTTP_SSL)
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
320 {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
321 ngx_http_ssl_srv_conf_t *sscf;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
322
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
323 sscf = ngx_http_get_module_srv_conf(hc->conf_ctx, ngx_http_ssl_module);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
324
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
325 if (sscf->enable || hc->addr_conf->ssl) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
326
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
327 c->log->action = "SSL handshaking";
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
328
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
329 if (hc->addr_conf->ssl && sscf->ssl.ctx == NULL) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
330 ngx_log_error(NGX_LOG_ERR, c->log, 0,
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
331 "no \"ssl_certificate\" is defined "
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
332 "in server listening on SSL port");
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
333 ngx_http_close_connection(c);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
334 return;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
335 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
336
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
337 hc->ssl = 1;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
338
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
339 rev->handler = ngx_http_ssl_handshake;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
340 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
341 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
342 #endif
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
343
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
344 if (rev->ready) {
346
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
345 /* the deferred accept(), rtsig, aio, iocp */
301
744965ec6275 nginx-0.0.3-2004-03-31-19:26:46 import
Igor Sysoev <igor@sysoev.ru>
parents: 299
diff changeset
346
611
3f8a2132b93d nginx-0.3.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 605
diff changeset
347 if (ngx_use_accept_mutex) {
563
9c2f3ed7a247 nginx-0.3.3-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 561
diff changeset
348 ngx_post_event(rev, &ngx_posted_events);
301
744965ec6275 nginx-0.0.3-2004-03-31-19:26:46 import
Igor Sysoev <igor@sysoev.ru>
parents: 299
diff changeset
349 return;
744965ec6275 nginx-0.0.3-2004-03-31-19:26:46 import
Igor Sysoev <igor@sysoev.ru>
parents: 299
diff changeset
350 }
744965ec6275 nginx-0.0.3-2004-03-31-19:26:46 import
Igor Sysoev <igor@sysoev.ru>
parents: 299
diff changeset
351
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
352 rev->handler(rev);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
353 return;
57
a499e0d1f16e nginx-0.0.1-2003-01-30-10:28:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 55
diff changeset
354 }
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
355
103
6dfda4cf5200 nginx-0.0.1-2003-06-11-19:28:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 101
diff changeset
356 ngx_add_timer(rev, c->listening->post_accept_timeout);
53
d1e42f1b8fd4 nginx-0.0.1-2003-01-27-00:08:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 52
diff changeset
357
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
358 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
143
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
359 ngx_http_close_connection(c);
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
360 return;
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
361 }
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
362 }
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
363
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
364
641
5e8fb59c18c1 nginx-0.3.42-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 639
diff changeset
365 static void
5e8fb59c18c1 nginx-0.3.42-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 639
diff changeset
366 ngx_http_init_request(ngx_event_t *rev)
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
367 {
1179
6e2216ad2c87 $request_time has millisecond precision
Igor Sysoev <igor@sysoev.ru>
parents: 1151
diff changeset
368 ngx_time_t *tp;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
369 ngx_connection_t *c;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
370 ngx_http_request_t *r;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
371 ngx_http_log_ctx_t *ctx;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
372 ngx_http_connection_t *hc;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
373 ngx_http_core_srv_conf_t *cscf;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
374 ngx_http_core_loc_conf_t *clcf;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
375 ngx_http_core_main_conf_t *cmcf;
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
376
91
637625a2acdb nginx-0.0.1-2003-05-19-20:39:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 89
diff changeset
377 c = rev->data;
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
378
160
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
379 if (rev->timedout) {
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
380 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT, "client timed out");
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
381
160
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
382 ngx_http_close_connection(c);
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
383 return;
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
384 }
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
385
2888
512d164a8348 keepalive_requests
Igor Sysoev <igor@sysoev.ru>
parents: 2883
diff changeset
386 c->requests++;
512d164a8348 keepalive_requests
Igor Sysoev <igor@sysoev.ru>
parents: 2883
diff changeset
387
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
388 hc = c->data;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
389
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
390 r = hc->request;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
391
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
392 if (r) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
393 ngx_memzero(r, sizeof(ngx_http_request_t));
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
394
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
395 r->pipeline = hc->pipeline;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
396
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
397 if (hc->nbusy) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
398 r->header_in = hc->busy[0];
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
399 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
400
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
401 } else {
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
402 r = ngx_pcalloc(c->pool, sizeof(ngx_http_request_t));
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
403 if (r == NULL) {
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
404 ngx_http_close_connection(c);
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
405 return;
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
406 }
368
15c84a40e87d nginx-0.0.7-2004-06-24-20:07:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 367
diff changeset
407
432
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
408 hc->request = r;
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
409 }
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
410
432
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
411 c->data = r;
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
412 r->http_connection = hc;
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
413
368
15c84a40e87d nginx-0.0.7-2004-06-24-20:07:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 367
diff changeset
414 c->sent = 0;
367
ceec87d1c2b3 nginx-0.0.7-2004-06-24-11:53:37 import
Igor Sysoev <igor@sysoev.ru>
parents: 362
diff changeset
415 r->signature = NGX_HTTP_MODULE;
216
f1d0e5f09c1e nginx-0.0.1-2003-12-25-23:26:58 import
Igor Sysoev <igor@sysoev.ru>
parents: 215
diff changeset
416
1805
bb72f7518992 use ngx_http_server_addr()
Igor Sysoev <igor@sysoev.ru>
parents: 1804
diff changeset
417 r->connection = c;
bb72f7518992 use ngx_http_server_addr()
Igor Sysoev <igor@sysoev.ru>
parents: 1804
diff changeset
418
5089
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
419 r->main_conf = hc->conf_ctx->main_conf;
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
420 r->srv_conf = hc->conf_ctx->srv_conf;
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
421 r->loc_conf = hc->conf_ctx->loc_conf;
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
422
3000
66ef86affbb8 fix segfault if 400 or 414 errors are handled intricately
Igor Sysoev <igor@sysoev.ru>
parents: 2994
diff changeset
423 r->read_event_handler = ngx_http_block_reading;
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
424
119
cd54bcbaf3b5 nginx-0.0.1-2003-07-21-01:15:59 import
Igor Sysoev <igor@sysoev.ru>
parents: 114
diff changeset
425 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
5086
1b204b8ea9a3 Introduced the ngx_http_set_connection_log() macro.
Valentin Bartenev <vbart@nginx.com>
parents: 5085
diff changeset
426
1b204b8ea9a3 Introduced the ngx_http_set_connection_log() macro.
Valentin Bartenev <vbart@nginx.com>
parents: 5085
diff changeset
427 ngx_http_set_connection_log(r->connection, clcf->error_log);
119
cd54bcbaf3b5 nginx-0.0.1-2003-07-21-01:15:59 import
Igor Sysoev <igor@sysoev.ru>
parents: 114
diff changeset
428
5089
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
429 cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
430
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
431 if (c->buffer == NULL) {
343
6bdf858bff8c nginx-0.0.3-2004-05-28-19:49:23 import; rename ngx_hunk_t to ngx_buf_t
Igor Sysoev <igor@sysoev.ru>
parents: 335
diff changeset
432 c->buffer = ngx_create_temp_buf(c->pool,
6bdf858bff8c nginx-0.0.3-2004-05-28-19:49:23 import; rename ngx_hunk_t to ngx_buf_t
Igor Sysoev <igor@sysoev.ru>
parents: 335
diff changeset
433 cscf->client_header_buffer_size);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
434 if (c->buffer == NULL) {
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
435 ngx_http_close_connection(c);
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
436 return;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
437 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
438 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
439
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
440 if (r->header_in == NULL) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
441 r->header_in = c->buffer;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
442 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
443
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
444 r->pool = ngx_create_pool(cscf->request_pool_size, c->log);
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
445 if (r->pool == NULL) {
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
446 ngx_http_close_connection(c);
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
447 return;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
448 }
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
449
294
5cfd65b8b0a7 nginx-0.0.3-2004-03-23-09:01:52 import
Igor Sysoev <igor@sysoev.ru>
parents: 293
diff changeset
450
416
b9bd635011de nginx-0.0.10-2004-09-06-22:45:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
451 if (ngx_list_init(&r->headers_out.headers, r->pool, 20,
581
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
452 sizeof(ngx_table_elt_t))
2536
a6d6d762c554 small optimization: " == NGX_ERROR" > " != NGX_OK"
Igor Sysoev <igor@sysoev.ru>
parents: 2534
diff changeset
453 != NGX_OK)
415
3c56e834be46 nginx-0.0.10-2004-09-05-23:54:02 import
Igor Sysoev <igor@sysoev.ru>
parents: 408
diff changeset
454 {
2902
a1a1c7e3fb8d fix "out of memory" case handling
Igor Sysoev <igor@sysoev.ru>
parents: 2888
diff changeset
455 ngx_destroy_pool(r->pool);
a1a1c7e3fb8d fix "out of memory" case handling
Igor Sysoev <igor@sysoev.ru>
parents: 2888
diff changeset
456 ngx_http_close_connection(c);
415
3c56e834be46 nginx-0.0.10-2004-09-05-23:54:02 import
Igor Sysoev <igor@sysoev.ru>
parents: 408
diff changeset
457 return;
3c56e834be46 nginx-0.0.10-2004-09-05-23:54:02 import
Igor Sysoev <igor@sysoev.ru>
parents: 408
diff changeset
458 }
3c56e834be46 nginx-0.0.10-2004-09-05-23:54:02 import
Igor Sysoev <igor@sysoev.ru>
parents: 408
diff changeset
459
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
460 r->ctx = ngx_pcalloc(r->pool, sizeof(void *) * ngx_http_max_module);
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
461 if (r->ctx == NULL) {
2902
a1a1c7e3fb8d fix "out of memory" case handling
Igor Sysoev <igor@sysoev.ru>
parents: 2888
diff changeset
462 ngx_destroy_pool(r->pool);
a1a1c7e3fb8d fix "out of memory" case handling
Igor Sysoev <igor@sysoev.ru>
parents: 2888
diff changeset
463 ngx_http_close_connection(c);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
464 return;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
465 }
10
4f3879d9b6f6 nginx-0.0.1-2002-09-11-19:18:33 import
Igor Sysoev <igor@sysoev.ru>
parents: 9
diff changeset
466
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
467 cmcf = ngx_http_get_module_main_conf(r, ngx_http_core_module);
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
468
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
469 r->variables = ngx_pcalloc(r->pool, cmcf->variables.nelts
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
470 * sizeof(ngx_http_variable_value_t));
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
471 if (r->variables == NULL) {
2902
a1a1c7e3fb8d fix "out of memory" case handling
Igor Sysoev <igor@sysoev.ru>
parents: 2888
diff changeset
472 ngx_destroy_pool(r->pool);
a1a1c7e3fb8d fix "out of memory" case handling
Igor Sysoev <igor@sysoev.ru>
parents: 2888
diff changeset
473 ngx_http_close_connection(c);
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
474 return;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
475 }
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
476
380
5ce6561246a5 nginx-0.0.7-2004-07-07-10:15:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 377
diff changeset
477 c->single_connection = 1;
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
478 c->destroyed = 0;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
479
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
480 #if (NGX_HTTP_SSL)
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
481 if (c->ssl) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
482 r->main_filter_need_in_memory = 1;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
483 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
484 #endif
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
485
553
45033d85b30e nginx-0.2.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 547
diff changeset
486 r->main = r;
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
487 r->count = 1;
553
45033d85b30e nginx-0.2.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 547
diff changeset
488
1179
6e2216ad2c87 $request_time has millisecond precision
Igor Sysoev <igor@sysoev.ru>
parents: 1151
diff changeset
489 tp = ngx_timeofday();
6e2216ad2c87 $request_time has millisecond precision
Igor Sysoev <igor@sysoev.ru>
parents: 1151
diff changeset
490 r->start_sec = tp->sec;
6e2216ad2c87 $request_time has millisecond precision
Igor Sysoev <igor@sysoev.ru>
parents: 1151
diff changeset
491 r->start_msec = tp->msec;
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 495
diff changeset
492
631
5d2b8078c1c2 nginx-0.3.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 629
diff changeset
493 r->method = NGX_HTTP_UNKNOWN;
5d2b8078c1c2 nginx-0.3.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 629
diff changeset
494
82
fccdb921e8b8 nginx-0.0.1-2003-04-25-18:43:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 77
diff changeset
495 r->headers_in.content_length_n = -1;
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
496 r->headers_in.keep_alive_n = -1;
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
497 r->headers_out.content_length_n = -1;
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
498 r->headers_out.last_modified_time = -1;
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
499
675
e924670896ab nginx-0.3.59-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 671
diff changeset
500 r->uri_changes = NGX_HTTP_MAX_URI_CHANGES + 1;
e924670896ab nginx-0.3.59-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 671
diff changeset
501 r->subrequests = NGX_HTTP_MAX_SUBREQUESTS + 1;
e924670896ab nginx-0.3.59-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 671
diff changeset
502
368
15c84a40e87d nginx-0.0.7-2004-06-24-20:07:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 367
diff changeset
503 r->http_state = NGX_HTTP_READING_REQUEST_STATE;
15c84a40e87d nginx-0.0.7-2004-06-24-20:07:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 367
diff changeset
504
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
505 ctx = c->log->data;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
506 ctx->request = r;
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
507 ctx->current_request = r;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
508 r->log_handler = ngx_http_log_error_handler;
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
509
426
3f88935a02e8 nginx-0.0.10-2004-09-14-23:39:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 423
diff changeset
510 #if (NGX_STAT_STUB)
2951
5acd98486a33 ignore ngx_atomic_fetch_add() result
Igor Sysoev <igor@sysoev.ru>
parents: 2902
diff changeset
511 (void) ngx_atomic_fetch_add(ngx_stat_reading, 1);
477
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
512 r->stat_reading = 1;
2951
5acd98486a33 ignore ngx_atomic_fetch_add() result
Igor Sysoev <igor@sysoev.ru>
parents: 2902
diff changeset
513 (void) ngx_atomic_fetch_add(ngx_stat_requests, 1);
426
3f88935a02e8 nginx-0.0.10-2004-09-14-23:39:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 423
diff changeset
514 #endif
3f88935a02e8 nginx-0.0.10-2004-09-14-23:39:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 423
diff changeset
515
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
516 rev->handler = ngx_http_process_request_line;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
517 ngx_http_process_request_line(rev);
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
518 }
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
519
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
520
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
521 #if (NGX_HTTP_SSL)
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
522
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
523 static void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
524 ngx_http_ssl_handshake(ngx_event_t *rev)
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
525 {
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
526 u_char buf[1];
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
527 ssize_t n;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
528 ngx_err_t err;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
529 ngx_int_t rc;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
530 ngx_connection_t *c;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
531 ngx_http_connection_t *hc;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
532 ngx_http_ssl_srv_conf_t *sscf;
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
533
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
534 c = rev->data;
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
535
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
536 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, rev->log, 0,
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
537 "http check ssl handshake");
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
538
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
539 if (rev->timedout) {
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
540 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT, "client timed out");
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
541 ngx_http_close_connection(c);
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
542 return;
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
543 }
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
544
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
545 n = recv(c->fd, (char *) buf, 1, MSG_PEEK);
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
546
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
547 err = ngx_socket_errno;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
548
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
549 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, rev->log, 0, "http recv(): %d", n);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
550
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
551 if (n == -1) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
552 if (err == NGX_EAGAIN) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
553
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
554 if (!rev->timer_set) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
555 ngx_add_timer(rev, c->listening->post_accept_timeout);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
556 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
557
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
558 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
559 ngx_http_close_connection(c);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
560 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
561
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
562 return;
1855
877cb2007c24 add code missed in r1830
Igor Sysoev <igor@sysoev.ru>
parents: 1829
diff changeset
563 }
877cb2007c24 add code missed in r1830
Igor Sysoev <igor@sysoev.ru>
parents: 1829
diff changeset
564
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
565 ngx_connection_error(c, err, "recv() failed");
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
566 ngx_http_close_connection(c);
1858
1ff400fed04d add code missed in r1856
Igor Sysoev <igor@sysoev.ru>
parents: 1856
diff changeset
567
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
568 return;
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
569 }
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
570
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
571 if (n == 1) {
3674
37715361263a fix recognition of SSLv2 Client Hello Packet large than 255 bytes
Igor Sysoev <igor@sysoev.ru>
parents: 3615
diff changeset
572 if (buf[0] & 0x80 /* SSLv2 */ || buf[0] == 0x16 /* SSLv3/TLSv1 */) {
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
573 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, rev->log, 0,
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
574 "https ssl handshake: 0x%02Xd", buf[0]);
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
575
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
576 hc = c->data;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
577 sscf = ngx_http_get_module_srv_conf(hc->conf_ctx,
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
578 ngx_http_ssl_module);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
579
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
580 if (ngx_ssl_create_connection(&sscf->ssl, c, NGX_SSL_BUFFER)
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
581 != NGX_OK)
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
582 {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
583 ngx_http_close_connection(c);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
584 return;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
585 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
586
396
6f3b20c1ac50 nginx-0.0.7-2004-07-18-23:11:20 import
Igor Sysoev <igor@sysoev.ru>
parents: 395
diff changeset
587 rc = ngx_ssl_handshake(c);
6f3b20c1ac50 nginx-0.0.7-2004-07-18-23:11:20 import
Igor Sysoev <igor@sysoev.ru>
parents: 395
diff changeset
588
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
589 if (rc == NGX_AGAIN) {
1829
81831a2bc67a fix socket leak if deferred accept was used
Igor Sysoev <igor@sysoev.ru>
parents: 1812
diff changeset
590
81831a2bc67a fix socket leak if deferred accept was used
Igor Sysoev <igor@sysoev.ru>
parents: 1812
diff changeset
591 if (!rev->timer_set) {
81831a2bc67a fix socket leak if deferred accept was used
Igor Sysoev <igor@sysoev.ru>
parents: 1812
diff changeset
592 ngx_add_timer(rev, c->listening->post_accept_timeout);
81831a2bc67a fix socket leak if deferred accept was used
Igor Sysoev <igor@sysoev.ru>
parents: 1812
diff changeset
593 }
81831a2bc67a fix socket leak if deferred accept was used
Igor Sysoev <igor@sysoev.ru>
parents: 1812
diff changeset
594
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
595 c->ssl->handler = ngx_http_ssl_handshake_handler;
396
6f3b20c1ac50 nginx-0.0.7-2004-07-18-23:11:20 import
Igor Sysoev <igor@sysoev.ru>
parents: 395
diff changeset
596 return;
6f3b20c1ac50 nginx-0.0.7-2004-07-18-23:11:20 import
Igor Sysoev <igor@sysoev.ru>
parents: 395
diff changeset
597 }
6f3b20c1ac50 nginx-0.0.7-2004-07-18-23:11:20 import
Igor Sysoev <igor@sysoev.ru>
parents: 395
diff changeset
598
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
599 ngx_http_ssl_handshake_handler(c);
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
600
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
601 return;
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
602 }
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
603
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
604 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, rev->log, 0, "plain http");
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
605
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
606 c->log->action = "reading client request line";
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
607
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
608 rev->handler = ngx_http_init_request;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
609 ngx_http_init_request(rev);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
610
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
611 return;
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
612 }
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
613
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
614 ngx_log_error(NGX_LOG_INFO, c->log, 0, "client closed connection");
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
615 ngx_http_close_connection(c);
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
616 }
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
617
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
618
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
619 static void
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
620 ngx_http_ssl_handshake_handler(ngx_connection_t *c)
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
621 {
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
622 if (c->ssl->handshaked) {
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
623
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
624 /*
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
625 * The majority of browsers do not send the "close notify" alert.
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
626 * Among them are MSIE, old Mozilla, Netscape 4, Konqueror,
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
627 * and Links. And what is more, MSIE ignores the server's alert.
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
628 *
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
629 * Opera and recent Mozilla send the alert.
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
630 */
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
631
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
632 c->ssl->no_wait_shutdown = 1;
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
633
4594
7d0561b2e0fb Fixed log->action after ssl handshake.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4593
diff changeset
634 c->log->action = "reading client request line";
7d0561b2e0fb Fixed log->action after ssl handshake.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4593
diff changeset
635
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
636 c->read->handler = ngx_http_init_request;
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
637 /* STUB: epoll edge */ c->write->handler = ngx_http_empty_handler;
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
638
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
639 ngx_http_init_request(c->read);
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
640
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
641 return;
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
642 }
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
643
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
644 if (c->read->timedout) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
645 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT, "client timed out");
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
646 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
647
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
648 ngx_http_close_connection(c);
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
649 }
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
650
1219
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
651 #ifdef SSL_CTRL_SET_TLSEXT_HOSTNAME
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
652
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
653 int
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
654 ngx_http_ssl_servername(ngx_ssl_conn_t *ssl_conn, int *ad, void *arg)
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
655 {
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
656 ngx_str_t host;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
657 const char *servername;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
658 ngx_connection_t *c;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
659 ngx_http_connection_t *hc;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
660 ngx_http_ssl_srv_conf_t *sscf;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
661 ngx_http_core_loc_conf_t *clcf;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
662 ngx_http_core_srv_conf_t *cscf;
1219
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
663
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
664 servername = SSL_get_servername(ssl_conn, TLSEXT_NAMETYPE_host_name);
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
665
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
666 if (servername == NULL) {
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
667 return SSL_TLSEXT_ERR_NOACK;
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
668 }
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
669
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
670 c = ngx_ssl_get_connection(ssl_conn);
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
671
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
672 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
673 "SSL server name: \"%s\"", servername);
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
674
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
675 host.len = ngx_strlen(servername);
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
676
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
677 if (host.len == 0) {
2195
a953f73273ee server_name "" support
Igor Sysoev <igor@sysoev.ru>
parents: 2193
diff changeset
678 return SSL_TLSEXT_ERR_NOACK;
a953f73273ee server_name "" support
Igor Sysoev <igor@sysoev.ru>
parents: 2193
diff changeset
679 }
a953f73273ee server_name "" support
Igor Sysoev <igor@sysoev.ru>
parents: 2193
diff changeset
680
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
681 host.data = (u_char *) servername;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
682
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
683 if (ngx_http_validate_host(&host, c->pool, 1) != NGX_OK) {
3152
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
684 return SSL_TLSEXT_ERR_NOACK;
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
685 }
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
686
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
687 hc = c->data;
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
688
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
689 if (ngx_http_find_virtual_server(c, hc->addr_conf->virtual_names, &host,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
690 NULL, &cscf)
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
691 != NGX_OK)
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
692 {
1219
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
693 return SSL_TLSEXT_ERR_NOACK;
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
694 }
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
695
5089
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
696 hc->conf_ctx = cscf->ctx;
903f2a5d86a5 SNI: reuse selected configuration for all requests in a connection.
Valentin Bartenev <vbart@nginx.com>
parents: 5088
diff changeset
697
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
698 clcf = ngx_http_get_module_loc_conf(hc->conf_ctx, ngx_http_core_module);
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
699
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
700 ngx_http_set_connection_log(c, clcf->error_log);
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
701
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
702 sscf = ngx_http_get_module_srv_conf(hc->conf_ctx, ngx_http_ssl_module);
1219
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
703
4304
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
704 if (sscf->ssl.ctx) {
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
705 SSL_set_SSL_CTX(ssl_conn, sscf->ssl.ctx);
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
706
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
707 /*
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
708 * SSL_set_SSL_CTX() only changes certs as of 1.0.0d
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
709 * adjust other things we care about
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
710 */
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
711
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
712 SSL_set_verify(ssl_conn, SSL_CTX_get_verify_mode(sscf->ssl.ctx),
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
713 SSL_CTX_get_verify_callback(sscf->ssl.ctx));
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
714
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
715 SSL_set_verify_depth(ssl_conn, SSL_CTX_get_verify_depth(sscf->ssl.ctx));
4033
4e1a489c26cd Better handling of various per-server ssl options with SNI.
Maxim Dounin <mdounin@mdounin.ru>
parents: 3985
diff changeset
716
4e1a489c26cd Better handling of various per-server ssl options with SNI.
Maxim Dounin <mdounin@mdounin.ru>
parents: 3985
diff changeset
717 #ifdef SSL_CTRL_CLEAR_OPTIONS
4304
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
718 /* only in 0.9.8m+ */
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
719 SSL_clear_options(ssl_conn, SSL_get_options(ssl_conn) &
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
720 ~SSL_CTX_get_options(sscf->ssl.ctx));
4033
4e1a489c26cd Better handling of various per-server ssl options with SNI.
Maxim Dounin <mdounin@mdounin.ru>
parents: 3985
diff changeset
721 #endif
4e1a489c26cd Better handling of various per-server ssl options with SNI.
Maxim Dounin <mdounin@mdounin.ru>
parents: 3985
diff changeset
722
4304
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
723 SSL_set_options(ssl_conn, SSL_CTX_get_options(sscf->ssl.ctx));
ed922fb9d6c1 Fixed segfault on ssl servers without cert with SNI (ticket #54).
Maxim Dounin <mdounin@mdounin.ru>
parents: 4195
diff changeset
724 }
4033
4e1a489c26cd Better handling of various per-server ssl options with SNI.
Maxim Dounin <mdounin@mdounin.ru>
parents: 3985
diff changeset
725
1219
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
726 return SSL_TLSEXT_ERR_OK;
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
727 }
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
728
86c5c9288acc SNI support
Igor Sysoev <igor@sysoev.ru>
parents: 1179
diff changeset
729 #endif
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
730
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
731 #endif
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
732
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
733
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
734 static void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
735 ngx_http_process_request_line(ngx_event_t *rev)
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
736 {
1585
4435ca2e467d merge_slashes
Igor Sysoev <igor@sysoev.ru>
parents: 1549
diff changeset
737 ssize_t n;
4435ca2e467d merge_slashes
Igor Sysoev <igor@sysoev.ru>
parents: 1549
diff changeset
738 ngx_int_t rc, rv;
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
739 ngx_str_t host;
1585
4435ca2e467d merge_slashes
Igor Sysoev <igor@sysoev.ru>
parents: 1549
diff changeset
740 ngx_connection_t *c;
4435ca2e467d merge_slashes
Igor Sysoev <igor@sysoev.ru>
parents: 1549
diff changeset
741 ngx_http_request_t *r;
4435ca2e467d merge_slashes
Igor Sysoev <igor@sysoev.ru>
parents: 1549
diff changeset
742 ngx_http_core_srv_conf_t *cscf;
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
743
91
637625a2acdb nginx-0.0.1-2003-05-19-20:39:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 89
diff changeset
744 c = rev->data;
637625a2acdb nginx-0.0.1-2003-05-19-20:39:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 89
diff changeset
745 r = c->data;
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
746
209
e1c815be05ae nginx-0.0.1-2003-12-09-18:08:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 201
diff changeset
747 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, rev->log, 0,
e1c815be05ae nginx-0.0.1-2003-12-09-18:08:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 201
diff changeset
748 "http process request line");
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
749
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
750 if (rev->timedout) {
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
751 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT, "client timed out");
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
752 c->timedout = 1;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
753 ngx_http_close_request(r, NGX_HTTP_REQUEST_TIME_OUT);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
754 return;
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
755 }
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
756
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
757 rc = NGX_AGAIN;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
758
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
759 for ( ;; ) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
760
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
761 if (rc == NGX_AGAIN) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
762 n = ngx_http_read_request_header(r);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
763
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
764 if (n == NGX_AGAIN || n == NGX_ERROR) {
201
267ea1d98683 nginx-0.0.1-2003-11-30-23:03:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 200
diff changeset
765 return;
267ea1d98683 nginx-0.0.1-2003-11-30-23:03:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 200
diff changeset
766 }
91
637625a2acdb nginx-0.0.1-2003-05-19-20:39:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 89
diff changeset
767 }
637625a2acdb nginx-0.0.1-2003-05-19-20:39:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 89
diff changeset
768
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
769 rc = ngx_http_parse_request_line(r, r->header_in);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
770
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
771 if (rc == NGX_OK) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
772
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
773 /* the request line has been parsed successfully */
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
774
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
775 r->request_line.len = r->request_end - r->request_start;
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
776 r->request_line.data = r->request_start;
4739
986cc869b09d Corrected $request_length calculation for pipelined requests.
Andrey Belov <defan@nginx.com>
parents: 4697
diff changeset
777 r->request_length = r->header_in->pos - r->request_start;
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
778
192
31824be1fc66 nginx-0.0.1-2003-11-20-10:05:50 import; auto/configure
Igor Sysoev <igor@sysoev.ru>
parents: 191
diff changeset
779
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
780 if (r->args_start) {
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
781 r->uri.len = r->args_start - 1 - r->uri_start;
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
782 } else {
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
783 r->uri.len = r->uri_end - r->uri_start;
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
784 }
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
785
469
2ff194b74f1e nginx-0.1.9-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 461
diff changeset
786
452
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
787 if (r->complex_uri || r->quoted_uri) {
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
788
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 2019
diff changeset
789 r->uri.data = ngx_pnalloc(r->pool, r->uri.len + 1);
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
790 if (r->uri.data == NULL) {
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
791 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
792 return;
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
793 }
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
794
1585
4435ca2e467d merge_slashes
Igor Sysoev <igor@sysoev.ru>
parents: 1549
diff changeset
795 cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
4435ca2e467d merge_slashes
Igor Sysoev <igor@sysoev.ru>
parents: 1549
diff changeset
796
4435ca2e467d merge_slashes
Igor Sysoev <igor@sysoev.ru>
parents: 1549
diff changeset
797 rc = ngx_http_parse_complex_uri(r, cscf->merge_slashes);
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
798
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
799 if (rc == NGX_HTTP_PARSE_INVALID_REQUEST) {
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
800 ngx_log_error(NGX_LOG_INFO, c->log, 0,
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
801 "client sent invalid request");
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
802 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
803 return;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
804 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
805
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
806 } else {
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
807 r->uri.data = r->uri_start;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
808 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
809
469
2ff194b74f1e nginx-0.1.9-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 461
diff changeset
810
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
811 r->unparsed_uri.len = r->uri_end - r->uri_start;
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
812 r->unparsed_uri.data = r->uri_start;
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
813
3615
31e9677b15a1 allow spaces in URI
Igor Sysoev <igor@sysoev.ru>
parents: 3570
diff changeset
814 r->valid_unparsed_uri = r->space_in_uri ? 0 : 1;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
815
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
816 r->method_name.len = r->method_end - r->request_start + 1;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
817 r->method_name.data = r->request_line.data;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
818
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
819
479
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
820 if (r->http_protocol.data) {
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
821 r->http_protocol.len = r->request_end - r->http_protocol.data;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
822 }
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
823
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
824
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
825 if (r->uri_ext) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
826 if (r->args_start) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
827 r->exten.len = r->args_start - 1 - r->uri_ext;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
828 } else {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
829 r->exten.len = r->uri_end - r->uri_ext;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
830 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
831
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
832 r->exten.data = r->uri_ext;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
833 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
834
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
835
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
836 if (r->args_start && r->uri_end > r->args_start) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
837 r->args.len = r->uri_end - r->args_start;
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
838 r->args.data = r->args_start;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
839 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
840
2980
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
841 #if (NGX_WIN32)
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
842 {
4675
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
843 u_char *p, *last;
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
844
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
845 p = r->uri.data;
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
846 last = r->uri.data + r->uri.len;
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
847
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
848 while (p < last) {
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
849
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
850 if (*p++ == ':') {
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
851
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
852 /*
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
853 * this check covers "::$data", "::$index_allocation" and
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
854 * ":$i30:$index_allocation"
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
855 */
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
856
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
857 if (p < last && *p == '$') {
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
858 ngx_log_error(NGX_LOG_INFO, c->log, 0,
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
859 "client sent unsafe win32 URI");
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
860 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
861 return;
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
862 }
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
863 }
79c147bdeb6a Win32: uris with ":$" are now rejected.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4640
diff changeset
864 }
2980
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
865
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
866 p = r->uri.data + r->uri.len - 1;
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
867
3570
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
868 while (p > r->uri.data) {
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
869
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
870 if (*p == ' ') {
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
871 p--;
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
872 continue;
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
873 }
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
874
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
875 if (*p == '.') {
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
876 p--;
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
877 continue;
3416
ee713c767b25 skip URI trailing spaces under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 3415
diff changeset
878 }
2980
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
879
3570
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
880 break;
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
881 }
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
882
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
883 if (p != r->uri.data + r->uri.len - 1) {
2980
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
884 r->uri.len = p + 1 - r->uri.data;
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
885 ngx_http_set_exten(r);
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
886 }
3570
e03b8a4fb906 test default NTFS stream "::$DATA"
Igor Sysoev <igor@sysoev.ru>
parents: 3419
diff changeset
887
2980
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
888 }
c96960a4b42c skip URI trailing dots under Win32
Igor Sysoev <igor@sysoev.ru>
parents: 2971
diff changeset
889 #endif
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
890
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
891 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
892 "http request line: \"%V\"", &r->request_line);
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
893
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
894 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
895 "http uri: \"%V\"", &r->uri);
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
896
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
897 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
898 "http args: \"%V\"", &r->args);
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
899
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
900 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
901 "http exten: \"%V\"", &r->exten);
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
902
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
903 if (r->host_start && r->host_end) {
3152
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
904
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
905 host.len = r->host_end - r->host_start;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
906 host.data = r->host_start;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
907
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
908 rc = ngx_http_validate_host(&host, r->pool, 0);
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
909
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
910 if (rc == NGX_DECLINED) {
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
911 ngx_log_error(NGX_LOG_INFO, c->log, 0,
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
912 "client sent invalid host in request line");
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
913 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
914 return;
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
915 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
916
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
917 if (rc == NGX_ERROR) {
3152
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
918 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
919 return;
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
920 }
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
921
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
922 r->headers_in.server = host;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
923 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
924
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
925 if (r->http_version < NGX_HTTP_VERSION_10) {
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
926
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
927 if (ngx_http_set_virtual_server(r, &r->headers_in.server)
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
928 == NGX_ERROR)
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
929 {
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
930 return;
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
931 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
932
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
933 ngx_http_process_request(r);
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
934 return;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
935 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
936
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
937
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
938 if (ngx_list_init(&r->headers_in.headers, r->pool, 20,
581
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
939 sizeof(ngx_table_elt_t))
2536
a6d6d762c554 small optimization: " == NGX_ERROR" > " != NGX_OK"
Igor Sysoev <igor@sysoev.ru>
parents: 2534
diff changeset
940 != NGX_OK)
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
941 {
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
942 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
943 return;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
944 }
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
945
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
946 c->log->action = "reading client request headers";
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
947
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
948 rev->handler = ngx_http_process_request_headers;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
949 ngx_http_process_request_headers(rev);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
950
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
951 return;
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
952 }
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
953
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
954 if (rc != NGX_AGAIN) {
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
955
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
956 /* there was error while a request line parsing */
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
957
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
958 ngx_log_error(NGX_LOG_INFO, c->log, 0,
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
959 ngx_http_client_errors[rc - NGX_HTTP_CLIENT_ERROR]);
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
960 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
408
d6e2b445c1b8 nginx-0.0.10-2004-08-27-19:40:59 import
Igor Sysoev <igor@sysoev.ru>
parents: 406
diff changeset
961 return;
d6e2b445c1b8 nginx-0.0.10-2004-08-27-19:40:59 import
Igor Sysoev <igor@sysoev.ru>
parents: 406
diff changeset
962 }
d6e2b445c1b8 nginx-0.0.10-2004-08-27-19:40:59 import
Igor Sysoev <igor@sysoev.ru>
parents: 406
diff changeset
963
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
964 /* NGX_AGAIN: a request line parsing is still incomplete */
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
965
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
966 if (r->header_in->pos == r->header_in->end) {
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
967
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
968 rv = ngx_http_alloc_large_header_buffer(r, 1);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
969
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
970 if (rv == NGX_ERROR) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
971 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
972 return;
220
4f81b931e9ff nginx-0.0.1-2004-01-08-11:47:17 import
Igor Sysoev <igor@sysoev.ru>
parents: 218
diff changeset
973 }
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
974
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
975 if (rv == NGX_DECLINED) {
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
976 r->request_line.len = r->header_in->end - r->request_start;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
977 r->request_line.data = r->request_start;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
978
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
979 ngx_log_error(NGX_LOG_INFO, c->log, 0,
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
980 "client sent too long URI");
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
981 ngx_http_finalize_request(r, NGX_HTTP_REQUEST_URI_TOO_LARGE);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
982 return;
66
4876cd4a36bb nginx-0.0.1-2003-03-05-20:30:51 import
Igor Sysoev <igor@sysoev.ru>
parents: 65
diff changeset
983 }
4876cd4a36bb nginx-0.0.1-2003-03-05-20:30:51 import
Igor Sysoev <igor@sysoev.ru>
parents: 65
diff changeset
984 }
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
985 }
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
986 }
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
987
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
988
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
989 static void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
990 ngx_http_process_request_headers(ngx_event_t *rev)
0
4eff17414a43 nginx-0.0.1-2002-08-06-20:39:45 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
991 {
3076
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
992 u_char *p;
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
993 size_t len;
507
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
994 ssize_t n;
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
995 ngx_int_t rc, rv;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
996 ngx_table_elt_t *h;
507
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
997 ngx_connection_t *c;
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
998 ngx_http_header_t *hh;
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
999 ngx_http_request_t *r;
511
c12967aadd87 nginx-0.1.30-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1000 ngx_http_core_srv_conf_t *cscf;
507
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
1001 ngx_http_core_main_conf_t *cmcf;
7
b5481d6fbbd4 nginx-0.0.1-2002-08-29-20:59:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 6
diff changeset
1002
91
637625a2acdb nginx-0.0.1-2003-05-19-20:39:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 89
diff changeset
1003 c = rev->data;
637625a2acdb nginx-0.0.1-2003-05-19-20:39:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 89
diff changeset
1004 r = c->data;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1005
201
267ea1d98683 nginx-0.0.1-2003-11-30-23:03:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 200
diff changeset
1006 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, rev->log, 0,
267ea1d98683 nginx-0.0.1-2003-11-30-23:03:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 200
diff changeset
1007 "http process request header line");
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1008
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1009 if (rev->timedout) {
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1010 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT, "client timed out");
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1011 c->timedout = 1;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1012 ngx_http_close_request(r, NGX_HTTP_REQUEST_TIME_OUT);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1013 return;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1014 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1015
507
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
1016 cmcf = ngx_http_get_module_main_conf(r, ngx_http_core_module);
511
c12967aadd87 nginx-0.1.30-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1017 cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
507
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
1018
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1019 rc = NGX_AGAIN;
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1020
7
b5481d6fbbd4 nginx-0.0.1-2002-08-29-20:59:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 6
diff changeset
1021 for ( ;; ) {
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1022
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1023 if (rc == NGX_AGAIN) {
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1024
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1025 if (r->header_in->pos == r->header_in->end) {
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1026
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1027 rv = ngx_http_alloc_large_header_buffer(r, 0);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1028
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1029 if (rv == NGX_ERROR) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1030 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1031 return;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1032 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1033
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1034 if (rv == NGX_DECLINED) {
3076
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1035 p = r->header_name_start;
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1036
3848
de59ad6bf557 introduce 494 code "Request Header Too Large"
Igor Sysoev <igor@sysoev.ru>
parents: 3814
diff changeset
1037 r->lingering_close = 1;
de59ad6bf557 introduce 494 code "Request Header Too Large"
Igor Sysoev <igor@sysoev.ru>
parents: 3814
diff changeset
1038
3287
e07630a9547d fix segfault if there is single large_client_header_buffers
Igor Sysoev <igor@sysoev.ru>
parents: 3228
diff changeset
1039 if (p == NULL) {
e07630a9547d fix segfault if there is single large_client_header_buffers
Igor Sysoev <igor@sysoev.ru>
parents: 3228
diff changeset
1040 ngx_log_error(NGX_LOG_INFO, c->log, 0,
e07630a9547d fix segfault if there is single large_client_header_buffers
Igor Sysoev <igor@sysoev.ru>
parents: 3228
diff changeset
1041 "client sent too large request");
3848
de59ad6bf557 introduce 494 code "Request Header Too Large"
Igor Sysoev <igor@sysoev.ru>
parents: 3814
diff changeset
1042 ngx_http_finalize_request(r,
de59ad6bf557 introduce 494 code "Request Header Too Large"
Igor Sysoev <igor@sysoev.ru>
parents: 3814
diff changeset
1043 NGX_HTTP_REQUEST_HEADER_TOO_LARGE);
3287
e07630a9547d fix segfault if there is single large_client_header_buffers
Igor Sysoev <igor@sysoev.ru>
parents: 3228
diff changeset
1044 return;
e07630a9547d fix segfault if there is single large_client_header_buffers
Igor Sysoev <igor@sysoev.ru>
parents: 3228
diff changeset
1045 }
e07630a9547d fix segfault if there is single large_client_header_buffers
Igor Sysoev <igor@sysoev.ru>
parents: 3228
diff changeset
1046
e07630a9547d fix segfault if there is single large_client_header_buffers
Igor Sysoev <igor@sysoev.ru>
parents: 3228
diff changeset
1047 len = r->header_in->end - p;
e07630a9547d fix segfault if there is single large_client_header_buffers
Igor Sysoev <igor@sysoev.ru>
parents: 3228
diff changeset
1048
3076
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1049 if (len > NGX_MAX_ERROR_STR - 300) {
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1050 len = NGX_MAX_ERROR_STR - 300;
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1051 p[len++] = '.'; p[len++] = '.'; p[len++] = '.';
531
c3bd8cdabb8f nginx-0.1.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 527
diff changeset
1052 }
c3bd8cdabb8f nginx-0.1.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 527
diff changeset
1053
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1054 ngx_log_error(NGX_LOG_INFO, c->log, 0,
3076
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1055 "client sent too long header line: \"%*s\"",
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1056 len, r->header_name_start);
3848
de59ad6bf557 introduce 494 code "Request Header Too Large"
Igor Sysoev <igor@sysoev.ru>
parents: 3814
diff changeset
1057
de59ad6bf557 introduce 494 code "Request Header Too Large"
Igor Sysoev <igor@sysoev.ru>
parents: 3814
diff changeset
1058 ngx_http_finalize_request(r,
de59ad6bf557 introduce 494 code "Request Header Too Large"
Igor Sysoev <igor@sysoev.ru>
parents: 3814
diff changeset
1059 NGX_HTTP_REQUEST_HEADER_TOO_LARGE);
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1060 return;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1061 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1062 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1063
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1064 n = ngx_http_read_request_header(r);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1065
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1066 if (n == NGX_AGAIN || n == NGX_ERROR) {
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1067 return;
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1068 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1069 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1070
2256
8c17cfe63d2c underscores_in_headers
Igor Sysoev <igor@sysoev.ru>
parents: 2250
diff changeset
1071 rc = ngx_http_parse_header_line(r, r->header_in,
8c17cfe63d2c underscores_in_headers
Igor Sysoev <igor@sysoev.ru>
parents: 2250
diff changeset
1072 cscf->underscores_in_headers);
7
b5481d6fbbd4 nginx-0.0.1-2002-08-29-20:59:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 6
diff changeset
1073
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1074 if (rc == NGX_OK) {
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1075
4739
986cc869b09d Corrected $request_length calculation for pipelined requests.
Andrey Belov <defan@nginx.com>
parents: 4697
diff changeset
1076 r->request_length += r->header_in->pos - r->header_name_start;
986cc869b09d Corrected $request_length calculation for pipelined requests.
Andrey Belov <defan@nginx.com>
parents: 4697
diff changeset
1077
511
c12967aadd87 nginx-0.1.30-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1078 if (r->invalid_header && cscf->ignore_invalid_headers) {
503
b1648294f693 nginx-0.1.26-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 501
diff changeset
1079
b1648294f693 nginx-0.1.26-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 501
diff changeset
1080 /* there was error while a header line parsing */
b1648294f693 nginx-0.1.26-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 501
diff changeset
1081
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1082 ngx_log_error(NGX_LOG_INFO, c->log, 0,
3076
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1083 "client sent invalid header line: \"%*s\"",
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1084 r->header_end - r->header_name_start,
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1085 r->header_name_start);
503
b1648294f693 nginx-0.1.26-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 501
diff changeset
1086 continue;
b1648294f693 nginx-0.1.26-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 501
diff changeset
1087 }
b1648294f693 nginx-0.1.26-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 501
diff changeset
1088
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1089 /* a header line has been parsed successfully */
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1090
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1091 h = ngx_list_push(&r->headers_in.headers);
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1092 if (h == NULL) {
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1093 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1094 return;
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1095 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1096
507
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
1097 h->hash = r->header_hash;
cd3117ad9aab nginx-0.1.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
1098
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1099 h->key.len = r->header_name_end - r->header_name_start;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1100 h->key.data = r->header_name_start;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1101 h->key.data[h->key.len] = '\0';
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1102
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1103 h->value.len = r->header_end - r->header_start;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1104 h->value.data = r->header_start;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1105 h->value.data[h->value.len] = '\0';
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
1106
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 2019
diff changeset
1107 h->lowcase_key = ngx_pnalloc(r->pool, h->key.len);
649
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1108 if (h->lowcase_key == NULL) {
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1109 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1110 return;
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1111 }
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1112
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1113 if (h->key.len == r->lowcase_index) {
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1114 ngx_memcpy(h->lowcase_key, r->lowcase_header, h->key.len);
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1115
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1116 } else {
2135
8c6521eedf84 ngx_strlow()
Igor Sysoev <igor@sysoev.ru>
parents: 2123
diff changeset
1117 ngx_strlow(h->lowcase_key, h->key.data, h->key.len);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1118 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1119
649
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1120 hh = ngx_hash_find(&cmcf->headers_in_hash, h->hash,
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1121 h->lowcase_key, h->key.len);
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1122
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1123 if (hh && hh->handler(r, h, hh->offset) != NGX_OK) {
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1124 return;
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1125 }
1e720b0be7ec nginx-0.3.46-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 647
diff changeset
1126
210
00cafae0bdf1 nginx-0.0.1-2003-12-14-23:10:27 import
Igor Sysoev <igor@sysoev.ru>
parents: 209
diff changeset
1127 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
1128 "http header: \"%V: %V\"",
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
1129 &h->key, &h->value);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1130
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
1131 continue;
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1132 }
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1133
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1134 if (rc == NGX_HTTP_PARSE_HEADER_DONE) {
8
708f8bb772ec nginx-0.0.1-2002-09-02-18:48:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 7
diff changeset
1135
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1136 /* a whole header has been parsed successfully */
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
1137
210
00cafae0bdf1 nginx-0.0.1-2003-12-14-23:10:27 import
Igor Sysoev <igor@sysoev.ru>
parents: 209
diff changeset
1138 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
00cafae0bdf1 nginx-0.0.1-2003-12-14-23:10:27 import
Igor Sysoev <igor@sysoev.ru>
parents: 209
diff changeset
1139 "http header done");
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
1140
4739
986cc869b09d Corrected $request_length calculation for pipelined requests.
Andrey Belov <defan@nginx.com>
parents: 4697
diff changeset
1141 r->request_length += r->header_in->pos - r->header_name_start;
475
c3c2848fc081 nginx-0.1.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 473
diff changeset
1142
368
15c84a40e87d nginx-0.0.7-2004-06-24-20:07:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 367
diff changeset
1143 r->http_state = NGX_HTTP_PROCESS_REQUEST_STATE;
15c84a40e87d nginx-0.0.7-2004-06-24-20:07:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 367
diff changeset
1144
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1145 rc = ngx_http_process_request_header(r);
119
cd54bcbaf3b5 nginx-0.0.1-2003-07-21-01:15:59 import
Igor Sysoev <igor@sysoev.ru>
parents: 114
diff changeset
1146
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1147 if (rc != NGX_OK) {
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1148 return;
82
fccdb921e8b8 nginx-0.0.1-2003-04-25-18:43:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 77
diff changeset
1149 }
fccdb921e8b8 nginx-0.0.1-2003-04-25-18:43:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 77
diff changeset
1150
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1151 ngx_http_process_request(r);
537
c9ad0d9c7d59 nginx-0.1.43-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 535
diff changeset
1152
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1153 return;
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1154 }
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1155
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1156 if (rc == NGX_AGAIN) {
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1157
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1158 /* a header line parsing is still not complete */
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1159
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1160 continue;
66
4876cd4a36bb nginx-0.0.1-2003-03-05-20:30:51 import
Igor Sysoev <igor@sysoev.ru>
parents: 65
diff changeset
1161 }
4876cd4a36bb nginx-0.0.1-2003-03-05-20:30:51 import
Igor Sysoev <igor@sysoev.ru>
parents: 65
diff changeset
1162
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1163 /* rc == NGX_HTTP_PARSE_INVALID_HEADER: "\r" is not followed by "\n" */
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1164
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1165 ngx_log_error(NGX_LOG_INFO, c->log, 0,
3076
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1166 "client sent invalid header line: \"%*s\\r...\"",
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1167 r->header_end - r->header_name_start,
44ac242eb6ac use %*s instead of %V
Igor Sysoev <igor@sysoev.ru>
parents: 3064
diff changeset
1168 r->header_name_start);
1427
bfb6aacc0ab9 return 400 response
Igor Sysoev <igor@sysoev.ru>
parents: 1424
diff changeset
1169 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1170 return;
19
d7908993fdeb nginx-0.0.1-2002-12-02-19:09:40 import; resume after 2 months stall
Igor Sysoev <igor@sysoev.ru>
parents: 18
diff changeset
1171 }
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
1172 }
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
1173
24
77c7629a2627 nginx-0.0.1-2002-12-10-21:05:12 import
Igor Sysoev <igor@sysoev.ru>
parents: 23
diff changeset
1174
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1175 static ssize_t
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1176 ngx_http_read_request_header(ngx_http_request_t *r)
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1177 {
95
b48066122884 nginx-0.0.1-2003-05-23-15:53:01 import
Igor Sysoev <igor@sysoev.ru>
parents: 94
diff changeset
1178 ssize_t n;
b48066122884 nginx-0.0.1-2003-05-23-15:53:01 import
Igor Sysoev <igor@sysoev.ru>
parents: 94
diff changeset
1179 ngx_event_t *rev;
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1180 ngx_connection_t *c;
95
b48066122884 nginx-0.0.1-2003-05-23-15:53:01 import
Igor Sysoev <igor@sysoev.ru>
parents: 94
diff changeset
1181 ngx_http_core_srv_conf_t *cscf;
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1182
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1183 c = r->connection;
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1184 rev = c->read;
103
6dfda4cf5200 nginx-0.0.1-2003-06-11-19:28:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 101
diff changeset
1185
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1186 n = r->header_in->last - r->header_in->pos;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1187
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1188 if (n > 0) {
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1189 return n;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1190 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1191
523
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1192 if (rev->ready) {
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1193 n = c->recv(c, r->header_in->last,
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1194 r->header_in->end - r->header_in->last);
523
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1195 } else {
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1196 n = NGX_AGAIN;
189
c966c09be66b nginx-0.0.1-2003-11-18-19:49:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 176
diff changeset
1197 }
c966c09be66b nginx-0.0.1-2003-11-18-19:49:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 176
diff changeset
1198
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1199 if (n == NGX_AGAIN) {
1856
11d12ef106a9 axe old flag remained after ancient "post_accept_timeout" directive
Igor Sysoev <igor@sysoev.ru>
parents: 1855
diff changeset
1200 if (!rev->timer_set) {
395
f8f0f1834266 nginx-0.0.7-2004-07-16-21:11:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 394
diff changeset
1201 cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
95
b48066122884 nginx-0.0.1-2003-05-23-15:53:01 import
Igor Sysoev <igor@sysoev.ru>
parents: 94
diff changeset
1202 ngx_add_timer(rev, cscf->client_header_timeout);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1203 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1204
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
1205 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
143
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
1206 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
1207 return NGX_ERROR;
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
1208 }
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
1209
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1210 return NGX_AGAIN;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1211 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1212
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1213 if (n == 0) {
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1214 ngx_log_error(NGX_LOG_INFO, c->log, 0,
4593
834049edae24 Fixed grammar in error messages.
Ruslan Ermilov <ru@nginx.com>
parents: 4552
diff changeset
1215 "client prematurely closed connection");
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
1216 }
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1217
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1218 if (n == 0 || n == NGX_ERROR) {
991
9075a1c5dc78 use right status code
Igor Sysoev <igor@sysoev.ru>
parents: 990
diff changeset
1219 c->error = 1;
992
3f2e60adf4ef correct an error log message
Igor Sysoev <igor@sysoev.ru>
parents: 991
diff changeset
1220 c->log->action = "reading client request headers";
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1221
991
9075a1c5dc78 use right status code
Igor Sysoev <igor@sysoev.ru>
parents: 990
diff changeset
1222 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1223 return NGX_ERROR;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1224 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1225
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1226 r->header_in->last += n;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1227
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1228 return n;
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1229 }
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1230
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
1231
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1232 static ngx_int_t
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1233 ngx_http_alloc_large_header_buffer(ngx_http_request_t *r,
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1234 ngx_uint_t request_line)
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1235 {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1236 u_char *old, *new;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1237 ngx_buf_t *b;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1238 ngx_http_connection_t *hc;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1239 ngx_http_core_srv_conf_t *cscf;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1240
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1241 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1242 "http alloc large header buffer");
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1243
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1244 if (request_line && r->state == 0) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1245
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1246 /* the client fills up the buffer with "\r\n" */
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1247
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1248 r->header_in->pos = r->header_in->start;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1249 r->header_in->last = r->header_in->start;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1250
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1251 return NGX_OK;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1252 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1253
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1254 old = request_line ? r->request_start : r->header_name_start;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1255
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1256 cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1257
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1258 if (r->state != 0
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1259 && (size_t) (r->header_in->pos - old)
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1260 >= cscf->large_client_header_buffers.size)
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1261 {
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1262 return NGX_DECLINED;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1263 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1264
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1265 hc = r->http_connection;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1266
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1267 if (hc->nfree) {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1268 b = hc->free[--hc->nfree];
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1269
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1270 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
1271 "http large header free: %p %uz",
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1272 b->pos, b->end - b->last);
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1273
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1274 } else if (hc->nbusy < cscf->large_client_header_buffers.num) {
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1275
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1276 if (hc->busy == NULL) {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1277 hc->busy = ngx_palloc(r->connection->pool,
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1278 cscf->large_client_header_buffers.num * sizeof(ngx_buf_t *));
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1279 if (hc->busy == NULL) {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1280 return NGX_ERROR;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1281 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1282 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1283
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1284 b = ngx_create_temp_buf(r->connection->pool,
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1285 cscf->large_client_header_buffers.size);
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1286 if (b == NULL) {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1287 return NGX_ERROR;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1288 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1289
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1290 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
1291 "http large header alloc: %p %uz",
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1292 b->pos, b->end - b->last);
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1293
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1294 } else {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1295 return NGX_DECLINED;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1296 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1297
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1298 hc->busy[hc->nbusy++] = b;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1299
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1300 if (r->state == 0) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1301 /*
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1302 * r->state == 0 means that a header line was parsed successfully
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1303 * and we do not need to copy incomplete header line and
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1304 * to relocate the parser header pointers
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1305 */
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1306
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1307 r->header_in = b;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1308
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1309 return NGX_OK;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1310 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1311
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1312 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1313 "http large header copy: %d", r->header_in->pos - old);
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1314
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1315 new = b->start;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1316
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1317 ngx_memcpy(new, old, r->header_in->pos - old);
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1318
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1319 b->pos = new + (r->header_in->pos - old);
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
1320 b->last = new + (r->header_in->pos - old);
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1321
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1322 if (request_line) {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1323 r->request_start = new;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1324
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1325 if (r->request_end) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1326 r->request_end = new + (r->request_end - old);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1327 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1328
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1329 r->method_end = new + (r->method_end - old);
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1330
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1331 r->uri_start = new + (r->uri_start - old);
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1332 r->uri_end = new + (r->uri_end - old);
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1333
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1334 if (r->schema_start) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1335 r->schema_start = new + (r->schema_start - old);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1336 r->schema_end = new + (r->schema_end - old);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1337 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1338
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1339 if (r->host_start) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1340 r->host_start = new + (r->host_start - old);
928
a6fe6bedb9e3 fix segfault when $host is used and
Igor Sysoev <igor@sysoev.ru>
parents: 895
diff changeset
1341 if (r->host_end) {
a6fe6bedb9e3 fix segfault when $host is used and
Igor Sysoev <igor@sysoev.ru>
parents: 895
diff changeset
1342 r->host_end = new + (r->host_end - old);
a6fe6bedb9e3 fix segfault when $host is used and
Igor Sysoev <igor@sysoev.ru>
parents: 895
diff changeset
1343 }
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1344 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1345
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1346 if (r->port_start) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1347 r->port_start = new + (r->port_start - old);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1348 r->port_end = new + (r->port_end - old);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1349 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
1350
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1351 if (r->uri_ext) {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1352 r->uri_ext = new + (r->uri_ext - old);
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1353 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1354
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1355 if (r->args_start) {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1356 r->args_start = new + (r->args_start - old);
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1357 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1358
1677
c997912a8f0b copy protocol value when large request line is copied,
Igor Sysoev <igor@sysoev.ru>
parents: 1676
diff changeset
1359 if (r->http_protocol.data) {
c997912a8f0b copy protocol value when large request line is copied,
Igor Sysoev <igor@sysoev.ru>
parents: 1676
diff changeset
1360 r->http_protocol.data = new + (r->http_protocol.data - old);
c997912a8f0b copy protocol value when large request line is copied,
Igor Sysoev <igor@sysoev.ru>
parents: 1676
diff changeset
1361 }
c997912a8f0b copy protocol value when large request line is copied,
Igor Sysoev <igor@sysoev.ru>
parents: 1676
diff changeset
1362
435
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1363 } else {
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1364 r->header_name_start = new;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1365 r->header_name_end = new + (r->header_name_end - old);
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1366 r->header_start = new + (r->header_start - old);
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1367 r->header_end = new + (r->header_end - old);
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1368 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1369
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1370 r->header_in = b;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1371
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1372 return NGX_OK;
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1373 }
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1374
5cdc4838d4e8 nginx-0.0.11-2004-09-22-20:18:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 432
diff changeset
1375
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1376 static ngx_int_t
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1377 ngx_http_process_header_line(ngx_http_request_t *r, ngx_table_elt_t *h,
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1378 ngx_uint_t offset)
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1379 {
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1380 ngx_table_elt_t **ph;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1381
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1382 ph = (ngx_table_elt_t **) ((char *) &r->headers_in + offset);
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1383
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1384 if (*ph == NULL) {
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1385 *ph = h;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1386 }
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1387
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1388 return NGX_OK;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1389 }
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1390
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1391
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1392 static ngx_int_t
523
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1393 ngx_http_process_unique_header_line(ngx_http_request_t *r, ngx_table_elt_t *h,
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1394 ngx_uint_t offset)
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1395 {
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1396 ngx_table_elt_t **ph;
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1397
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1398 ph = (ngx_table_elt_t **) ((char *) &r->headers_in + offset);
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1399
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1400 if (*ph == NULL) {
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1401 *ph = h;
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1402 return NGX_OK;
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1403 }
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1404
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1405 ngx_log_error(NGX_LOG_INFO, r->connection->log, 0,
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1406 "client sent duplicate header line: \"%V: %V\", "
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1407 "previous value: \"%V: %V\"",
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
1408 &h->key, &h->value, &(*ph)->key, &(*ph)->value);
523
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1409
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1410 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1411
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1412 return NGX_ERROR;
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1413 }
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1414
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1415
2019117e6b38 nginx-0.1.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1416 static ngx_int_t
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1417 ngx_http_process_host(ngx_http_request_t *r, ngx_table_elt_t *h,
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1418 ngx_uint_t offset)
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1419 {
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1420 ngx_int_t rc;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1421 ngx_str_t host;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1422
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1423 if (r->headers_in.host == NULL) {
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1424 r->headers_in.host = h;
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1425 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1426
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1427 host = h->value;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1428
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1429 rc = ngx_http_validate_host(&host, r->pool, 0);
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1430
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1431 if (rc == NGX_DECLINED) {
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1432 ngx_log_error(NGX_LOG_INFO, r->connection->log, 0,
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1433 "client sent invalid host header");
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1434 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1435 return NGX_ERROR;
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1436 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1437
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1438 if (rc == NGX_ERROR) {
3152
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1439 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1440 return NGX_ERROR;
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1441 }
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1442
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1443 if (r->headers_in.server.len) {
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1444 return NGX_OK;
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1445 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1446
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1447 r->headers_in.server = host;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1448
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1449 return NGX_OK;
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1450 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1451
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1452
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1453 static ngx_int_t
1467
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1454 ngx_http_process_connection(ngx_http_request_t *r, ngx_table_elt_t *h,
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1455 ngx_uint_t offset)
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1456 {
1549
099d8470e6c3 pass length clearly
Igor Sysoev <igor@sysoev.ru>
parents: 1543
diff changeset
1457 if (ngx_strcasestrn(h->value.data, "close", 5 - 1)) {
1467
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1458 r->headers_in.connection_type = NGX_HTTP_CONNECTION_CLOSE;
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1459
1549
099d8470e6c3 pass length clearly
Igor Sysoev <igor@sysoev.ru>
parents: 1543
diff changeset
1460 } else if (ngx_strcasestrn(h->value.data, "keep-alive", 10 - 1)) {
1467
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1461 r->headers_in.connection_type = NGX_HTTP_CONNECTION_KEEP_ALIVE;
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1462 }
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1463
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1464 return NGX_OK;
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1465 }
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1466
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1467
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1468 static ngx_int_t
2004
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1469 ngx_http_process_user_agent(ngx_http_request_t *r, ngx_table_elt_t *h,
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1470 ngx_uint_t offset)
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1471 {
2205
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1472 u_char *user_agent, *msie;
2004
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1473
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1474 if (r->headers_in.user_agent) {
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1475 return NGX_OK;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1476 }
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1477
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1478 r->headers_in.user_agent = h;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1479
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1480 /* check some widespread browsers while the header is in CPU cache */
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1481
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1482 user_agent = h->value.data;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1483
2205
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1484 msie = ngx_strstrn(user_agent, "MSIE ", 5 - 1);
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1485
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1486 if (msie && msie + 7 < user_agent + h->value.len) {
2004
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1487
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1488 r->headers_in.msie = 1;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1489
2205
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1490 if (msie[6] == '.') {
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1491
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1492 switch (msie[5]) {
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1493 case '4':
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1494 case '5':
3054
a137de814516 do not disable gzip for MSIE 6.0 SV1 in "gzip_disable msie6"
Igor Sysoev <igor@sysoev.ru>
parents: 3052
diff changeset
1495 r->headers_in.msie6 = 1;
a137de814516 do not disable gzip for MSIE 6.0 SV1 in "gzip_disable msie6"
Igor Sysoev <igor@sysoev.ru>
parents: 3052
diff changeset
1496 break;
2205
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1497 case '6':
3054
a137de814516 do not disable gzip for MSIE 6.0 SV1 in "gzip_disable msie6"
Igor Sysoev <igor@sysoev.ru>
parents: 3052
diff changeset
1498 if (ngx_strstrn(msie + 8, "SV1", 3 - 1) == NULL) {
a137de814516 do not disable gzip for MSIE 6.0 SV1 in "gzip_disable msie6"
Igor Sysoev <igor@sysoev.ru>
parents: 3052
diff changeset
1499 r->headers_in.msie6 = 1;
a137de814516 do not disable gzip for MSIE 6.0 SV1 in "gzip_disable msie6"
Igor Sysoev <igor@sysoev.ru>
parents: 3052
diff changeset
1500 }
a137de814516 do not disable gzip for MSIE 6.0 SV1 in "gzip_disable msie6"
Igor Sysoev <igor@sysoev.ru>
parents: 3052
diff changeset
1501 break;
2205
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1502 }
2004
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1503 }
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1504
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1505 #if 0
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1506 /* MSIE ignores the SSL "close notify" alert */
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1507 if (c->ssl) {
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1508 c->ssl->no_send_shutdown = 1;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1509 }
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1510 #endif
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1511 }
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1512
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1513 if (ngx_strstrn(user_agent, "Opera", 5 - 1)) {
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1514 r->headers_in.opera = 1;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1515 r->headers_in.msie = 0;
2205
5398f47082f0 gzip_disable msie6
Igor Sysoev <igor@sysoev.ru>
parents: 2195
diff changeset
1516 r->headers_in.msie6 = 0;
2004
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1517 }
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1518
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1519 if (!r->headers_in.msie && !r->headers_in.opera) {
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1520
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1521 if (ngx_strstrn(user_agent, "Gecko/", 6 - 1)) {
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1522 r->headers_in.gecko = 1;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1523
3315
63fafb988446 r->chrome
Igor Sysoev <igor@sysoev.ru>
parents: 3287
diff changeset
1524 } else if (ngx_strstrn(user_agent, "Chrome/", 7 - 1)) {
63fafb988446 r->chrome
Igor Sysoev <igor@sysoev.ru>
parents: 3287
diff changeset
1525 r->headers_in.chrome = 1;
63fafb988446 r->chrome
Igor Sysoev <igor@sysoev.ru>
parents: 3287
diff changeset
1526
4552
b00098cbc44d Restricted keepalive_disable safari to OS X only.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4472
diff changeset
1527 } else if (ngx_strstrn(user_agent, "Safari/", 7 - 1)
b00098cbc44d Restricted keepalive_disable safari to OS X only.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4472
diff changeset
1528 && ngx_strstrn(user_agent, "Mac OS X", 8 - 1))
b00098cbc44d Restricted keepalive_disable safari to OS X only.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4472
diff changeset
1529 {
3419
fcd72b8d69f3 disable keepalive for Safari:
Igor Sysoev <igor@sysoev.ru>
parents: 3416
diff changeset
1530 r->headers_in.safari = 1;
fcd72b8d69f3 disable keepalive for Safari:
Igor Sysoev <igor@sysoev.ru>
parents: 3416
diff changeset
1531
2004
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1532 } else if (ngx_strstrn(user_agent, "Konqueror", 9 - 1)) {
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1533 r->headers_in.konqueror = 1;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1534 }
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1535 }
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1536
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1537 return NGX_OK;
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1538 }
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1539
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1540
38fa1d3a31b7 test user agent in header callback
Igor Sysoev <igor@sysoev.ru>
parents: 1974
diff changeset
1541 static ngx_int_t
5084
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1542 ngx_http_process_multi_header_lines(ngx_http_request_t *r, ngx_table_elt_t *h,
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1543 ngx_uint_t offset)
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1544 {
5084
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1545 ngx_array_t *headers;
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1546 ngx_table_elt_t **ph;
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1547
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1548 headers = (ngx_array_t *) ((char *) &r->headers_in + offset);
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1549
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1550 if (headers->elts == NULL) {
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1551 if (ngx_array_init(headers, r->pool, 1, sizeof(ngx_table_elt_t *))
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1552 != NGX_OK)
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1553 {
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1554 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1555 return NGX_ERROR;
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1556 }
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1557 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1558
5084
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1559 ph = ngx_array_push(headers);
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1560 if (ph == NULL) {
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1561 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1562 return NGX_ERROR;
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1563 }
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1564
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1565 *ph = h;
f7fe817c92a2 Correctly handle multiple X-Forwarded-For headers (ticket #106).
Ruslan Ermilov <ru@nginx.com>
parents: 5082
diff changeset
1566 return NGX_OK;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1567 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1568
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1569
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1570 static ngx_int_t
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1571 ngx_http_process_request_header(ngx_http_request_t *r)
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1572 {
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1573 if (ngx_http_set_virtual_server(r, &r->headers_in.server) == NGX_ERROR) {
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1574 return NGX_ERROR;
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1575 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1576
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1577 if (r->headers_in.host == NULL && r->http_version > NGX_HTTP_VERSION_10) {
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1578 ngx_log_error(NGX_LOG_INFO, r->connection->log, 0,
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1579 "client sent HTTP/1.1 request without \"Host\" header");
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1580 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1581 return NGX_ERROR;
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1582 }
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1583
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1584 if (r->headers_in.content_length) {
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1585 r->headers_in.content_length_n =
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 657
diff changeset
1586 ngx_atoof(r->headers_in.content_length->value.data,
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1587 r->headers_in.content_length->value.len);
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1588
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1589 if (r->headers_in.content_length_n == NGX_ERROR) {
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1590 ngx_log_error(NGX_LOG_INFO, r->connection->log, 0,
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1591 "client sent invalid \"Content-Length\" header");
4930
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1592 ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
1593 return NGX_ERROR;
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1594 }
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1595 }
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1596
1464
3263e4b17903 style fix
Igor Sysoev <igor@sysoev.ru>
parents: 1434
diff changeset
1597 if (r->method & NGX_HTTP_TRACE) {
1151
b1ebd03de948 disable TRACE method
Igor Sysoev <igor@sysoev.ru>
parents: 1135
diff changeset
1598 ngx_log_error(NGX_LOG_INFO, r->connection->log, 0,
b1ebd03de948 disable TRACE method
Igor Sysoev <igor@sysoev.ru>
parents: 1135
diff changeset
1599 "client sent TRACE method");
b1ebd03de948 disable TRACE method
Igor Sysoev <igor@sysoev.ru>
parents: 1135
diff changeset
1600 ngx_http_finalize_request(r, NGX_HTTP_NOT_ALLOWED);
b1ebd03de948 disable TRACE method
Igor Sysoev <igor@sysoev.ru>
parents: 1135
diff changeset
1601 return NGX_ERROR;
b1ebd03de948 disable TRACE method
Igor Sysoev <igor@sysoev.ru>
parents: 1135
diff changeset
1602 }
b1ebd03de948 disable TRACE method
Igor Sysoev <igor@sysoev.ru>
parents: 1135
diff changeset
1603
4930
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1604 if (r->headers_in.transfer_encoding) {
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1605 if (r->headers_in.transfer_encoding->value.len == 7
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1606 && ngx_strncasecmp(r->headers_in.transfer_encoding->value.data,
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1607 (u_char *) "chunked", 7) == 0)
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1608 {
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1609 r->headers_in.content_length = NULL;
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1610 r->headers_in.content_length_n = -1;
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1611 r->headers_in.chunked = 1;
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1612
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1613 } else if (r->headers_in.transfer_encoding->value.len != 8
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1614 || ngx_strncasecmp(r->headers_in.transfer_encoding->value.data,
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1615 (u_char *) "identity", 8) != 0)
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1616 {
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1617 ngx_log_error(NGX_LOG_INFO, r->connection->log, 0,
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1618 "client sent unknown \"Transfer-Encoding\": \"%V\"",
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1619 &r->headers_in.transfer_encoding->value);
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1620 ngx_http_finalize_request(r, NGX_HTTP_NOT_IMPLEMENTED);
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1621 return NGX_ERROR;
6f085bfcdb4d Request body: chunked transfer encoding support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4891
diff changeset
1622 }
298
4a3f18406832 nginx-0.0.3-2004-03-30-10:27:36 import
Igor Sysoev <igor@sysoev.ru>
parents: 294
diff changeset
1623 }
4a3f18406832 nginx-0.0.3-2004-03-30-10:27:36 import
Igor Sysoev <igor@sysoev.ru>
parents: 294
diff changeset
1624
1467
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1625 if (r->headers_in.connection_type == NGX_HTTP_CONNECTION_KEEP_ALIVE) {
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1626 if (r->headers_in.keep_alive) {
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1627 r->headers_in.keep_alive_n =
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1628 ngx_atotm(r->headers_in.keep_alive->value.data,
e5352b711c47 there may be several "Connection" header lines and each may have several tokens
Igor Sysoev <igor@sysoev.ru>
parents: 1464
diff changeset
1629 r->headers_in.keep_alive->value.len);
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1630 }
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1631 }
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1632
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1633 return NGX_OK;
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1634 }
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1635
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1636
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1637 static void
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1638 ngx_http_process_request(ngx_http_request_t *r)
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1639 {
1704
e584e946e198 move condition declarations inside blocks where they are used
Igor Sysoev <igor@sysoev.ru>
parents: 1677
diff changeset
1640 ngx_connection_t *c;
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1641
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1642 c = r->connection;
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1643
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1644 #if (NGX_HTTP_SSL)
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1645
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
1646 if (r->http_connection->ssl) {
1704
e584e946e198 move condition declarations inside blocks where they are used
Igor Sysoev <igor@sysoev.ru>
parents: 1677
diff changeset
1647 long rc;
1974
f32cc6df6bd6 fix memory leak when ssl_verify_client is on
Igor Sysoev <igor@sysoev.ru>
parents: 1924
diff changeset
1648 X509 *cert;
1704
e584e946e198 move condition declarations inside blocks where they are used
Igor Sysoev <igor@sysoev.ru>
parents: 1677
diff changeset
1649 ngx_http_ssl_srv_conf_t *sscf;
e584e946e198 move condition declarations inside blocks where they are used
Igor Sysoev <igor@sysoev.ru>
parents: 1677
diff changeset
1650
5091
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
1651 if (c->ssl == NULL) {
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
1652 ngx_log_error(NGX_LOG_INFO, c->log, 0,
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
1653 "client sent plain HTTP request to HTTPS port");
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
1654 ngx_http_finalize_request(r, NGX_HTTP_TO_HTTPS);
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
1655 return;
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
1656 }
d3e256c67d6d SSL: do not treat SSL handshake as request.
Valentin Bartenev <vbart@nginx.com>
parents: 5090
diff changeset
1657
669
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1658 sscf = ngx_http_get_module_srv_conf(r, ngx_http_ssl_module);
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1659
2994
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1660 if (sscf->verify) {
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1661 rc = SSL_get_verify_result(c->ssl->connection);
669
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1662
4884
e406c997470a SSL: the "ssl_verify_client" directive parameter "optional_no_ca".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4770
diff changeset
1663 if (rc != X509_V_OK
e406c997470a SSL: the "ssl_verify_client" directive parameter "optional_no_ca".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4770
diff changeset
1664 && (sscf->verify != 3 || !ngx_ssl_verify_error_optional(rc)))
e406c997470a SSL: the "ssl_verify_client" directive parameter "optional_no_ca".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4770
diff changeset
1665 {
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1666 ngx_log_error(NGX_LOG_INFO, c->log, 0,
671
cec32b3753ac nginx-0.3.57-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 669
diff changeset
1667 "client SSL certificate verify error: (%l:%s)",
669
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1668 rc, X509_verify_cert_error_string(rc));
1924
291689a7e5dc invalidate SSL session if there is no valid client certificate
Igor Sysoev <igor@sysoev.ru>
parents: 1894
diff changeset
1669
291689a7e5dc invalidate SSL session if there is no valid client certificate
Igor Sysoev <igor@sysoev.ru>
parents: 1894
diff changeset
1670 ngx_ssl_remove_cached_session(sscf->ssl.ctx,
291689a7e5dc invalidate SSL session if there is no valid client certificate
Igor Sysoev <igor@sysoev.ru>
parents: 1894
diff changeset
1671 (SSL_get0_session(c->ssl->connection)));
291689a7e5dc invalidate SSL session if there is no valid client certificate
Igor Sysoev <igor@sysoev.ru>
parents: 1894
diff changeset
1672
669
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1673 ngx_http_finalize_request(r, NGX_HTTPS_CERT_ERROR);
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1674 return;
669
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1675 }
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1676
2994
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1677 if (sscf->verify == 1) {
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1678 cert = SSL_get_peer_certificate(c->ssl->connection);
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1679
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1680 if (cert == NULL) {
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1681 ngx_log_error(NGX_LOG_INFO, c->log, 0,
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1682 "client sent no required SSL certificate");
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1683
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1684 ngx_ssl_remove_cached_session(sscf->ssl.ctx,
1924
291689a7e5dc invalidate SSL session if there is no valid client certificate
Igor Sysoev <igor@sysoev.ru>
parents: 1894
diff changeset
1685 (SSL_get0_session(c->ssl->connection)));
291689a7e5dc invalidate SSL session if there is no valid client certificate
Igor Sysoev <igor@sysoev.ru>
parents: 1894
diff changeset
1686
2994
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1687 ngx_http_finalize_request(r, NGX_HTTPS_NO_CERT);
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1688 return;
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1689 }
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1690
f33c48457d0c *) $ssl_client_verify
Igor Sysoev <igor@sysoev.ru>
parents: 2993
diff changeset
1691 X509_free(cert);
669
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1692 }
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1693 }
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1694 }
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1695
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1696 #endif
562806624c4a nginx-0.3.56-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1697
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1698 if (c->read->timer_set) {
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1699 ngx_del_timer(c->read);
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1700 }
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1701
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1702 #if (NGX_STAT_STUB)
2951
5acd98486a33 ignore ngx_atomic_fetch_add() result
Igor Sysoev <igor@sysoev.ru>
parents: 2902
diff changeset
1703 (void) ngx_atomic_fetch_add(ngx_stat_reading, -1);
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1704 r->stat_reading = 0;
2951
5acd98486a33 ignore ngx_atomic_fetch_add() result
Igor Sysoev <igor@sysoev.ru>
parents: 2902
diff changeset
1705 (void) ngx_atomic_fetch_add(ngx_stat_writing, 1);
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1706 r->stat_writing = 1;
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1707 #endif
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1708
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1709 c->read->handler = ngx_http_request_handler;
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1710 c->write->handler = ngx_http_request_handler;
1368
202cae9a0c2b rename ngx_http_block_read() and ngx_http_test_read() to ..._reading()
Igor Sysoev <igor@sysoev.ru>
parents: 1283
diff changeset
1711 r->read_event_handler = ngx_http_block_reading;
1233
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1712
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1713 ngx_http_handler(r);
754f3648642d fix ssl_verify_client for HTTP/0.9
Igor Sysoev <igor@sysoev.ru>
parents: 1219
diff changeset
1714
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1715 ngx_http_run_posted_requests(c);
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1716 }
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1717
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
1718
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1719 static ngx_int_t
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1720 ngx_http_validate_host(ngx_str_t *host, ngx_pool_t *pool, ngx_uint_t alloc)
477
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
1721 {
4313
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1722 u_char *h, ch;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1723 size_t i, dot_pos, host_len;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1724
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1725 enum {
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1726 sw_usual = 0,
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1727 sw_literal,
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1728 sw_rest
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1729 } state;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1730
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1731 dot_pos = host->len;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1732 host_len = host->len;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1733
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1734 h = host->data;
4313
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1735
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1736 state = sw_usual;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1737
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1738 for (i = 0; i < host->len; i++) {
3152
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1739 ch = h[i];
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1740
4313
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1741 switch (ch) {
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1742
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1743 case '.':
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1744 if (dot_pos == i - 1) {
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1745 return NGX_DECLINED;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1746 }
4313
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1747 dot_pos = i;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1748 break;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1749
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1750 case ':':
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1751 if (state == sw_usual) {
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1752 host_len = i;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1753 state = sw_rest;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1754 }
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1755 break;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1756
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1757 case '[':
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1758 if (i == 0) {
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1759 state = sw_literal;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1760 }
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1761 break;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1762
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1763 case ']':
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1764 if (state == sw_literal) {
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1765 host_len = i + 1;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1766 state = sw_rest;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1767 }
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1768 break;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1769
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1770 case '\0':
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1771 return NGX_DECLINED;
4313
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1772
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1773 default:
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1774
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1775 if (ngx_path_separator(ch)) {
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1776 return NGX_DECLINED;
4313
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1777 }
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1778
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1779 if (ch >= 'A' && ch <= 'Z') {
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1780 alloc = 1;
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1781 }
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1782
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1783 break;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1784 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1785 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1786
4313
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1787 if (dot_pos == host_len - 1) {
e7db97bfac25 Added support for IP-literal in the Host header and request line (ticket #1).
Valentin Bartenev <vbart@nginx.com>
parents: 4304
diff changeset
1788 host_len--;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1789 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1790
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1791 if (host_len == 0) {
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1792 return NGX_DECLINED;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1793 }
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1794
3152
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1795 if (alloc) {
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1796 host->data = ngx_pnalloc(pool, host_len);
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1797 if (host->data == NULL) {
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1798 return NGX_ERROR;
3152
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1799 }
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1800
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1801 ngx_strlow(host->data, h, host_len);
3152
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1802 }
8bf534c7c998 $host is always in low case:
Igor Sysoev <igor@sysoev.ru>
parents: 3145
diff changeset
1803
5087
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1804 host->len = host_len;
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1805
66e0f9adbc8c Changed interface of ngx_http_validate_host().
Valentin Bartenev <vbart@nginx.com>
parents: 5086
diff changeset
1806 return NGX_OK;
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1807 }
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1808
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1809
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1810 static ngx_int_t
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1811 ngx_http_set_virtual_server(ngx_http_request_t *r, ngx_str_t *host)
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1812 {
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1813 ngx_int_t rc;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1814 ngx_http_connection_t *hc;
593
425af804d968 nginx-0.3.18-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
1815 ngx_http_core_loc_conf_t *clcf;
425af804d968 nginx-0.3.18-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
1816 ngx_http_core_srv_conf_t *cscf;
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1817
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1818 hc = r->http_connection;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1819
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1820 rc = ngx_http_find_virtual_server(r->connection,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1821 hc->addr_conf->virtual_names,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1822 host, r, &cscf);
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1823
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1824 if (rc == NGX_ERROR) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1825 ngx_http_close_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1826 return NGX_ERROR;
477
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
1827 }
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
1828
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1829 if (rc == NGX_DECLINED) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1830 return NGX_OK;
1387
cb8b30ef3e7e regex in server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1373
diff changeset
1831 }
cb8b30ef3e7e regex in server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1373
diff changeset
1832
593
425af804d968 nginx-0.3.18-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
1833 r->srv_conf = cscf->ctx->srv_conf;
425af804d968 nginx-0.3.18-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
1834 r->loc_conf = cscf->ctx->loc_conf;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1835
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1836 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
5086
1b204b8ea9a3 Introduced the ngx_http_set_connection_log() macro.
Valentin Bartenev <vbart@nginx.com>
parents: 5085
diff changeset
1837
1b204b8ea9a3 Introduced the ngx_http_set_connection_log() macro.
Valentin Bartenev <vbart@nginx.com>
parents: 5085
diff changeset
1838 ngx_http_set_connection_log(r->connection, clcf->error_log);
477
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
1839
2007
b9de93d804ea *) host in request line has priority
Igor Sysoev <igor@sysoev.ru>
parents: 2005
diff changeset
1840 return NGX_OK;
477
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
1841 }
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
1842
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
1843
5088
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1844 static ngx_int_t
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1845 ngx_http_find_virtual_server(ngx_connection_t *c,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1846 ngx_http_virtual_names_t *virtual_names, ngx_str_t *host,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1847 ngx_http_request_t *r, ngx_http_core_srv_conf_t **cscfp)
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1848 {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1849 ngx_http_core_srv_conf_t *cscf;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1850
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1851 if (virtual_names == NULL) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1852 return NGX_DECLINED;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1853 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1854
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1855 cscf = ngx_hash_find_combined(&virtual_names->names,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1856 ngx_hash_key(host->data, host->len),
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1857 host->data, host->len);
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1858
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1859 if (cscf) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1860 *cscfp = cscf;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1861 return NGX_OK;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1862 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1863
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1864 #if (NGX_PCRE)
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1865
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1866 if (host->len && virtual_names->nregex) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1867 ngx_int_t n;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1868 ngx_uint_t i;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1869 ngx_http_server_name_t *sn;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1870
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1871 sn = virtual_names->regex;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1872
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1873 #ifdef SSL_CTRL_SET_TLSEXT_HOSTNAME
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1874
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1875 if (r == NULL) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1876 for (i = 0; i < virtual_names->nregex; i++) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1877
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1878 n = ngx_regex_exec(sn[i].regex->regex, host, NULL, 0);
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1879
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1880 if (n == NGX_REGEX_NO_MATCHED) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1881 continue;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1882 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1883
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1884 if (n >= 0) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1885 *cscfp = sn[i].server;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1886 return NGX_OK;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1887 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1888
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1889 ngx_log_error(NGX_LOG_ALERT, c->log, 0,
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1890 ngx_regex_exec_n " failed: %i "
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1891 "on \"%V\" using \"%V\"",
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1892 n, host, &sn[i].regex->name);
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1893
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1894 return NGX_ERROR;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1895 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1896
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1897 return NGX_DECLINED;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1898 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1899
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1900 #endif /* SSL_CTRL_SET_TLSEXT_HOSTNAME */
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1901
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1902 for (i = 0; i < virtual_names->nregex; i++) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1903
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1904 n = ngx_http_regex_exec(r, sn[i].regex, host);
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1905
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1906 if (n == NGX_DECLINED) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1907 continue;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1908 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1909
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1910 if (n == NGX_OK) {
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1911 *cscfp = sn[i].server;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1912 return NGX_OK;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1913 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1914
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1915 return NGX_ERROR;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1916 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1917 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1918
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1919 #endif /* NGX_PCRE */
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1920
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1921 return NGX_DECLINED;
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1922 }
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1923
ac31fcecb464 SNI: ignore captures in server_name regexes when matching by SNI.
Valentin Bartenev <vbart@nginx.com>
parents: 5087
diff changeset
1924
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1925 static void
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1926 ngx_http_request_handler(ngx_event_t *ev)
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1927 {
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1928 ngx_connection_t *c;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1929 ngx_http_request_t *r;
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1930 ngx_http_log_ctx_t *ctx;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1931
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1932 c = ev->data;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1933 r = c->data;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1934
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1935 ctx = c->log->data;
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1936 ctx->current_request = r;
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1937
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1938 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0,
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1939 "http run request: \"%V?%V\"", &r->uri, &r->args);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1940
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1941 if (ev->write) {
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1942 r->write_event_handler(r);
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1943
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1944 } else {
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1945 r->read_event_handler(r);
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
1946 }
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1947
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1948 ngx_http_run_posted_requests(c);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1949 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1950
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1951
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1952 void
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1953 ngx_http_run_posted_requests(ngx_connection_t *c)
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1954 {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1955 ngx_http_request_t *r;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1956 ngx_http_log_ctx_t *ctx;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1957 ngx_http_posted_request_t *pr;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1958
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1959 for ( ;; ) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1960
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1961 if (c->destroyed) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1962 return;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1963 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1964
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1965 r = c->data;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1966 pr = r->main->posted_requests;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1967
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1968 if (pr == NULL) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1969 return;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1970 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1971
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1972 r->main->posted_requests = pr->next;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1973
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1974 r = pr->request;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1975
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1976 ctx = c->log->data;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1977 ctx->current_request = r;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1978
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1979 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0,
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1980 "http posted request: \"%V?%V\"", &r->uri, &r->args);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1981
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1982 r->write_event_handler(r);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1983 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1984 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1985
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1986
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1987 ngx_int_t
3064
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
1988 ngx_http_post_request(ngx_http_request_t *r, ngx_http_posted_request_t *pr)
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1989 {
3064
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
1990 ngx_http_posted_request_t **p;
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
1991
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1992 if (pr == NULL) {
3064
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
1993 pr = ngx_palloc(r->pool, sizeof(ngx_http_posted_request_t));
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
1994 if (pr == NULL) {
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
1995 return NGX_ERROR;
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
1996 }
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1997 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1998
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
1999 pr->request = r;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2000 pr->next = NULL;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2001
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2002 for (p = &r->main->posted_requests; *p; p = &(*p)->next) { /* void */ }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2003
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2004 *p = pr;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2005
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2006 return NGX_OK;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2007 }
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2008
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2009
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2010 void
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2011 ngx_http_finalize_request(ngx_http_request_t *r, ngx_int_t rc)
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2012 {
1424
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2013 ngx_connection_t *c;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2014 ngx_http_request_t *pr;
210
00cafae0bdf1 nginx-0.0.1-2003-12-14-23:10:27 import
Igor Sysoev <igor@sysoev.ru>
parents: 209
diff changeset
2015 ngx_http_core_loc_conf_t *clcf;
00cafae0bdf1 nginx-0.0.1-2003-12-14-23:10:27 import
Igor Sysoev <igor@sysoev.ru>
parents: 209
diff changeset
2016
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2017 c = r->connection;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2018
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2019 ngx_log_debug5(NGX_LOG_DEBUG_HTTP, c->log, 0,
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2020 "http finalize request: %d, \"%V?%V\" a:%d, c:%d",
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2021 rc, &r->uri, &r->args, r == c->data, r->main->count);
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2022
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2023 if (rc == NGX_DONE) {
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2024 ngx_http_finalize_connection(r);
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2025 return;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2026 }
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2027
2819
43fe53832da7 handle big responses for "size" and "test" image_filters
Igor Sysoev <igor@sysoev.ru>
parents: 2785
diff changeset
2028 if (rc == NGX_OK && r->filter_finalize) {
43fe53832da7 handle big responses for "size" and "test" image_filters
Igor Sysoev <igor@sysoev.ru>
parents: 2785
diff changeset
2029 c->error = 1;
43fe53832da7 handle big responses for "size" and "test" image_filters
Igor Sysoev <igor@sysoev.ru>
parents: 2785
diff changeset
2030 }
43fe53832da7 handle big responses for "size" and "test" image_filters
Igor Sysoev <igor@sysoev.ru>
parents: 2785
diff changeset
2031
681
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
2032 if (rc == NGX_DECLINED) {
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
2033 r->content_handler = NULL;
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
2034 r->write_event_handler = ngx_http_core_run_phases;
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
2035 ngx_http_core_run_phases(r);
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
2036 return;
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
2037 }
7e24168b0853 nginx-0.4.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 675
diff changeset
2038
777
4ab852b691f5 <!--#include virtual=... set=... -->
Igor Sysoev <igor@sysoev.ru>
parents: 716
diff changeset
2039 if (r != r->main && r->post_subrequest) {
4ab852b691f5 <!--#include virtual=... set=... -->
Igor Sysoev <igor@sysoev.ru>
parents: 716
diff changeset
2040 rc = r->post_subrequest->handler(r, r->post_subrequest->data, rc);
667
63a820b0bc6c nginx-0.3.55-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 665
diff changeset
2041 }
63a820b0bc6c nginx-0.3.55-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 665
diff changeset
2042
1783
cfb879757a43 call post_action for 499
Igor Sysoev <igor@sysoev.ru>
parents: 1779
diff changeset
2043 if (rc == NGX_ERROR
cfb879757a43 call post_action for 499
Igor Sysoev <igor@sysoev.ru>
parents: 1779
diff changeset
2044 || rc == NGX_HTTP_REQUEST_TIME_OUT
cfb879757a43 call post_action for 499
Igor Sysoev <igor@sysoev.ru>
parents: 1779
diff changeset
2045 || rc == NGX_HTTP_CLIENT_CLOSED_REQUEST
cfb879757a43 call post_action for 499
Igor Sysoev <igor@sysoev.ru>
parents: 1779
diff changeset
2046 || c->error)
cfb879757a43 call post_action for 499
Igor Sysoev <igor@sysoev.ru>
parents: 1779
diff changeset
2047 {
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
2048 if (ngx_http_post_action(r) == NGX_OK) {
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
2049 return;
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
2050 }
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
2051
3052
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2052 if (r->main->blocked) {
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2053 r->write_event_handler = ngx_http_request_finalizer;
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2054 }
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2055
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2056 ngx_http_terminate_request(r, rc);
142
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
2057 return;
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
2058 }
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
2059
637
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
2060 if (rc >= NGX_HTTP_SPECIAL_RESPONSE
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
2061 || rc == NGX_HTTP_CREATED
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
2062 || rc == NGX_HTTP_NO_CONTENT)
e60fe4cf1d4e nginx-0.3.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 635
diff changeset
2063 {
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
2064 if (rc == NGX_HTTP_CLOSE) {
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2065 ngx_http_terminate_request(r, rc);
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
2066 return;
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
2067 }
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
2068
597
9262f520ce21 nginx-0.3.20-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 593
diff changeset
2069 if (r == r->main) {
1424
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2070 if (c->read->timer_set) {
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2071 ngx_del_timer(c->read);
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2072 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2073
1424
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2074 if (c->write->timer_set) {
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2075 ngx_del_timer(c->write);
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2076 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2077 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2078
2250
7fc20e1105cd set request handlers, this fixes complex proxied 400 handler with SSI includes
Igor Sysoev <igor@sysoev.ru>
parents: 2233
diff changeset
2079 c->read->handler = ngx_http_request_handler;
7fc20e1105cd set request handlers, this fixes complex proxied 400 handler with SSI includes
Igor Sysoev <igor@sysoev.ru>
parents: 2233
diff changeset
2080 c->write->handler = ngx_http_request_handler;
7fc20e1105cd set request handlers, this fixes complex proxied 400 handler with SSI includes
Igor Sysoev <igor@sysoev.ru>
parents: 2233
diff changeset
2081
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2082 ngx_http_finalize_request(r, ngx_http_special_response_handler(r, rc));
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2083 return;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2084 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2085
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2086 if (r != r->main) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2087
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2088 if (r->buffered || r->postponed) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2089
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2090 if (ngx_http_set_write_handler(r) != NGX_OK) {
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2091 ngx_http_terminate_request(r, 0);
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2092 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2093
525
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2094 return;
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2095 }
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2096
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2097 pr = r->parent;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2098
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2099 if (r == c->data) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2100
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2101 r->main->count--;
4471
b19a651471d9 Core: protection from subrequest loops.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
2102 r->main->subrequests++;
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2103
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2104 if (!r->logged) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2105
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2106 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2107
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2108 if (clcf->log_subrequest) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2109 ngx_http_log_request(r);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2110 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2111
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2112 r->logged = 1;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2113
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2114 } else {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2115 ngx_log_error(NGX_LOG_ALERT, c->log, 0,
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2116 "subrequest: \"%V?%V\" logged again",
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2117 &r->uri, &r->args);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2118 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2119
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2120 r->done = 1;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2121
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2122 if (pr->postponed && pr->postponed->request == r) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2123 pr->postponed = pr->postponed->next;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2124 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2125
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2126 c->data = pr;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2127
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2128 } else {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2129
4612
c42553296af1 Removed surplus condition.
Valentin Bartenev <vbart@nginx.com>
parents: 4594
diff changeset
2130 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0,
c42553296af1 Removed surplus condition.
Valentin Bartenev <vbart@nginx.com>
parents: 4594
diff changeset
2131 "http finalize non-active request: \"%V?%V\"",
c42553296af1 Removed surplus condition.
Valentin Bartenev <vbart@nginx.com>
parents: 4594
diff changeset
2132 &r->uri, &r->args);
c42553296af1 Removed surplus condition.
Valentin Bartenev <vbart@nginx.com>
parents: 4594
diff changeset
2133
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2134 r->write_event_handler = ngx_http_request_finalizer;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2135
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2136 if (r->waited) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2137 r->done = 1;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2138 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2139 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2140
3064
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
2141 if (ngx_http_post_request(pr, NULL) != NGX_OK) {
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2142 r->main->count++;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2143 ngx_http_terminate_request(r, 0);
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2144 return;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2145 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2146
1424
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2147 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0,
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2148 "http wake parent request: \"%V?%V\"",
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2149 &pr->uri, &pr->args);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2150
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2151 return;
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2152 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2153
3052
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2154 if (r->buffered || c->buffered || r->postponed || r->blocked) {
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2155
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2156 if (ngx_http_set_write_handler(r) != NGX_OK) {
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2157 ngx_http_terminate_request(r, 0);
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
2158 }
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
2159
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2160 return;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2161 }
160
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
2162
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2163 if (r != c->data) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2164 ngx_log_error(NGX_LOG_ALERT, c->log, 0,
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2165 "http finalize non-active request: \"%V?%V\"",
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2166 &r->uri, &r->args);
142
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
2167 return;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 525
diff changeset
2168 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 525
diff changeset
2169
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2170 r->done = 1;
3415
1b8c3599e3ce Fix segfault when while discarding body a write event handler is called,
Igor Sysoev <igor@sysoev.ru>
parents: 3325
diff changeset
2171 r->write_event_handler = ngx_http_request_empty_handler;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2172
629
65bf042c0b4f nginx-0.3.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 623
diff changeset
2173 if (!r->post_action) {
65bf042c0b4f nginx-0.3.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 623
diff changeset
2174 r->request_complete = 1;
65bf042c0b4f nginx-0.3.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 623
diff changeset
2175 }
65bf042c0b4f nginx-0.3.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 623
diff changeset
2176
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
2177 if (ngx_http_post_action(r) == NGX_OK) {
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 573
diff changeset
2178 return;
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 573
diff changeset
2179 }
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 573
diff changeset
2180
1424
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2181 if (c->read->timer_set) {
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2182 ngx_del_timer(c->read);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2183 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2184
1424
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2185 if (c->write->timer_set) {
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2186 c->write->delayed = 0;
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2187 ngx_del_timer(c->write);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2188 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2189
1424
937fbbf611cd optimize r->connection in ngx_http_finalize_request()
Igor Sysoev <igor@sysoev.ru>
parents: 1423
diff changeset
2190 if (c->read->eof) {
1423
75e908236701 cancel keep-alive and lingering close on EOF
Igor Sysoev <igor@sysoev.ru>
parents: 1387
diff changeset
2191 ngx_http_close_request(r, 0);
75e908236701 cancel keep-alive and lingering close on EOF
Igor Sysoev <igor@sysoev.ru>
parents: 1387
diff changeset
2192 return;
75e908236701 cancel keep-alive and lingering close on EOF
Igor Sysoev <igor@sysoev.ru>
parents: 1387
diff changeset
2193 }
75e908236701 cancel keep-alive and lingering close on EOF
Igor Sysoev <igor@sysoev.ru>
parents: 1387
diff changeset
2194
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2195 ngx_http_finalize_connection(r);
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2196 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2197
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2198
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2199 static void
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2200 ngx_http_terminate_request(ngx_http_request_t *r, ngx_int_t rc)
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2201 {
3064
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
2202 ngx_http_cleanup_t *cln;
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
2203 ngx_http_request_t *mr;
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
2204 ngx_http_ephemeral_t *e;
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2205
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2206 mr = r->main;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2207
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2208 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
3052
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2209 "http terminate request count:%d", mr->count);
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2210
3176
60bc5cc68d3b log 499 instead 0, the bug was introduced in r3050
Igor Sysoev <igor@sysoev.ru>
parents: 3153
diff changeset
2211 if (rc > 0 && (mr->headers_out.status == 0 || mr->connection->sent == 0)) {
60bc5cc68d3b log 499 instead 0, the bug was introduced in r3050
Igor Sysoev <igor@sysoev.ru>
parents: 3153
diff changeset
2212 mr->headers_out.status = rc;
60bc5cc68d3b log 499 instead 0, the bug was introduced in r3050
Igor Sysoev <igor@sysoev.ru>
parents: 3153
diff changeset
2213 }
60bc5cc68d3b log 499 instead 0, the bug was introduced in r3050
Igor Sysoev <igor@sysoev.ru>
parents: 3153
diff changeset
2214
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2215 cln = mr->cleanup;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2216 mr->cleanup = NULL;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2217
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2218 while (cln) {
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2219 if (cln->handler) {
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2220 cln->handler(cln->data);
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2221 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2222
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2223 cln = cln->next;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2224 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2225
3052
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2226 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2227 "http terminate cleanup count:%d blk:%d",
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2228 mr->count, mr->blocked);
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2229
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2230 if (mr->write_event_handler) {
3052
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2231
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2232 if (mr->blocked) {
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2233 return;
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2234 }
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2235
3064
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
2236 e = ngx_http_ephemeral(mr);
3051
26dfc0fa22c8 style fix
Igor Sysoev <igor@sysoev.ru>
parents: 3050
diff changeset
2237 mr->posted_requests = NULL;
26dfc0fa22c8 style fix
Igor Sysoev <igor@sysoev.ru>
parents: 3050
diff changeset
2238 mr->write_event_handler = ngx_http_terminate_handler;
3064
23e6f26fb4bd *) ngx_http_ephemeral
Igor Sysoev <igor@sysoev.ru>
parents: 3054
diff changeset
2239 (void) ngx_http_post_request(mr, &e->terminal_posted_request);
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2240 return;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2241 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2242
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2243 ngx_http_close_request(mr, rc);
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2244 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2245
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2246
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2247 static void
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2248 ngx_http_terminate_handler(ngx_http_request_t *r)
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2249 {
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2250 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
3052
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
2251 "http terminate handler count:%d", r->count);
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2252
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2253 r->count = 1;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2254
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2255 ngx_http_close_request(r, 0);
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2256 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2257
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2258
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2259 static void
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2260 ngx_http_finalize_connection(ngx_http_request_t *r)
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2261 {
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2262 ngx_http_core_loc_conf_t *clcf;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2263
3211
3ea03c1fe050 add lingering timeout if a response is short and a request body is being
Igor Sysoev <igor@sysoev.ru>
parents: 3180
diff changeset
2264 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
3ea03c1fe050 add lingering timeout if a response is short and a request body is being
Igor Sysoev <igor@sysoev.ru>
parents: 3180
diff changeset
2265
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2266 if (r->main->count != 1) {
3211
3ea03c1fe050 add lingering timeout if a response is short and a request body is being
Igor Sysoev <igor@sysoev.ru>
parents: 3180
diff changeset
2267
3214
798a7f1d3b2f restore discard body handler after ngx_http_set_writer() set it to
Igor Sysoev <igor@sysoev.ru>
parents: 3211
diff changeset
2268 if (r->discard_body) {
798a7f1d3b2f restore discard body handler after ngx_http_set_writer() set it to
Igor Sysoev <igor@sysoev.ru>
parents: 3211
diff changeset
2269 r->read_event_handler = ngx_http_discarded_request_body_handler;
3985
07d1aa82899b always set timer in discard body handler, this fixes the cases
Igor Sysoev <igor@sysoev.ru>
parents: 3984
diff changeset
2270 ngx_add_timer(r->connection->read, clcf->lingering_timeout);
3214
798a7f1d3b2f restore discard body handler after ngx_http_set_writer() set it to
Igor Sysoev <igor@sysoev.ru>
parents: 3211
diff changeset
2271
798a7f1d3b2f restore discard body handler after ngx_http_set_writer() set it to
Igor Sysoev <igor@sysoev.ru>
parents: 3211
diff changeset
2272 if (r->lingering_time == 0) {
798a7f1d3b2f restore discard body handler after ngx_http_set_writer() set it to
Igor Sysoev <igor@sysoev.ru>
parents: 3211
diff changeset
2273 r->lingering_time = ngx_time()
3211
3ea03c1fe050 add lingering timeout if a response is short and a request body is being
Igor Sysoev <igor@sysoev.ru>
parents: 3180
diff changeset
2274 + (time_t) (clcf->lingering_time / 1000);
3214
798a7f1d3b2f restore discard body handler after ngx_http_set_writer() set it to
Igor Sysoev <igor@sysoev.ru>
parents: 3211
diff changeset
2275 }
3211
3ea03c1fe050 add lingering timeout if a response is short and a request body is being
Igor Sysoev <igor@sysoev.ru>
parents: 3180
diff changeset
2276 }
3ea03c1fe050 add lingering timeout if a response is short and a request body is being
Igor Sysoev <igor@sysoev.ru>
parents: 3180
diff changeset
2277
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2278 ngx_http_close_request(r, 0);
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2279 return;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2280 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2281
230
1119faf4635a nginx-0.0.1-2004-01-16-09:15:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 220
diff changeset
2282 if (!ngx_terminate
326
8733703a37f3 nginx-0.0.3-2004-04-26-00:13:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 323
diff changeset
2283 && !ngx_exiting
2019
e720be7bc195 style fix
Igor Sysoev <igor@sysoev.ru>
parents: 2014
diff changeset
2284 && r->keepalive
230
1119faf4635a nginx-0.0.1-2004-01-16-09:15:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 220
diff changeset
2285 && clcf->keepalive_timeout > 0)
1119faf4635a nginx-0.0.1-2004-01-16-09:15:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 220
diff changeset
2286 {
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2287 ngx_http_set_keepalive(r);
230
1119faf4635a nginx-0.0.1-2004-01-16-09:15:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 220
diff changeset
2288 return;
3984
3e51832c8215 lingering_close "off|on|always"
Igor Sysoev <igor@sysoev.ru>
parents: 3983
diff changeset
2289 }
3e51832c8215 lingering_close "off|on|always"
Igor Sysoev <igor@sysoev.ru>
parents: 3983
diff changeset
2290
3e51832c8215 lingering_close "off|on|always"
Igor Sysoev <igor@sysoev.ru>
parents: 3983
diff changeset
2291 if (clcf->lingering_close == NGX_HTTP_LINGERING_ALWAYS
3e51832c8215 lingering_close "off|on|always"
Igor Sysoev <igor@sysoev.ru>
parents: 3983
diff changeset
2292 || (clcf->lingering_close == NGX_HTTP_LINGERING_ON
3e51832c8215 lingering_close "off|on|always"
Igor Sysoev <igor@sysoev.ru>
parents: 3983
diff changeset
2293 && (r->lingering_close
3e51832c8215 lingering_close "off|on|always"
Igor Sysoev <igor@sysoev.ru>
parents: 3983
diff changeset
2294 || r->header_in->pos < r->header_in->last
3e51832c8215 lingering_close "off|on|always"
Igor Sysoev <igor@sysoev.ru>
parents: 3983
diff changeset
2295 || r->connection->read->ready)))
3981
77604e9a1ed8 enable lingering close for pipelined requests
Igor Sysoev <igor@sysoev.ru>
parents: 3978
diff changeset
2296 {
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2297 ngx_http_set_lingering_close(r);
230
1119faf4635a nginx-0.0.1-2004-01-16-09:15:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 220
diff changeset
2298 return;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2299 }
142
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
2300
230
1119faf4635a nginx-0.0.1-2004-01-16-09:15:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 220
diff changeset
2301 ngx_http_close_request(r, 0);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2302 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2303
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2304
525
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2305 static ngx_int_t
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2306 ngx_http_set_write_handler(ngx_http_request_t *r)
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2307 {
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2308 ngx_event_t *wev;
91
637625a2acdb nginx-0.0.1-2003-05-19-20:39:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 89
diff changeset
2309 ngx_http_core_loc_conf_t *clcf;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2310
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2311 r->http_state = NGX_HTTP_WRITING_REQUEST_STATE;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2312
3215
4edf28522d24 allow discarding body while a long response transfer
Igor Sysoev <igor@sysoev.ru>
parents: 3214
diff changeset
2313 r->read_event_handler = r->discard_body ?
4edf28522d24 allow discarding body while a long response transfer
Igor Sysoev <igor@sysoev.ru>
parents: 3214
diff changeset
2314 ngx_http_discarded_request_body_handler:
4edf28522d24 allow discarding body while a long response transfer
Igor Sysoev <igor@sysoev.ru>
parents: 3214
diff changeset
2315 ngx_http_test_reading;
525
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2316 r->write_event_handler = ngx_http_writer;
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2317
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2318 wev = r->connection->write;
369
9c2515d70489 nginx-0.0.7-2004-06-25-18:42:03 import
Igor Sysoev <igor@sysoev.ru>
parents: 368
diff changeset
2319
362
7650aea1816f nginx-0.0.7-2004-06-21-19:59:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 361
diff changeset
2320 if (wev->ready && wev->delayed) {
525
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2321 return NGX_OK;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2322 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2323
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2324 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
362
7650aea1816f nginx-0.0.7-2004-06-21-19:59:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 361
diff changeset
2325 if (!wev->delayed) {
361
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2326 ngx_add_timer(wev, clcf->send_timeout);
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2327 }
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2328
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2329 if (ngx_handle_write_event(wev, clcf->send_lowat) != NGX_OK) {
143
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
2330 ngx_http_close_request(r, 0);
525
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2331 return NGX_ERROR;
143
5526213be452 nginx-0.0.1-2003-10-10-19:10:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 142
diff changeset
2332 }
525
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2333
09b42134ac0c nginx-0.1.37-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 523
diff changeset
2334 return NGX_OK;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2335 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2336
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2337
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2338 static void
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2339 ngx_http_writer(ngx_http_request_t *r)
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2340 {
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2341 int rc;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2342 ngx_event_t *wev;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2343 ngx_connection_t *c;
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2344 ngx_http_core_loc_conf_t *clcf;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2345
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2346 c = r->connection;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2347 wev = c->write;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2348
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2349 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, wev->log, 0,
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2350 "http writer handler: \"%V?%V\"", &r->uri, &r->args);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2351
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2352 clcf = ngx_http_get_module_loc_conf(r->main, ngx_http_core_module);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2353
361
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2354 if (wev->timedout) {
362
7650aea1816f nginx-0.0.7-2004-06-21-19:59:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 361
diff changeset
2355 if (!wev->delayed) {
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
2356 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT,
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
2357 "client timed out");
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
2358 c->timedout = 1;
567
1af2fcb3be8a nginx-0.3.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
2359
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
2360 ngx_http_finalize_request(r, NGX_HTTP_REQUEST_TIME_OUT);
361
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2361 return;
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2362 }
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2363
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2364 wev->timedout = 0;
362
7650aea1816f nginx-0.0.7-2004-06-21-19:59:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 361
diff changeset
2365 wev->delayed = 0;
361
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2366
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2367 if (!wev->ready) {
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2368 ngx_add_timer(wev, clcf->send_timeout);
160
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
2369
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2370 if (ngx_handle_write_event(wev, clcf->send_lowat) != NGX_OK) {
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2371 ngx_http_close_request(r, 0);
361
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2372 }
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2373
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2374 return;
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2375 }
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2376
4195
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2377 }
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2378
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2379 if (wev->delayed || r->aio) {
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2380 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, wev->log, 0,
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2381 "http writer delayed");
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2382
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2383 if (ngx_handle_write_event(wev, clcf->send_lowat) != NGX_OK) {
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2384 ngx_http_close_request(r, 0);
361
446782c909b3 nginx-0.0.7-2004-06-20-23:54:15 import
Igor Sysoev <igor@sysoev.ru>
parents: 358
diff changeset
2385 }
4195
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2386
35f4997c08ce Fix for socket leak with "aio sendfile" and "limit_rate".
Maxim Dounin <mdounin@mdounin.ru>
parents: 4194
diff changeset
2387 return;
160
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
2388 }
e7e094d34162 nginx-0.0.1-2003-10-27-11:53:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 159
diff changeset
2389
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2390 rc = ngx_http_output_filter(r, NULL);
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2391
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2392 ngx_log_debug3(NGX_LOG_DEBUG_HTTP, c->log, 0,
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2393 "http writer output filter: %d, \"%V?%V\"",
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2394 rc, &r->uri, &r->args);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2395
2883
d0cba58e5bfa fix socket leak introduced in r2378
Igor Sysoev <igor@sysoev.ru>
parents: 2857
diff changeset
2396 if (rc == NGX_ERROR) {
d0cba58e5bfa fix socket leak introduced in r2378
Igor Sysoev <igor@sysoev.ru>
parents: 2857
diff changeset
2397 ngx_http_finalize_request(r, rc);
d0cba58e5bfa fix socket leak introduced in r2378
Igor Sysoev <igor@sysoev.ru>
parents: 2857
diff changeset
2398 return;
d0cba58e5bfa fix socket leak introduced in r2378
Igor Sysoev <igor@sysoev.ru>
parents: 2857
diff changeset
2399 }
d0cba58e5bfa fix socket leak introduced in r2378
Igor Sysoev <igor@sysoev.ru>
parents: 2857
diff changeset
2400
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2401 if (r->buffered || r->postponed || (r == r->main && c->buffered)) {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2402
4194
7ce8f2cde0af Fix for connection drops with AIO.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4033
diff changeset
2403 if (!wev->delayed) {
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2404 ngx_add_timer(wev, clcf->send_timeout);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2405 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2406
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2407 if (ngx_handle_write_event(wev, clcf->send_lowat) != NGX_OK) {
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2408 ngx_http_close_request(r, 0);
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2409 }
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2410
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2411 return;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2412 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2413
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2414 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, wev->log, 0,
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2415 "http writer done: \"%V?%V\"", &r->uri, &r->args);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2416
3216
79ae445ec57b fix two previous commits: an early parallel body discarding completion
Igor Sysoev <igor@sysoev.ru>
parents: 3215
diff changeset
2417 r->write_event_handler = ngx_http_request_empty_handler;
79ae445ec57b fix two previous commits: an early parallel body discarding completion
Igor Sysoev <igor@sysoev.ru>
parents: 3215
diff changeset
2418
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2419 ngx_http_finalize_request(r, rc);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2420 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2421
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2422
2377
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2423 static void
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2424 ngx_http_request_finalizer(ngx_http_request_t *r)
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2425 {
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2426 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2427 "http finalizer done: \"%V?%V\"", &r->uri, &r->args);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2428
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2429 ngx_http_finalize_request(r, 0);
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2430 }
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2431
87b8c44906b5 *) refactor subrequest handling, now they run as separate posted requests
Igor Sysoev <igor@sysoev.ru>
parents: 2370
diff changeset
2432
1368
202cae9a0c2b rename ngx_http_block_read() and ngx_http_test_read() to ..._reading()
Igor Sysoev <igor@sysoev.ru>
parents: 1283
diff changeset
2433 void
202cae9a0c2b rename ngx_http_block_read() and ngx_http_test_read() to ..._reading()
Igor Sysoev <igor@sysoev.ru>
parents: 1283
diff changeset
2434 ngx_http_block_reading(ngx_http_request_t *r)
13
2aba961a1d34 nginx-0.0.1-2002-09-16-19:01:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 12
diff changeset
2435 {
1283
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2436 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
1368
202cae9a0c2b rename ngx_http_block_read() and ngx_http_test_read() to ..._reading()
Igor Sysoev <igor@sysoev.ru>
parents: 1283
diff changeset
2437 "http reading blocked");
1283
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2438
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2439 /* aio does not call this handler */
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2440
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2441 if ((ngx_event_flags & NGX_USE_LEVEL_EVENT)
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2442 && r->connection->read->active)
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2443 {
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2444 if (ngx_del_event(r->connection->read, NGX_READ_EVENT, 0) != NGX_OK) {
1283
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2445 ngx_http_close_request(r, 0);
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2446 }
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2447 }
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2448 }
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2449
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2450
2294
ce574b0ffeec ngx_http_limit_req_module
Igor Sysoev <igor@sysoev.ru>
parents: 2265
diff changeset
2451 void
1368
202cae9a0c2b rename ngx_http_block_read() and ngx_http_test_read() to ..._reading()
Igor Sysoev <igor@sysoev.ru>
parents: 1283
diff changeset
2452 ngx_http_test_reading(ngx_http_request_t *r)
1283
a3f8d6d17b94 proxy_ignore_client_abort, fastcgi_ignore_client_abort, and so on were
Igor Sysoev <igor@sysoev.ru>
parents: 1253
diff changeset
2453 {
1061
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2454 int n;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2455 char buf[1];
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2456 ngx_err_t err;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2457 ngx_event_t *rev;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2458 ngx_connection_t *c;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2459
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2460 c = r->connection;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2461 rev = c->read;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2462
1368
202cae9a0c2b rename ngx_http_block_read() and ngx_http_test_read() to ..._reading()
Igor Sysoev <igor@sysoev.ru>
parents: 1283
diff changeset
2463 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, c->log, 0, "http test reading");
1061
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2464
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2465 #if (NGX_HAVE_KQUEUE)
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2466
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2467 if (ngx_event_flags & NGX_USE_KQUEUE_EVENT) {
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2468
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2469 if (!rev->pending_eof) {
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2470 return;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2471 }
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2472
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2473 rev->eof = 1;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2474 c->error = 1;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2475 err = rev->kq_errno;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2476
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2477 goto closed;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2478 }
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2479
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2480 #endif
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2481
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2482 n = recv(c->fd, buf, 1, MSG_PEEK);
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2483
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2484 if (n == 0) {
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2485 rev->eof = 1;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2486 c->error = 1;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2487 err = 0;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2488
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2489 goto closed;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2490
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2491 } else if (n == -1) {
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2492 err = ngx_socket_errno;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2493
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2494 if (err != NGX_EAGAIN) {
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2495 rev->eof = 1;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2496 c->error = 1;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2497
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2498 goto closed;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2499 }
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2500 }
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2501
59
e8cdc2989cee nginx-0.0.1-2003-02-06-20:21:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 57
diff changeset
2502 /* aio does not call this handler */
e8cdc2989cee nginx-0.0.1-2003-02-06-20:21:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 57
diff changeset
2503
1061
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2504 if ((ngx_event_flags & NGX_USE_LEVEL_EVENT) && rev->active) {
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2505
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2506 if (ngx_del_event(rev, NGX_READ_EVENT, 0) != NGX_OK) {
89
29bf798b583f nginx-0.0.1-2003-05-15-19:42:53 import
Igor Sysoev <igor@sysoev.ru>
parents: 87
diff changeset
2507 ngx_http_close_request(r, 0);
29bf798b583f nginx-0.0.1-2003-05-15-19:42:53 import
Igor Sysoev <igor@sysoev.ru>
parents: 87
diff changeset
2508 }
59
e8cdc2989cee nginx-0.0.1-2003-02-06-20:21:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 57
diff changeset
2509 }
1061
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2510
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2511 return;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2512
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2513 closed:
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2514
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2515 if (err) {
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2516 rev->error = 1;
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2517 }
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2518
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2519 ngx_log_error(NGX_LOG_INFO, c->log, err,
4593
834049edae24 Fixed grammar in error messages.
Ruslan Ermilov <ru@nginx.com>
parents: 4552
diff changeset
2520 "client prematurely closed connection");
1061
9aca452fe12a if client closes a connection prematurely, then epoll (at least
Igor Sysoev <igor@sysoev.ru>
parents: 1059
diff changeset
2521
1115
f07a5f4017d9 finalize request to allow post_action
Igor Sysoev <igor@sysoev.ru>
parents: 1110
diff changeset
2522 ngx_http_finalize_request(r, 0);
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2523 }
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2524
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2525
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2526 static void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2527 ngx_http_set_keepalive(ngx_http_request_t *r)
60
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2528 {
452
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
2529 int tcp_nodelay;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2530 ngx_int_t i;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2531 ngx_buf_t *b, *f;
95
b48066122884 nginx-0.0.1-2003-05-23-15:53:01 import
Igor Sysoev <igor@sysoev.ru>
parents: 94
diff changeset
2532 ngx_event_t *rev, *wev;
b48066122884 nginx-0.0.1-2003-05-23-15:53:01 import
Igor Sysoev <igor@sysoev.ru>
parents: 94
diff changeset
2533 ngx_connection_t *c;
432
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
2534 ngx_http_connection_t *hc;
95
b48066122884 nginx-0.0.1-2003-05-23-15:53:01 import
Igor Sysoev <igor@sysoev.ru>
parents: 94
diff changeset
2535 ngx_http_core_srv_conf_t *cscf;
b48066122884 nginx-0.0.1-2003-05-23-15:53:01 import
Igor Sysoev <igor@sysoev.ru>
parents: 94
diff changeset
2536 ngx_http_core_loc_conf_t *clcf;
60
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2537
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2538 c = r->connection;
65
4222c496acb3 nginx-0.0.1-2003-03-05-09:37:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 64
diff changeset
2539 rev = c->read;
60
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2540
1373
fdea12ffb24a discard request body before going to keep-alive state and use lingering timeouts
Igor Sysoev <igor@sysoev.ru>
parents: 1368
diff changeset
2541 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
fdea12ffb24a discard request body before going to keep-alive state and use lingering timeouts
Igor Sysoev <igor@sysoev.ru>
parents: 1368
diff changeset
2542
239
574bea0142be nginx-0.0.1-2004-01-26-11:52:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 233
diff changeset
2543 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, c->log, 0, "set http keepalive handler");
94
8220378432a8 nginx-0.0.1-2003-05-22-19:23:47 import
Igor Sysoev <igor@sysoev.ru>
parents: 93
diff changeset
2544
1373
fdea12ffb24a discard request body before going to keep-alive state and use lingering timeouts
Igor Sysoev <igor@sysoev.ru>
parents: 1368
diff changeset
2545 if (r->discard_body) {
2489
d1a7203a8a44 avoid a double redirect response if
Igor Sysoev <igor@sysoev.ru>
parents: 2388
diff changeset
2546 r->write_event_handler = ngx_http_request_empty_handler;
1373
fdea12ffb24a discard request body before going to keep-alive state and use lingering timeouts
Igor Sysoev <igor@sysoev.ru>
parents: 1368
diff changeset
2547 r->lingering_time = ngx_time() + (time_t) (clcf->lingering_time / 1000);
fdea12ffb24a discard request body before going to keep-alive state and use lingering timeouts
Igor Sysoev <igor@sysoev.ru>
parents: 1368
diff changeset
2548 ngx_add_timer(rev, clcf->lingering_timeout);
fdea12ffb24a discard request body before going to keep-alive state and use lingering timeouts
Igor Sysoev <igor@sysoev.ru>
parents: 1368
diff changeset
2549 return;
fdea12ffb24a discard request body before going to keep-alive state and use lingering timeouts
Igor Sysoev <igor@sysoev.ru>
parents: 1368
diff changeset
2550 }
fdea12ffb24a discard request body before going to keep-alive state and use lingering timeouts
Igor Sysoev <igor@sysoev.ru>
parents: 1368
diff changeset
2551
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2552 c->log->action = "closing request";
432
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
2553
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
2554 hc = r->http_connection;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2555 b = r->header_in;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2556
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2557 if (b->pos < b->last) {
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2558
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2559 /* the pipelined request */
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2560
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2561 if (b != c->buffer) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2562
455
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2563 /*
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2564 * If the large header buffers were allocated while the previous
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2565 * request processing then we do not use c->buffer for
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2566 * the pipelined request (see ngx_http_init_request()).
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 573
diff changeset
2567 *
455
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2568 * Now we would move the large header buffers to the free list.
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2569 */
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2570
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2571 cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2572
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2573 if (hc->free == NULL) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2574 hc->free = ngx_palloc(c->pool,
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2575 cscf->large_client_header_buffers.num * sizeof(ngx_buf_t *));
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2576
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2577 if (hc->free == NULL) {
477
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
2578 ngx_http_close_request(r, 0);
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2579 return;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2580 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2581 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2582
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2583 for (i = 0; i < hc->nbusy - 1; i++) {
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2584 f = hc->busy[i];
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2585 hc->free[hc->nfree++] = f;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2586 f->pos = f->start;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2587 f->last = f->start;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2588 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2589
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2590 hc->busy[0] = b;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2591 hc->nbusy = 1;
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2592 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2593 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2594
3180
0e420f3f8e18 clear r->keepalive to disable preventively calling
Igor Sysoev <igor@sysoev.ru>
parents: 3176
diff changeset
2595 r->keepalive = 0;
0e420f3f8e18 clear r->keepalive to disable preventively calling
Igor Sysoev <igor@sysoev.ru>
parents: 3176
diff changeset
2596
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
2597 ngx_http_free_request(r, 0);
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
2598
432
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
2599 c->data = hc;
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2600
93
738fe44c70d5 nginx-0.0.1-2003-05-21-17:28:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 92
diff changeset
2601 ngx_add_timer(rev, clcf->keepalive_timeout);
738fe44c70d5 nginx-0.0.1-2003-05-21-17:28:21 import
Igor Sysoev <igor@sysoev.ru>
parents: 92
diff changeset
2602
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2603 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2604 ngx_http_close_connection(c);
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2605 return;
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2606 }
65
4222c496acb3 nginx-0.0.1-2003-03-05-09:37:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 64
diff changeset
2607
259
d30f2c39caae nginx-0.0.2-2004-02-12-23:57:10 import
Igor Sysoev <igor@sysoev.ru>
parents: 258
diff changeset
2608 wev = c->write;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2609 wev->handler = ngx_http_empty_handler;
65
4222c496acb3 nginx-0.0.1-2003-03-05-09:37:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 64
diff changeset
2610
343
6bdf858bff8c nginx-0.0.3-2004-05-28-19:49:23 import; rename ngx_hunk_t to ngx_buf_t
Igor Sysoev <igor@sysoev.ru>
parents: 335
diff changeset
2611 if (b->pos < b->last) {
65
4222c496acb3 nginx-0.0.1-2003-03-05-09:37:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 64
diff changeset
2612
239
574bea0142be nginx-0.0.1-2004-01-26-11:52:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 233
diff changeset
2613 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, c->log, 0, "pipelined request");
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2614
432
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
2615 hc->pipeline = 1;
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2616 c->log->action = "reading client pipelined request line";
567
1af2fcb3be8a nginx-0.3.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
2617
2014
4151c33e4dfa avoid recursive loop
Igor Sysoev <igor@sysoev.ru>
parents: 2007
diff changeset
2618 rev->handler = ngx_http_init_request;
4151c33e4dfa avoid recursive loop
Igor Sysoev <igor@sysoev.ru>
parents: 2007
diff changeset
2619 ngx_post_event(rev, &ngx_posted_events);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2620 return;
65
4222c496acb3 nginx-0.0.1-2003-03-05-09:37:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 64
diff changeset
2621 }
4222c496acb3 nginx-0.0.1-2003-03-05-09:37:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 64
diff changeset
2622
432
11362a3e3911 nginx-0.0.11-2004-09-21-09:38:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 430
diff changeset
2623 hc->pipeline = 0;
65
4222c496acb3 nginx-0.0.1-2003-03-05-09:37:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 64
diff changeset
2624
455
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2625 /*
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2626 * To keep a memory footprint as small as possible for an idle
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2627 * keepalive connection we try to free the ngx_http_request_t and
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2628 * c->buffer's memory if they were allocated outside the c->pool.
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2629 * The large header buffers are always allocated outside the c->pool and
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2630 * are freed too.
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2631 */
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2632
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2633 if (ngx_pfree(c->pool, r) == NGX_OK) {
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2634 hc->request = NULL;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2635 }
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2636
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2637 b = c->buffer;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2638
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2639 if (ngx_pfree(c->pool, b->start) == NGX_OK) {
455
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2640
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2641 /*
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2642 * the special note for ngx_http_keepalive_handler() that
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2643 * c->buffer's memory was freed
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2644 */
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2645
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2646 b->pos = NULL;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2647
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2648 } else {
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2649 b->pos = b->start;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2650 b->last = b->start;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2651 }
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2652
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
2653 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0, "hc free: %p %d",
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2654 hc->free, hc->nfree);
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2655
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2656 if (hc->free) {
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2657 for (i = 0; i < hc->nfree; i++) {
1708
3748e50f9b23 large_client_header_buffers did not free()ed before keep-alive
Igor Sysoev <igor@sysoev.ru>
parents: 1704
diff changeset
2658 ngx_pfree(c->pool, hc->free[i]->start);
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2659 hc->free[i] = NULL;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2660 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2661
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2662 hc->nfree = 0;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2663 }
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2664
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
2665 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0, "hc busy: %p %d",
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2666 hc->busy, hc->nbusy);
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2667
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2668 if (hc->busy) {
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2669 for (i = 0; i < hc->nbusy; i++) {
1708
3748e50f9b23 large_client_header_buffers did not free()ed before keep-alive
Igor Sysoev <igor@sysoev.ru>
parents: 1704
diff changeset
2670 ngx_pfree(c->pool, hc->busy[i]->start);
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2671 hc->busy[i] = NULL;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2672 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2673
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2674 hc->nbusy = 0;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2675 }
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2676
1779
06014cfdb5b1 create ssl buffer on demand and free it before keep-alive
Igor Sysoev <igor@sysoev.ru>
parents: 1776
diff changeset
2677 #if (NGX_HTTP_SSL)
06014cfdb5b1 create ssl buffer on demand and free it before keep-alive
Igor Sysoev <igor@sysoev.ru>
parents: 1776
diff changeset
2678 if (c->ssl) {
06014cfdb5b1 create ssl buffer on demand and free it before keep-alive
Igor Sysoev <igor@sysoev.ru>
parents: 1776
diff changeset
2679 ngx_ssl_free_buffer(c);
06014cfdb5b1 create ssl buffer on demand and free it before keep-alive
Igor Sysoev <igor@sysoev.ru>
parents: 1776
diff changeset
2680 }
06014cfdb5b1 create ssl buffer on demand and free it before keep-alive
Igor Sysoev <igor@sysoev.ru>
parents: 1776
diff changeset
2681 #endif
06014cfdb5b1 create ssl buffer on demand and free it before keep-alive
Igor Sysoev <igor@sysoev.ru>
parents: 1776
diff changeset
2682
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2683 rev->handler = ngx_http_keepalive_handler;
65
4222c496acb3 nginx-0.0.1-2003-03-05-09:37:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 64
diff changeset
2684
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2685 if (wev->active && (ngx_event_flags & NGX_USE_LEVEL_EVENT)) {
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2686 if (ngx_del_event(wev, NGX_WRITE_EVENT, 0) != NGX_OK) {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2687 ngx_http_close_connection(c);
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2688 return;
60
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2689 }
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2690 }
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2691
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2692 c->log->action = "keepalive";
64
34d647deb1da nginx-0.0.1-2003-03-04-09:33:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 60
diff changeset
2693
344
e366ba5db8f8 nginx-0.0.3-2004-06-01-10:04:46 import
Igor Sysoev <igor@sysoev.ru>
parents: 343
diff changeset
2694 if (c->tcp_nopush == NGX_TCP_NOPUSH_SET) {
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2695 if (ngx_tcp_push(c->fd) == -1) {
328
fb4dfb2ac0fc nginx-0.0.3-2004-04-28-10:14:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 326
diff changeset
2696 ngx_connection_error(c, ngx_socket_errno, ngx_tcp_push_n " failed");
fb4dfb2ac0fc nginx-0.0.3-2004-04-28-10:14:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 326
diff changeset
2697 ngx_http_close_connection(c);
fb4dfb2ac0fc nginx-0.0.3-2004-04-28-10:14:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 326
diff changeset
2698 return;
101
2e069b6e6920 nginx-0.0.1-2003-06-04-21:28:33 import
Igor Sysoev <igor@sysoev.ru>
parents: 100
diff changeset
2699 }
452
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
2700
344
e366ba5db8f8 nginx-0.0.3-2004-06-01-10:04:46 import
Igor Sysoev <igor@sysoev.ru>
parents: 343
diff changeset
2701 c->tcp_nopush = NGX_TCP_NOPUSH_UNSET;
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2702 tcp_nodelay = ngx_tcp_nodelay_and_tcp_nopush ? 1 : 0;
452
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
2703
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
2704 } else {
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2705 tcp_nodelay = 1;
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2706 }
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2707
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2708 if (tcp_nodelay
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2709 && clcf->tcp_nodelay
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2710 && c->tcp_nodelay == NGX_TCP_NODELAY_UNSET)
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2711 {
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2712 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, c->log, 0, "tcp_nodelay");
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2713
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2714 if (setsockopt(c->fd, IPPROTO_TCP, TCP_NODELAY,
635
18268abd340c nginx-0.3.39-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 633
diff changeset
2715 (const void *) &tcp_nodelay, sizeof(int))
18268abd340c nginx-0.3.39-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 633
diff changeset
2716 == -1)
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2717 {
2560
a7443674e429 ignore EINVAL from setsockopt() on Solaris
Igor Sysoev <igor@sysoev.ru>
parents: 2556
diff changeset
2718 #if (NGX_SOLARIS)
a7443674e429 ignore EINVAL from setsockopt() on Solaris
Igor Sysoev <igor@sysoev.ru>
parents: 2556
diff changeset
2719 /* Solaris returns EINVAL if a socket has been shut down */
a7443674e429 ignore EINVAL from setsockopt() on Solaris
Igor Sysoev <igor@sysoev.ru>
parents: 2556
diff changeset
2720 c->log_error = NGX_ERROR_IGNORE_EINVAL;
a7443674e429 ignore EINVAL from setsockopt() on Solaris
Igor Sysoev <igor@sysoev.ru>
parents: 2556
diff changeset
2721 #endif
a7443674e429 ignore EINVAL from setsockopt() on Solaris
Igor Sysoev <igor@sysoev.ru>
parents: 2556
diff changeset
2722
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2723 ngx_connection_error(c, ngx_socket_errno,
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2724 "setsockopt(TCP_NODELAY) failed");
2560
a7443674e429 ignore EINVAL from setsockopt() on Solaris
Igor Sysoev <igor@sysoev.ru>
parents: 2556
diff changeset
2725
a7443674e429 ignore EINVAL from setsockopt() on Solaris
Igor Sysoev <igor@sysoev.ru>
parents: 2556
diff changeset
2726 c->log_error = NGX_ERROR_INFO;
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2727 ngx_http_close_connection(c);
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2728 return;
452
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
2729 }
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2730
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2731 c->tcp_nodelay = NGX_TCP_NODELAY_SET;
101
2e069b6e6920 nginx-0.0.1-2003-06-04-21:28:33 import
Igor Sysoev <igor@sysoev.ru>
parents: 100
diff changeset
2732 }
2e069b6e6920 nginx-0.0.1-2003-06-04-21:28:33 import
Igor Sysoev <igor@sysoev.ru>
parents: 100
diff changeset
2733
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2734 #if 0
455
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2735 /* if ngx_http_request_t was freed then we need some other place */
367
ceec87d1c2b3 nginx-0.0.7-2004-06-24-11:53:37 import
Igor Sysoev <igor@sysoev.ru>
parents: 362
diff changeset
2736 r->http_state = NGX_HTTP_KEEPALIVE_STATE;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2737 #endif
367
ceec87d1c2b3 nginx-0.0.7-2004-06-24-11:53:37 import
Igor Sysoev <igor@sysoev.ru>
parents: 362
diff changeset
2738
1135
03f1133f24e8 close keep-alive connections in the shuting down processes
Igor Sysoev <igor@sysoev.ru>
parents: 1115
diff changeset
2739 c->idle = 1;
3880
e3cb8e27e413 reuse keepalive connections if there are no free worker connections
Igor Sysoev <igor@sysoev.ru>
parents: 3848
diff changeset
2740 ngx_reusable_connection(c, 1);
1135
03f1133f24e8 close keep-alive connections in the shuting down processes
Igor Sysoev <igor@sysoev.ru>
parents: 1115
diff changeset
2741
164
84036764e215 nginx-0.0.1-2003-10-29-11:30:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 161
diff changeset
2742 if (rev->ready) {
2014
4151c33e4dfa avoid recursive loop
Igor Sysoev <igor@sysoev.ru>
parents: 2007
diff changeset
2743 ngx_post_event(rev, &ngx_posted_events);
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2744 }
60
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2745 }
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2746
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2747
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2748 static void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2749 ngx_http_keepalive_handler(ngx_event_t *rev)
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
2750 {
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2751 size_t size;
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2752 ssize_t n;
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2753 ngx_buf_t *b;
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2754 ngx_connection_t *c;
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
2755
394
e7a68e14ccd3 nginx-0.0.7-2004-07-16-10:33:35 import
Igor Sysoev <igor@sysoev.ru>
parents: 393
diff changeset
2756 c = rev->data;
13
2aba961a1d34 nginx-0.0.1-2002-09-16-19:01:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 12
diff changeset
2757
239
574bea0142be nginx-0.0.1-2004-01-26-11:52:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 233
diff changeset
2758 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, c->log, 0, "http keepalive handler");
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2759
1135
03f1133f24e8 close keep-alive connections in the shuting down processes
Igor Sysoev <igor@sysoev.ru>
parents: 1115
diff changeset
2760 if (rev->timedout || c->close) {
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2761 ngx_http_close_connection(c);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2762 return;
68
d549fdc17d7e nginx-0.0.1-2003-03-12-20:32:22 import
Igor Sysoev <igor@sysoev.ru>
parents: 67
diff changeset
2763 }
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2764
469
2ff194b74f1e nginx-0.1.9-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 461
diff changeset
2765 #if (NGX_HAVE_KQUEUE)
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2766
455
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2767 if (ngx_event_flags & NGX_USE_KQUEUE_EVENT) {
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
2768 if (rev->pending_eof) {
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2769 c->log->handler = NULL;
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2770 ngx_log_error(NGX_LOG_INFO, c->log, rev->kq_errno,
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
2771 "kevent() reported that client %V closed "
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2772 "keepalive connection", &c->addr_text);
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2773 #if (NGX_HTTP_SSL)
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2774 if (c->ssl) {
547
818fbd4750b9 nginx-0.2.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 543
diff changeset
2775 c->ssl->no_send_shutdown = 1;
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2776 }
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 469
diff changeset
2777 #endif
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2778 ngx_http_close_connection(c);
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2779 return;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2780 }
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2781 }
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2782
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2783 #endif
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2784
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2785 b = c->buffer;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2786 size = b->end - b->start;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2787
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2788 if (b->pos == NULL) {
455
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2789
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2790 /*
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2791 * The c->buffer's memory was freed by ngx_http_set_keepalive().
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2792 * However, the c->buffer->start and c->buffer->end were not changed
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2793 * to keep the buffer size.
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2794 */
295d97d70c69 nginx-0.1.2-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 452
diff changeset
2795
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2796 b->pos = ngx_palloc(c->pool, size);
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2797 if (b->pos == NULL) {
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2798 ngx_http_close_connection(c);
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2799 return;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2800 }
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2801
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2802 b->start = b->pos;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2803 b->last = b->pos;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2804 b->end = b->pos + size;
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2805 }
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2806
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2807 /*
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2808 * MSIE closes a keepalive connection with RST flag
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2809 * so we ignore ECONNRESET here.
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2810 */
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2811
256
8e39cab6abd5 nginx-0.0.2-2004-02-10-19:23:38 import
Igor Sysoev <igor@sysoev.ru>
parents: 253
diff changeset
2812 c->log_error = NGX_ERROR_IGNORE_ECONNRESET;
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2813 ngx_set_socket_errno(0);
396
6f3b20c1ac50 nginx-0.0.7-2004-07-18-23:11:20 import
Igor Sysoev <igor@sysoev.ru>
parents: 395
diff changeset
2814
437
470270fa84d2 nginx-0.0.12-2004-09-23-20:39:34 import
Igor Sysoev <igor@sysoev.ru>
parents: 436
diff changeset
2815 n = c->recv(c, b->last, size);
256
8e39cab6abd5 nginx-0.0.2-2004-02-10-19:23:38 import
Igor Sysoev <igor@sysoev.ru>
parents: 253
diff changeset
2816 c->log_error = NGX_ERROR_INFO;
13
2aba961a1d34 nginx-0.0.1-2002-09-16-19:01:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 12
diff changeset
2817
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2818 if (n == NGX_AGAIN) {
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2819 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
475
c3c2848fc081 nginx-0.1.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 473
diff changeset
2820 ngx_http_close_connection(c);
5082
42a888fdad0b Fixed potential segfault in ngx_http_keepalive_handler().
Valentin Bartenev <vbart@nginx.com>
parents: 5072
diff changeset
2821 return;
475
c3c2848fc081 nginx-0.1.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 473
diff changeset
2822 }
c3c2848fc081 nginx-0.1.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 473
diff changeset
2823
4891
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2824 /*
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2825 * Like ngx_http_set_keepalive() we are trying to not hold
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2826 * c->buffer's memory for a keepalive connection.
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2827 */
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2828
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2829 if (ngx_pfree(c->pool, b->start) == NGX_OK) {
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2830
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2831 /*
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2832 * the special note that c->buffer's memory was freed
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2833 */
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2834
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2835 b->pos = NULL;
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2836 }
1e666c78a42c ngx_http_keepalive_handler() is now trying to not keep c->buffer's memory for
Valentin Bartenev <vbart@nginx.com>
parents: 4884
diff changeset
2837
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2838 return;
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2839 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2840
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2841 if (n == NGX_ERROR) {
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2842 ngx_http_close_connection(c);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2843 return;
68
d549fdc17d7e nginx-0.0.1-2003-03-12-20:32:22 import
Igor Sysoev <igor@sysoev.ru>
parents: 67
diff changeset
2844 }
13
2aba961a1d34 nginx-0.0.1-2002-09-16-19:01:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 12
diff changeset
2845
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2846 c->log->handler = NULL;
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
2847
13
2aba961a1d34 nginx-0.0.1-2002-09-16-19:01:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 12
diff changeset
2848 if (n == 0) {
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2849 ngx_log_error(NGX_LOG_INFO, c->log, ngx_socket_errno,
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2850 "client %V closed keepalive connection", &c->addr_text);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2851 ngx_http_close_connection(c);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2852 return;
13
2aba961a1d34 nginx-0.0.1-2002-09-16-19:01:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 12
diff changeset
2853 }
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
2854
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2855 b->last += n;
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2856
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2857 c->log->handler = ngx_http_log_error;
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
2858 c->log->action = "reading client request line";
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
2859
1135
03f1133f24e8 close keep-alive connections in the shuting down processes
Igor Sysoev <igor@sysoev.ru>
parents: 1115
diff changeset
2860 c->idle = 0;
3880
e3cb8e27e413 reuse keepalive connections if there are no free worker connections
Igor Sysoev <igor@sysoev.ru>
parents: 3848
diff changeset
2861 ngx_reusable_connection(c, 0);
1135
03f1133f24e8 close keep-alive connections in the shuting down processes
Igor Sysoev <igor@sysoev.ru>
parents: 1115
diff changeset
2862
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2863 ngx_http_init_request(rev);
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
2864 }
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
2865
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
2866
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2867 static void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2868 ngx_http_set_lingering_close(ngx_http_request_t *r)
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 573
diff changeset
2869 {
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2870 ngx_event_t *rev, *wev;
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2871 ngx_connection_t *c;
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2872 ngx_http_core_loc_conf_t *clcf;
44
0e81ac0bb3e2 nginx-0.0.1-2003-01-09-08:36:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 41
diff changeset
2873
60
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2874 c = r->connection;
53
d1e42f1b8fd4 nginx-0.0.1-2003-01-27-00:08:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 52
diff changeset
2875
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2876 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
44
0e81ac0bb3e2 nginx-0.0.1-2003-01-09-08:36:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 41
diff changeset
2877
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2878 rev = c->read;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2879 rev->handler = ngx_http_lingering_close_handler;
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2880
557
ecd9c160f25b nginx-0.3.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 553
diff changeset
2881 r->lingering_time = ngx_time() + (time_t) (clcf->lingering_time / 1000);
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2882 ngx_add_timer(rev, clcf->lingering_timeout);
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2883
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2884 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2885 ngx_http_close_request(r, 0);
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2886 return;
53
d1e42f1b8fd4 nginx-0.0.1-2003-01-27-00:08:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 52
diff changeset
2887 }
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2888
144
ef8c87afcfc5 nginx-0.0.1-2003-10-12-20:49:16 import
Igor Sysoev <igor@sysoev.ru>
parents: 143
diff changeset
2889 wev = c->write;
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2890 wev->handler = ngx_http_empty_handler;
53
d1e42f1b8fd4 nginx-0.0.1-2003-01-27-00:08:14 import
Igor Sysoev <igor@sysoev.ru>
parents: 52
diff changeset
2891
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2892 if (wev->active && (ngx_event_flags & NGX_USE_LEVEL_EVENT)) {
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2893 if (ngx_del_event(wev, NGX_WRITE_EVENT, 0) != NGX_OK) {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2894 ngx_http_close_request(r, 0);
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2895 return;
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2896 }
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2897 }
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2898
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2899 if (ngx_shutdown_socket(c->fd, NGX_WRITE_SHUTDOWN) == -1) {
328
fb4dfb2ac0fc nginx-0.0.3-2004-04-28-10:14:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 326
diff changeset
2900 ngx_connection_error(c, ngx_socket_errno,
fb4dfb2ac0fc nginx-0.0.3-2004-04-28-10:14:50 import
Igor Sysoev <igor@sysoev.ru>
parents: 326
diff changeset
2901 ngx_shutdown_socket_n " failed");
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2902 ngx_http_close_request(r, 0);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2903 return;
60
50186b49f2ad nginx-0.0.1-2003-02-11-10:14:40 import
Igor Sysoev <igor@sysoev.ru>
parents: 59
diff changeset
2904 }
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2905
164
84036764e215 nginx-0.0.1-2003-10-29-11:30:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 161
diff changeset
2906 if (rev->ready) {
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2907 ngx_http_lingering_close_handler(rev);
67
5a7d1aaa1618 nginx-0.0.1-2003-03-11-23:38:13 import
Igor Sysoev <igor@sysoev.ru>
parents: 66
diff changeset
2908 }
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2909 }
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2910
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2911
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2912 static void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2913 ngx_http_lingering_close_handler(ngx_event_t *rev)
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 24
diff changeset
2914 {
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2915 ssize_t n;
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2916 ngx_msec_t timer;
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2917 ngx_connection_t *c;
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2918 ngx_http_request_t *r;
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2919 ngx_http_core_loc_conf_t *clcf;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2920 u_char buffer[NGX_HTTP_LINGERING_BUFFER_SIZE];
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2921
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2922 c = rev->data;
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2923 r = c->data;
57
a499e0d1f16e nginx-0.0.1-2003-01-30-10:28:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 55
diff changeset
2924
239
574bea0142be nginx-0.0.1-2004-01-26-11:52:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 233
diff changeset
2925 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, c->log, 0,
574bea0142be nginx-0.0.1-2004-01-26-11:52:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 233
diff changeset
2926 "http lingering close handler");
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2927
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2928 if (rev->timedout) {
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2929 ngx_http_close_request(r, 0);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2930 return;
38
2ffaa35fba42 nginx-0.0.1-2002-12-24-10:09:57 import
Igor Sysoev <igor@sysoev.ru>
parents: 37
diff changeset
2931 }
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2932
1640
02a22cd5282a 64-bit time_t compatibility
Igor Sysoev <igor@sysoev.ru>
parents: 1630
diff changeset
2933 timer = (ngx_msec_t) (r->lingering_time - ngx_time());
38
2ffaa35fba42 nginx-0.0.1-2002-12-24-10:09:57 import
Igor Sysoev <igor@sysoev.ru>
parents: 37
diff changeset
2934 if (timer <= 0) {
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2935 ngx_http_close_request(r, 0);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2936 return;
38
2ffaa35fba42 nginx-0.0.1-2002-12-24-10:09:57 import
Igor Sysoev <igor@sysoev.ru>
parents: 37
diff changeset
2937 }
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2938
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2939 do {
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2940 n = c->recv(c, buffer, NGX_HTTP_LINGERING_BUFFER_SIZE);
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2941
239
574bea0142be nginx-0.0.1-2004-01-26-11:52:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 233
diff changeset
2942 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0, "lingering read: %d", n);
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2943
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2944 if (n == NGX_ERROR || n == 0) {
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2945 ngx_http_close_request(r, 0);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
2946 return;
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2947 }
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2948
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2949 } while (rev->ready);
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2950
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2385
diff changeset
2951 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
477
ad1e9ebf93bb nginx-0.1.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 475
diff changeset
2952 ngx_http_close_request(r, 0);
475
c3c2848fc081 nginx-0.1.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 473
diff changeset
2953 return;
c3c2848fc081 nginx-0.1.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 473
diff changeset
2954 }
c3c2848fc081 nginx-0.1.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 473
diff changeset
2955
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2956 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2957
13
2aba961a1d34 nginx-0.0.1-2002-09-16-19:01:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 12
diff changeset
2958 timer *= 1000;
436
9549fc9508e5 nginx-0.0.11-2004-09-23-10:32:00 import
Igor Sysoev <igor@sysoev.ru>
parents: 435
diff changeset
2959
96
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2960 if (timer > clcf->lingering_timeout) {
a23d010f356d nginx-0.0.1-2003-05-27-16:18:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 95
diff changeset
2961 timer = clcf->lingering_timeout;
38
2ffaa35fba42 nginx-0.0.1-2002-12-24-10:09:57 import
Igor Sysoev <igor@sysoev.ru>
parents: 37
diff changeset
2962 }
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2963
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
2964 ngx_add_timer(rev, timer);
12
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2965 }
055ed05235ae nginx-0.0.1-2002-09-13-18:47:42 import
Igor Sysoev <igor@sysoev.ru>
parents: 11
diff changeset
2966
3
34a521b1a148 nginx-0.0.1-2002-08-20-18:48:28 import
Igor Sysoev <igor@sysoev.ru>
parents: 2
diff changeset
2967
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2968 void
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2969 ngx_http_empty_handler(ngx_event_t *wev)
94
8220378432a8 nginx-0.0.1-2003-05-22-19:23:47 import
Igor Sysoev <igor@sysoev.ru>
parents: 93
diff changeset
2970 {
239
574bea0142be nginx-0.0.1-2004-01-26-11:52:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 233
diff changeset
2971 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, wev->log, 0, "http empty handler");
94
8220378432a8 nginx-0.0.1-2003-05-22-19:23:47 import
Igor Sysoev <igor@sysoev.ru>
parents: 93
diff changeset
2972
8220378432a8 nginx-0.0.1-2003-05-22-19:23:47 import
Igor Sysoev <igor@sysoev.ru>
parents: 93
diff changeset
2973 return;
8220378432a8 nginx-0.0.1-2003-05-22-19:23:47 import
Igor Sysoev <igor@sysoev.ru>
parents: 93
diff changeset
2974 }
8220378432a8 nginx-0.0.1-2003-05-22-19:23:47 import
Igor Sysoev <igor@sysoev.ru>
parents: 93
diff changeset
2975
8220378432a8 nginx-0.0.1-2003-05-22-19:23:47 import
Igor Sysoev <igor@sysoev.ru>
parents: 93
diff changeset
2976
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2977 void
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2978 ngx_http_request_empty_handler(ngx_http_request_t *r)
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2979 {
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2980 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
2981 "http request empty handler");
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2982
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2983 return;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2984 }
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2985
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
2986
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2987 ngx_int_t
581
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
2988 ngx_http_send_special(ngx_http_request_t *r, ngx_uint_t flags)
142
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
2989 {
343
6bdf858bff8c nginx-0.0.3-2004-05-28-19:49:23 import; rename ngx_hunk_t to ngx_buf_t
Igor Sysoev <igor@sysoev.ru>
parents: 335
diff changeset
2990 ngx_buf_t *b;
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
2991 ngx_chain_t out;
142
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
2992
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2993 b = ngx_calloc_buf(r->pool);
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
2994 if (b == NULL) {
343
6bdf858bff8c nginx-0.0.3-2004-05-28-19:49:23 import; rename ngx_hunk_t to ngx_buf_t
Igor Sysoev <igor@sysoev.ru>
parents: 335
diff changeset
2995 return NGX_ERROR;
6bdf858bff8c nginx-0.0.3-2004-05-28-19:49:23 import; rename ngx_hunk_t to ngx_buf_t
Igor Sysoev <igor@sysoev.ru>
parents: 335
diff changeset
2996 }
6bdf858bff8c nginx-0.0.3-2004-05-28-19:49:23 import; rename ngx_hunk_t to ngx_buf_t
Igor Sysoev <igor@sysoev.ru>
parents: 335
diff changeset
2997
581
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
2998 if (flags & NGX_HTTP_LAST) {
2971
87ddbe960172 fix ngx_http_send_special() for subrequests handled by perl
Igor Sysoev <igor@sysoev.ru>
parents: 2951
diff changeset
2999
87ddbe960172 fix ngx_http_send_special() for subrequests handled by perl
Igor Sysoev <igor@sysoev.ru>
parents: 2951
diff changeset
3000 if (r == r->main && !r->post_action) {
87ddbe960172 fix ngx_http_send_special() for subrequests handled by perl
Igor Sysoev <igor@sysoev.ru>
parents: 2951
diff changeset
3001 b->last_buf = 1;
87ddbe960172 fix ngx_http_send_special() for subrequests handled by perl
Igor Sysoev <igor@sysoev.ru>
parents: 2951
diff changeset
3002
87ddbe960172 fix ngx_http_send_special() for subrequests handled by perl
Igor Sysoev <igor@sysoev.ru>
parents: 2951
diff changeset
3003 } else {
2993
f592d466bbda fix r2972, it caused "zero size buf" alert.
Igor Sysoev <igor@sysoev.ru>
parents: 2992
diff changeset
3004 b->sync = 1;
2971
87ddbe960172 fix ngx_http_send_special() for subrequests handled by perl
Igor Sysoev <igor@sysoev.ru>
parents: 2951
diff changeset
3005 b->last_in_chain = 1;
87ddbe960172 fix ngx_http_send_special() for subrequests handled by perl
Igor Sysoev <igor@sysoev.ru>
parents: 2951
diff changeset
3006 }
581
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
3007 }
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
3008
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
3009 if (flags & NGX_HTTP_FLUSH) {
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
3010 b->flush = 1;
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
3011 }
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
3012
343
6bdf858bff8c nginx-0.0.3-2004-05-28-19:49:23 import; rename ngx_hunk_t to ngx_buf_t
Igor Sysoev <igor@sysoev.ru>
parents: 335
diff changeset
3013 out.buf = b;
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
3014 out.next = NULL;
142
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
3015
153
c71aeb75c071 nginx-0.0.1-2003-10-21-20:49:56 import
Igor Sysoev <igor@sysoev.ru>
parents: 152
diff changeset
3016 return ngx_http_output_filter(r, &out);
142
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
3017 }
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
3018
cb77c084acdb nginx-0.0.1-2003-10-09-11:00:45 import
Igor Sysoev <igor@sysoev.ru>
parents: 137
diff changeset
3019
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3020 static ngx_int_t
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3021 ngx_http_post_action(ngx_http_request_t *r)
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3022 {
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3023 ngx_http_core_loc_conf_t *clcf;
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3024
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3025 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3026
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3027 if (clcf->post_action.data == NULL) {
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3028 return NGX_DECLINED;
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3029 }
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3030
4472
c95b828912a3 Core: protection from cycles with named locations and post_action.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4471
diff changeset
3031 if (r->post_action && r->uri_changes == 0) {
c95b828912a3 Core: protection from cycles with named locations and post_action.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4471
diff changeset
3032 return NGX_DECLINED;
c95b828912a3 Core: protection from cycles with named locations and post_action.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4471
diff changeset
3033 }
c95b828912a3 Core: protection from cycles with named locations and post_action.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4471
diff changeset
3034
623
0216fd1471f3 nginx-0.3.33-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 615
diff changeset
3035 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
0216fd1471f3 nginx-0.3.33-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 615
diff changeset
3036 "post action: \"%V\"", &clcf->post_action);
0216fd1471f3 nginx-0.3.33-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 615
diff changeset
3037
3145
9160a117a46a fix request counter for post_action, the bug was introduced in r3050
Igor Sysoev <igor@sysoev.ru>
parents: 3076
diff changeset
3038 r->main->count--;
9160a117a46a fix request counter for post_action, the bug was introduced in r3050
Igor Sysoev <igor@sysoev.ru>
parents: 3076
diff changeset
3039
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3040 r->http_version = NGX_HTTP_VERSION_9;
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3041 r->header_only = 1;
629
65bf042c0b4f nginx-0.3.36-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 623
diff changeset
3042 r->post_action = 1;
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3043
1368
202cae9a0c2b rename ngx_http_block_read() and ngx_http_test_read() to ..._reading()
Igor Sysoev <igor@sysoev.ru>
parents: 1283
diff changeset
3044 r->read_event_handler = ngx_http_block_reading;
895
49d03c183ad2 fix post_action for disconnected client
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
3045
1894
22e28e77246b named locations in post_action
Igor Sysoev <igor@sysoev.ru>
parents: 1858
diff changeset
3046 if (clcf->post_action.data[0] == '/') {
22e28e77246b named locations in post_action
Igor Sysoev <igor@sysoev.ru>
parents: 1858
diff changeset
3047 ngx_http_internal_redirect(r, &clcf->post_action, NULL);
22e28e77246b named locations in post_action
Igor Sysoev <igor@sysoev.ru>
parents: 1858
diff changeset
3048
22e28e77246b named locations in post_action
Igor Sysoev <igor@sysoev.ru>
parents: 1858
diff changeset
3049 } else {
22e28e77246b named locations in post_action
Igor Sysoev <igor@sysoev.ru>
parents: 1858
diff changeset
3050 ngx_http_named_location(r, &clcf->post_action);
22e28e77246b named locations in post_action
Igor Sysoev <igor@sysoev.ru>
parents: 1858
diff changeset
3051 }
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3052
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3053 return NGX_OK;
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3054 }
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3055
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3056
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3057 static void
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3058 ngx_http_close_request(ngx_http_request_t *r, ngx_int_t rc)
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3059 {
639
715d24327080 nginx-0.3.41-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 637
diff changeset
3060 ngx_connection_t *c;
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
3061
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3062 r = r->main;
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
3063 c = r->connection;
639
715d24327080 nginx-0.3.41-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 637
diff changeset
3064
3052
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
3065 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0,
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
3066 "http request count:%d blk:%d", r->count, r->blocked);
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3067
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3068 if (r->count == 0) {
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3069 ngx_log_error(NGX_LOG_ALERT, c->log, 0, "http request count is zero");
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3070 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3071
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3072 r->count--;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3073
3052
6060225e9261 FreeBSD and Linux AIO support
Igor Sysoev <igor@sysoev.ru>
parents: 3051
diff changeset
3074 if (r->count || r->blocked) {
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3075 return;
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3076 }
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3077
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3078 ngx_http_free_request(r, rc);
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
3079 ngx_http_close_connection(c);
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
3080 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
3081
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
3082
613
c73c5c58c619 nginx-0.3.28-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 611
diff changeset
3083 static void
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3084 ngx_http_free_request(ngx_http_request_t *r, ngx_int_t rc)
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 567
diff changeset
3085 {
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3086 ngx_log_t *log;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3087 struct linger linger;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3088 ngx_http_cleanup_t *cln;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3089 ngx_http_log_ctx_t *ctx;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3090 ngx_http_core_loc_conf_t *clcf;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3091
201
267ea1d98683 nginx-0.0.1-2003-11-30-23:03:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 200
diff changeset
3092 log = r->connection->log;
267ea1d98683 nginx-0.0.1-2003-11-30-23:03:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 200
diff changeset
3093
267ea1d98683 nginx-0.0.1-2003-11-30-23:03:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 200
diff changeset
3094 ngx_log_debug0(NGX_LOG_DEBUG_HTTP, log, 0, "http close request");
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3095
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3096 if (r->pool == NULL) {
531
c3bd8cdabb8f nginx-0.1.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 527
diff changeset
3097 ngx_log_error(NGX_LOG_ALERT, log, 0, "http request already closed");
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3098 return;
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3099 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3100
639
715d24327080 nginx-0.3.41-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 637
diff changeset
3101 for (cln = r->cleanup; cln; cln = cln->next) {
715d24327080 nginx-0.3.41-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 637
diff changeset
3102 if (cln->handler) {
715d24327080 nginx-0.3.41-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 637
diff changeset
3103 cln->handler(cln->data);
715d24327080 nginx-0.3.41-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 637
diff changeset
3104 }
715d24327080 nginx-0.3.41-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 637
diff changeset
3105 }
715d24327080 nginx-0.3.41-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 637
diff changeset
3106
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
3107 #if (NGX_STAT_STUB)
567
1af2fcb3be8a nginx-0.3.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
3108
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
3109 if (r->stat_reading) {
2951
5acd98486a33 ignore ngx_atomic_fetch_add() result
Igor Sysoev <igor@sysoev.ru>
parents: 2902
diff changeset
3110 (void) ngx_atomic_fetch_add(ngx_stat_reading, -1);
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
3111 }
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
3112
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
3113 if (r->stat_writing) {
2951
5acd98486a33 ignore ngx_atomic_fetch_add() result
Igor Sysoev <igor@sysoev.ru>
parents: 2902
diff changeset
3114 (void) ngx_atomic_fetch_add(ngx_stat_writing, -1);
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
3115 }
567
1af2fcb3be8a nginx-0.3.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
3116
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
3117 #endif
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 426
diff changeset
3118
3049
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3119 if (rc > 0 && (r->headers_out.status == 0 || r->connection->sent == 0)) {
67254117b774 request reference counter
Igor Sysoev <igor@sysoev.ru>
parents: 3000
diff changeset
3120 r->headers_out.status = rc;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3121 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3122
2077
479440385e35 fix error message
Igor Sysoev <igor@sysoev.ru>
parents: 2067
diff changeset
3123 log->action = "logging request";
479440385e35 fix error message
Igor Sysoev <igor@sysoev.ru>
parents: 2067
diff changeset
3124
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3125 ngx_http_log_request(r);
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3126
2077
479440385e35 fix error message
Igor Sysoev <igor@sysoev.ru>
parents: 2067
diff changeset
3127 log->action = "closing request";
479440385e35 fix error message
Igor Sysoev <igor@sysoev.ru>
parents: 2067
diff changeset
3128
346
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3129 if (r->connection->timedout) {
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3130 clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3131
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3132 if (clcf->reset_timedout_connection) {
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3133 linger.l_onoff = 1;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3134 linger.l_linger = 0;
346
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3135
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3136 if (setsockopt(r->connection->fd, SOL_SOCKET, SO_LINGER,
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3137 (const void *) &linger, sizeof(struct linger)) == -1)
346
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3138 {
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3139 ngx_log_error(NGX_LOG_ALERT, log, ngx_socket_errno,
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3140 "setsockopt(SO_LINGER) failed");
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3141 }
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3142 }
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3143 }
55e496a8ece3 nginx-0.0.3-2004-06-06-23:49:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 344
diff changeset
3144
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3145 /* the various request strings were allocated from r->pool */
201
267ea1d98683 nginx-0.0.1-2003-11-30-23:03:18 import
Igor Sysoev <igor@sysoev.ru>
parents: 200
diff changeset
3146 ctx = log->data;
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
3147 ctx->request = NULL;
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3148
367
ceec87d1c2b3 nginx-0.0.7-2004-06-24-11:53:37 import
Igor Sysoev <igor@sysoev.ru>
parents: 362
diff changeset
3149 r->request_line.len = 0;
ceec87d1c2b3 nginx-0.0.7-2004-06-24-11:53:37 import
Igor Sysoev <igor@sysoev.ru>
parents: 362
diff changeset
3150
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
3151 r->connection->destroyed = 1;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
3152
87
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3153 ngx_destroy_pool(r->pool);
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3154 }
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3155
5f6d848dcbef nginx-0.0.1-2003-05-13-20:02:32 import
Igor Sysoev <igor@sysoev.ru>
parents: 86
diff changeset
3156
531
c3bd8cdabb8f nginx-0.1.40-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 527
diff changeset
3157 static void
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3158 ngx_http_log_request(ngx_http_request_t *r)
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3159 {
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3160 ngx_uint_t i, n;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3161 ngx_http_handler_pt *log_handler;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3162 ngx_http_core_main_conf_t *cmcf;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3163
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3164 cmcf = ngx_http_get_module_main_conf(r, ngx_http_core_module);
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3165
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3166 log_handler = cmcf->phases[NGX_HTTP_LOG_PHASE].handlers.elts;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3167 n = cmcf->phases[NGX_HTTP_LOG_PHASE].handlers.nelts;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3168
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3169 for (i = 0; i < n; i++) {
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3170 log_handler[i](r);
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3171 }
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3172 }
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3173
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3174
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2256
diff changeset
3175 static void
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
3176 ngx_http_close_connection(ngx_connection_t *c)
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
3177 {
479
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
3178 ngx_pool_t *pool;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
3179
239
574bea0142be nginx-0.0.1-2004-01-26-11:52:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 233
diff changeset
3180 ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
257
70e1c7d2b83d nginx-0.0.2-2004-02-11-20:08:49 import
Igor Sysoev <igor@sysoev.ru>
parents: 256
diff changeset
3181 "close http connection: %d", c->fd);
86
3973260705cc nginx-0.0.1-2003-05-12-19:52:24 import
Igor Sysoev <igor@sysoev.ru>
parents: 82
diff changeset
3182
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 537
diff changeset
3183 #if (NGX_HTTP_SSL)
452
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3184
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3185 if (c->ssl) {
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3186 if (ngx_ssl_shutdown(c) == NGX_AGAIN) {
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 573
diff changeset
3187 c->ssl->handler = ngx_http_close_connection;
452
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3188 return;
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3189 }
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3190 }
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3191
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3192 #endif
23fb87bddda1 nginx-0.1.1-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 449
diff changeset
3193
426
3f88935a02e8 nginx-0.0.10-2004-09-14-23:39:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 423
diff changeset
3194 #if (NGX_STAT_STUB)
2951
5acd98486a33 ignore ngx_atomic_fetch_add() result
Igor Sysoev <igor@sysoev.ru>
parents: 2902
diff changeset
3195 (void) ngx_atomic_fetch_add(ngx_stat_active, -1);
426
3f88935a02e8 nginx-0.0.10-2004-09-14-23:39:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 423
diff changeset
3196 #endif
3f88935a02e8 nginx-0.0.10-2004-09-14-23:39:54 import
Igor Sysoev <igor@sysoev.ru>
parents: 423
diff changeset
3197
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
3198 c->destroyed = 1;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
3199
479
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
3200 pool = c->pool;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
3201
417
0526206251f6 nginx-0.0.10-2004-09-07-19:29:22 import
Igor Sysoev <igor@sysoev.ru>
parents: 416
diff changeset
3202 ngx_close_connection(c);
479
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
3203
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
3204 ngx_destroy_pool(pool);
18
72ad26c77d2d nginx-0.0.1-2002-10-04-21:58:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 17
diff changeset
3205 }
72ad26c77d2d nginx-0.0.1-2002-10-04-21:58:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 17
diff changeset
3206
72ad26c77d2d nginx-0.0.1-2002-10-04-21:58:04 import
Igor Sysoev <igor@sysoev.ru>
parents: 17
diff changeset
3207
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
3208 static u_char *
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
3209 ngx_http_log_error(ngx_log_t *log, u_char *buf, size_t len)
6
669801705ab1 nginx-0.0.1-2002-08-26-19:18:19 import
Igor Sysoev <igor@sysoev.ru>
parents: 3
diff changeset
3210 {
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
3211 u_char *p;
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3212 ngx_http_request_t *r;
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
3213 ngx_http_log_ctx_t *ctx;
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
3214
483
621229427cba nginx-0.1.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
3215 if (log->action) {
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3216 p = ngx_snprintf(buf, len, " while %s", log->action);
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
3217 len -= p - buf;
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3218 buf = p;
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
3219 }
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
3220
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3221 ctx = log->data;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3222
1810
755e09d5c271 log server address
Igor Sysoev <igor@sysoev.ru>
parents: 1805
diff changeset
3223 p = ngx_snprintf(buf, len, ", client: %V", &ctx->connection->addr_text);
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3224 len -= p - buf;
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3225
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3226 r = ctx->request;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3227
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3228 if (r) {
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3229 return r->log_handler(r, ctx->current_request, p, len);
1810
755e09d5c271 log server address
Igor Sysoev <igor@sysoev.ru>
parents: 1805
diff changeset
3230
755e09d5c271 log server address
Igor Sysoev <igor@sysoev.ru>
parents: 1805
diff changeset
3231 } else {
755e09d5c271 log server address
Igor Sysoev <igor@sysoev.ru>
parents: 1805
diff changeset
3232 p = ngx_snprintf(p, len, ", server: %V",
755e09d5c271 log server address
Igor Sysoev <igor@sysoev.ru>
parents: 1805
diff changeset
3233 &ctx->connection->listening->addr_text);
69
e43f406e4525 nginx-0.0.1-2003-03-20-19:09:44 import
Igor Sysoev <igor@sysoev.ru>
parents: 68
diff changeset
3234 }
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
3235
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3236 return p;
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3237 }
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3238
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3239
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3240 static u_char *
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3241 ngx_http_log_error_handler(ngx_http_request_t *r, ngx_http_request_t *sr,
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3242 u_char *buf, size_t len)
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 507
diff changeset
3243 {
1811
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3244 char *uri_separator;
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3245 u_char *p;
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3246 ngx_http_upstream_t *u;
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3247 ngx_http_core_srv_conf_t *cscf;
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3248
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3249 cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3250
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3251 p = ngx_snprintf(buf, len, ", server: %V", &cscf->server_name);
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3252 len -= p - buf;
0d9c6fe7502b axe useless r->server_name
Igor Sysoev <igor@sysoev.ru>
parents: 1810
diff changeset
3253 buf = p;
503
b1648294f693 nginx-0.1.26-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 501
diff changeset
3254
1656
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3255 if (r->request_line.data == NULL && r->request_start) {
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3256 for (p = r->request_start; p < r->header_in->last; p++) {
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3257 if (*p == CR || *p == LF) {
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3258 break;
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3259 }
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3260 }
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3261
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3262 r->request_line.len = p - r->request_start;
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3263 r->request_line.data = r->request_start;
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3264 }
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3265
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3266 if (r->request_line.len) {
7a9b44e35c53 log entire request line instead of URI only
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
3267 p = ngx_snprintf(buf, len, ", request: \"%V\"", &r->request_line);
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3268 len -= p - buf;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3269 buf = p;
461
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
3270 }
a88a3e4e158f nginx-0.1.5-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 457
diff changeset
3271
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3272 if (r != sr) {
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3273 p = ngx_snprintf(buf, len, ", subrequest: \"%V\"", &sr->uri);
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3274 len -= p - buf;
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3275 buf = p;
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3276 }
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3277
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3278 u = sr->upstream;
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3279
884
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3280 if (u && u->peer.name) {
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3281
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3282 uri_separator = "";
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3283
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3284 #if (NGX_HAVE_UNIX_DOMAIN)
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3285 if (u->peer.sockaddr && u->peer.sockaddr->sa_family == AF_UNIX) {
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3286 uri_separator = ":";
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3287 }
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3288 #endif
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3289
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3290 p = ngx_snprintf(buf, len, ", upstream: \"%V%V%s%V\"",
1658
13f8dec720b5 proxy_pass variables support
Igor Sysoev <igor@sysoev.ru>
parents: 1656
diff changeset
3291 &u->schema, u->peer.name,
884
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 864
diff changeset
3292 uri_separator, &u->uri);
665
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3293 len -= p - buf;
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3294 buf = p;
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3295 }
5fd7a5e99047 nginx-0.3.54-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
3296
505
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3297 if (r->headers_in.host) {
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3298 p = ngx_snprintf(buf, len, ", host: \"%V\"",
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3299 &r->headers_in.host->value);
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3300 len -= p - buf;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3301 buf = p;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3302 }
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3303
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3304 if (r->headers_in.referer) {
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3305 p = ngx_snprintf(buf, len, ", referrer: \"%V\"",
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3306 &r->headers_in.referer->value);
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3307 buf = p;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3308 }
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3309
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3310 return buf;
ee66921ecd47 nginx-0.1.27-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 503
diff changeset
3311 }