annotate src/stream/ngx_stream_log_module.c @ 6965:3ef4cadfad7f

Added support for "429 Too Many Requests" response (RFC6585). This change adds reason phrase in status line and pretty response body when "429" status code is used in "return", "limit_conn_status" and/or "limit_req_status" directives. Signed-off-by: Piotr Sikora <piotrsikora@google.com>
author Piotr Sikora <piotrsikora@google.com>
date Fri, 24 Mar 2017 02:48:03 -0700
parents 3fb9b5eb75c0
children 265c29b0b8b8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
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: 427
diff changeset
1
da8c5707af39 nginx-0.1.0-2004-09-28-12:34:51 import; set copyright and remove unused files
Igor Sysoev <igor@sysoev.ru>
parents: 427
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: 4327
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: 427
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: 427
diff changeset
6
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
7
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
10 #include <ngx_stream.h>
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
11
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
12 #if (NGX_ZLIB)
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
13 #include <zlib.h>
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
14 #endif
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
15
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
16
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
17 typedef struct ngx_stream_log_op_s ngx_stream_log_op_t;
880
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
18
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
19 typedef u_char *(*ngx_stream_log_op_run_pt) (ngx_stream_session_t *s,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
20 u_char *buf, ngx_stream_log_op_t *op);
880
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
21
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
22 typedef size_t (*ngx_stream_log_op_getlen_pt) (ngx_stream_session_t *s,
880
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
23 uintptr_t data);
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
24
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
25
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
26 struct ngx_stream_log_op_s {
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
27 size_t len;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
28 ngx_stream_log_op_getlen_pt getlen;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
29 ngx_stream_log_op_run_pt run;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
30 uintptr_t data;
880
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
31 };
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
32
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
33
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
34 typedef struct {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
35 ngx_str_t name;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
36 ngx_array_t *flushes;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
37 ngx_array_t *ops; /* array of ngx_stream_log_op_t */
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
38 } ngx_stream_log_fmt_t;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
39
657
400711951595 nginx-0.3.50-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 645
diff changeset
40
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
41 typedef struct {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
42 ngx_array_t formats; /* array of ngx_stream_log_fmt_t */
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
43 } ngx_stream_log_main_conf_t;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
44
657
400711951595 nginx-0.3.50-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 645
diff changeset
45
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
46 typedef struct {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
47 u_char *start;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
48 u_char *pos;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
49 u_char *last;
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
50
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
51 ngx_event_t *event;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
52 ngx_msec_t flush;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
53 ngx_int_t gzip;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
54 } ngx_stream_log_buf_t;
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
55
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
56
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
57 typedef struct {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
58 ngx_array_t *lengths;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
59 ngx_array_t *values;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
60 } ngx_stream_log_script_t;
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
61
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
62
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
63 typedef struct {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
64 ngx_open_file_t *file;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
65 ngx_stream_log_script_t *script;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
66 time_t disk_full_time;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
67 time_t error_log_time;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
68 ngx_syslog_peer_t *syslog_peer;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
69 ngx_stream_log_fmt_t *format;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
70 ngx_stream_complex_value_t *filter;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
71 } ngx_stream_log_t;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
72
657
400711951595 nginx-0.3.50-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 645
diff changeset
73
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
74 typedef struct {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
75 ngx_array_t *logs; /* array of ngx_stream_log_t */
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
76
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
77 ngx_open_file_cache_t *open_file_cache;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
78 time_t open_file_cache_valid;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
79 ngx_uint_t open_file_cache_min_uses;
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
80
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
81 ngx_uint_t off; /* unsigned off:1 */
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
82 } ngx_stream_log_srv_conf_t;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
83
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
84
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
85 typedef struct {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
86 ngx_str_t name;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
87 size_t len;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
88 ngx_stream_log_op_run_pt run;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
89 } ngx_stream_log_var_t;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
90
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
91
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
92 static void ngx_stream_log_write(ngx_stream_session_t *s, ngx_stream_log_t *log,
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
93 u_char *buf, size_t len);
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
94 static ssize_t ngx_stream_log_script_write(ngx_stream_session_t *s,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
95 ngx_stream_log_script_t *script, u_char **name, u_char *buf, size_t len);
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
96
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
97 #if (NGX_ZLIB)
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
98 static ssize_t ngx_stream_log_gzip(ngx_fd_t fd, u_char *buf, size_t len,
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
99 ngx_int_t level, ngx_log_t *log);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
100
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
101 static void *ngx_stream_log_gzip_alloc(void *opaque, u_int items, u_int size);
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
102 static void ngx_stream_log_gzip_free(void *opaque, void *address);
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
103 #endif
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
104
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
105 static void ngx_stream_log_flush(ngx_open_file_t *file, ngx_log_t *log);
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
106 static void ngx_stream_log_flush_handler(ngx_event_t *ev);
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
107
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
108 static ngx_int_t ngx_stream_log_variable_compile(ngx_conf_t *cf,
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
109 ngx_stream_log_op_t *op, ngx_str_t *value, ngx_uint_t json);
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
110 static size_t ngx_stream_log_variable_getlen(ngx_stream_session_t *s,
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
111 uintptr_t data);
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
112 static u_char *ngx_stream_log_variable(ngx_stream_session_t *s, u_char *buf,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
113 ngx_stream_log_op_t *op);
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
114 static uintptr_t ngx_stream_log_escape(u_char *dst, u_char *src, size_t size);
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
115 static size_t ngx_stream_log_json_variable_getlen(ngx_stream_session_t *s,
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
116 uintptr_t data);
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
117 static u_char *ngx_stream_log_json_variable(ngx_stream_session_t *s,
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
118 u_char *buf, ngx_stream_log_op_t *op);
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
119
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
120
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
121 static void *ngx_stream_log_create_main_conf(ngx_conf_t *cf);
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
122 static void *ngx_stream_log_create_srv_conf(ngx_conf_t *cf);
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
123 static char *ngx_stream_log_merge_srv_conf(ngx_conf_t *cf, void *parent,
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
124 void *child);
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
125 static char *ngx_stream_log_set_log(ngx_conf_t *cf, ngx_command_t *cmd,
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
126 void *conf);
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
127 static char *ngx_stream_log_set_format(ngx_conf_t *cf, ngx_command_t *cmd,
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
128 void *conf);
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
129 static char *ngx_stream_log_compile_format(ngx_conf_t *cf,
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
130 ngx_array_t *flushes, ngx_array_t *ops, ngx_array_t *args, ngx_uint_t s);
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
131 static char *ngx_stream_log_open_file_cache(ngx_conf_t *cf, ngx_command_t *cmd,
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
132 void *conf);
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
133 static ngx_int_t ngx_stream_log_init(ngx_conf_t *cf);
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
134
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
135
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
136 static ngx_command_t ngx_stream_log_commands[] = {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
137
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
138 { ngx_string("log_format"),
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
139 NGX_STREAM_MAIN_CONF|NGX_CONF_2MORE,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
140 ngx_stream_log_set_format,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
141 NGX_STREAM_MAIN_CONF_OFFSET,
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
142 0,
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
143 NULL },
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
144
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
145 { ngx_string("access_log"),
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
146 NGX_STREAM_MAIN_CONF|NGX_STREAM_SRV_CONF|NGX_CONF_1MORE,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
147 ngx_stream_log_set_log,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
148 NGX_STREAM_SRV_CONF_OFFSET,
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
149 0,
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
150 NULL },
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
151
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
152 { ngx_string("open_log_file_cache"),
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
153 NGX_STREAM_MAIN_CONF|NGX_STREAM_SRV_CONF|NGX_CONF_TAKE1234,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
154 ngx_stream_log_open_file_cache,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
155 NGX_STREAM_SRV_CONF_OFFSET,
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
156 0,
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
157 NULL },
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
158
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
159 ngx_null_command
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
160 };
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
161
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
162
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
163 static ngx_stream_module_t ngx_stream_log_module_ctx = {
880
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
164 NULL, /* preconfiguration */
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
165 ngx_stream_log_init, /* postconfiguration */
177
4db54fdbcbe7 nginx-0.0.1-2003-11-10-20:17:31 import
Igor Sysoev <igor@sysoev.ru>
parents: 176
diff changeset
166
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
167 ngx_stream_log_create_main_conf, /* create main configuration */
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
168 NULL, /* init main configuration */
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
169
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
170 ngx_stream_log_create_srv_conf, /* create server configuration */
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
171 ngx_stream_log_merge_srv_conf /* merge server configuration */
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
172 };
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
173
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
174
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
175 ngx_module_t ngx_stream_log_module = {
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
176 NGX_MODULE_V1,
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
177 &ngx_stream_log_module_ctx, /* module context */
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
178 ngx_stream_log_commands, /* module directives */
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
179 NGX_STREAM_MODULE, /* module type */
541
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
180 NULL, /* init master */
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
181 NULL, /* init module */
541
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
182 NULL, /* init process */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
183 NULL, /* init thread */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
184 NULL, /* exit thread */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
185 NULL, /* exit process */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
186 NULL, /* exit master */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
187 NGX_MODULE_V1_PADDING
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
188 };
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
189
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
190
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
191 static ngx_int_t
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
192 ngx_stream_log_handler(ngx_stream_session_t *s)
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
193 {
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
194 u_char *line, *p;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
195 size_t len, size;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
196 ssize_t n;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
197 ngx_str_t val;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
198 ngx_uint_t i, l;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
199 ngx_stream_log_t *log;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
200 ngx_stream_log_op_t *op;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
201 ngx_stream_log_buf_t *buffer;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
202 ngx_stream_log_srv_conf_t *lscf;
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
203
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
204 ngx_log_debug0(NGX_LOG_DEBUG_STREAM, s->connection->log, 0,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
205 "stream log handler");
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
206
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
207 lscf = ngx_stream_get_module_srv_conf(s, ngx_stream_log_module);
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
208
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
209 if (lscf->off || lscf->logs == NULL) {
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
210 return NGX_OK;
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
211 }
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
212
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
213 log = lscf->logs->elts;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
214 for (l = 0; l < lscf->logs->nelts; l++) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
215
5653
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
216 if (log[l].filter) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
217 if (ngx_stream_complex_value(s, log[l].filter, &val) != NGX_OK) {
5653
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
218 return NGX_ERROR;
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
219 }
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
220
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
221 if (val.len == 0 || (val.len == 1 && val.data[0] == '0')) {
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
222 continue;
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
223 }
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
224 }
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
225
633
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
226 if (ngx_time() == log[l].disk_full_time) {
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
227
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
228 /*
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
229 * on FreeBSD writing to a full filesystem with enabled softupdates
633
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
230 * may block process for much longer time than writing to non-full
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
231 * filesystem, so we skip writing to a log for one second
633
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
232 */
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
233
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
234 continue;
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
235 }
f971949ffb58 nginx-0.3.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 581
diff changeset
236
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
237 ngx_stream_script_flush_no_cacheable_variables(s,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
238 log[l].format->flushes);
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
239
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
240 len = 0;
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
241 op = log[l].format->ops->elts;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
242 for (i = 0; i < log[l].format->ops->nelts; i++) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
243 if (op[i].len == 0) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
244 len += op[i].getlen(s, op[i].data);
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
245
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
246 } else {
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
247 len += op[i].len;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
248 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
249 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
250
5702
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
251 if (log[l].syslog_peer) {
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
252
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
253 /* length of syslog's PRI and HEADER message parts */
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
254 len += sizeof("<255>Jan 01 00:00:00 ") - 1
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
255 + ngx_cycle->hostname.len + 1
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
256 + log[l].syslog_peer->tag.len + 2;
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
257
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
258 goto alloc_line;
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
259 }
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
260
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
261 len += NGX_LINEFEED_SIZE;
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
262
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
263 buffer = log[l].file ? log[l].file->data : NULL;
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
264
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
265 if (buffer) {
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
266
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
267 if (len > (size_t) (buffer->last - buffer->pos)) {
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
268
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
269 ngx_stream_log_write(s, &log[l], buffer->start,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
270 buffer->pos - buffer->start);
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
271
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
272 buffer->pos = buffer->start;
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
273 }
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
274
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
275 if (len <= (size_t) (buffer->last - buffer->pos)) {
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
276
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
277 p = buffer->pos;
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
278
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
279 if (buffer->event && p == buffer->start) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
280 ngx_add_timer(buffer->event, buffer->flush);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
281 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
282
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
283 for (i = 0; i < log[l].format->ops->nelts; i++) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
284 p = op[i].run(s, p, &op[i]);
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
285 }
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
286
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
287 ngx_linefeed(p);
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
288
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
289 buffer->pos = p;
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
290
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
291 continue;
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
292 }
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
293
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
294 if (buffer->event && buffer->event->timer_set) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
295 ngx_del_timer(buffer->event);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
296 }
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
297 }
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
298
5702
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
299 alloc_line:
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
300
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
301 line = ngx_pnalloc(s->connection->pool, len);
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
302 if (line == NULL) {
473
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 461
diff changeset
303 return NGX_ERROR;
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 461
diff changeset
304 }
8e8f3af115b5 nginx-0.1.11-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 461
diff changeset
305
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
306 p = line;
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
307
5702
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
308 if (log[l].syslog_peer) {
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
309 p = ngx_syslog_add_header(log[l].syslog_peer, line);
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
310 }
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
311
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
312 for (i = 0; i < log[l].format->ops->nelts; i++) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
313 p = op[i].run(s, p, &op[i]);
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
314 }
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
315
5702
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
316 if (log[l].syslog_peer) {
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
317
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
318 size = p - line;
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
319
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
320 n = ngx_syslog_send(log[l].syslog_peer, line, size);
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
321
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
322 if (n < 0) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
323 ngx_log_error(NGX_LOG_WARN, s->connection->log, 0,
5702
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
324 "send() to syslog failed");
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
325
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
326 } else if ((size_t) n != size) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
327 ngx_log_error(NGX_LOG_WARN, s->connection->log, 0,
5702
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
328 "send() to syslog has written only %z of %uz",
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
329 n, size);
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
330 }
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
331
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
332 continue;
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
333 }
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
334
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
335 ngx_linefeed(p);
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
336
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
337 ngx_stream_log_write(s, &log[l], line, p - line);
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
338 }
26
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
339
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
340 return NGX_OK;
53cb81681040 nginx-0.0.1-2002-12-15-09:25:09 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
341 }
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
342
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
343
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
344 static void
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
345 ngx_stream_log_write(ngx_stream_session_t *s, ngx_stream_log_t *log,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
346 u_char *buf, size_t len)
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
347 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
348 u_char *name;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
349 time_t now;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
350 ssize_t n;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
351 ngx_err_t err;
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
352 #if (NGX_ZLIB)
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
353 ngx_stream_log_buf_t *buffer;
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
354 #endif
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
355
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
356 if (log->script == NULL) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
357 name = log->file->name.data;
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
358
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
359 #if (NGX_ZLIB)
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
360 buffer = log->file->data;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
361
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
362 if (buffer && buffer->gzip) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
363 n = ngx_stream_log_gzip(log->file->fd, buf, len, buffer->gzip,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
364 s->connection->log);
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
365 } else {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
366 n = ngx_write_fd(log->file->fd, buf, len);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
367 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
368 #else
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
369 n = ngx_write_fd(log->file->fd, buf, len);
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
370 #endif
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
371
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
372 } else {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
373 name = NULL;
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
374 n = ngx_stream_log_script_write(s, log->script, &name, buf, len);
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
375 }
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
376
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
377 if (n == (ssize_t) len) {
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
378 return;
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
379 }
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
380
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
381 now = ngx_time();
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
382
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
383 if (n == -1) {
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
384 err = ngx_errno;
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
385
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
386 if (err == NGX_ENOSPC) {
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
387 log->disk_full_time = now;
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
388 }
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
389
1161
6002e0253221 use 60 seconds interval but not 61 seconds
Igor Sysoev <igor@sysoev.ru>
parents: 1074
diff changeset
390 if (now - log->error_log_time > 59) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
391 ngx_log_error(NGX_LOG_ALERT, s->connection->log, err,
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
392 ngx_write_fd_n " to \"%s\" failed", name);
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
393
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
394 log->error_log_time = now;
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
395 }
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
396
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
397 return;
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
398 }
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
399
1161
6002e0253221 use 60 seconds interval but not 61 seconds
Igor Sysoev <igor@sysoev.ru>
parents: 1074
diff changeset
400 if (now - log->error_log_time > 59) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
401 ngx_log_error(NGX_LOG_ALERT, s->connection->log, 0,
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
402 ngx_write_fd_n " to \"%s\" was incomplete: %z of %uz",
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
403 name, n, len);
1071
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
404
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
405 log->error_log_time = now;
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
406 }
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
407 }
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
408
bd4202f92581 log a failure of the writing to access_log once per minute
Igor Sysoev <igor@sysoev.ru>
parents: 905
diff changeset
409
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
410 static ssize_t
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
411 ngx_stream_log_script_write(ngx_stream_session_t *s,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
412 ngx_stream_log_script_t *script, u_char **name, u_char *buf, size_t len)
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
413 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
414 ssize_t n;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
415 ngx_str_t log;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
416 ngx_open_file_info_t of;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
417 ngx_stream_log_srv_conf_t *lscf;
4494
13e09cf11d4e Disable symlinks: initialization of the "disable_symlinks" field in
Valentin Bartenev <vbart@nginx.com>
parents: 4478
diff changeset
418
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
419 if (ngx_stream_script_run(s, &log, script->lengths->elts, 1,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
420 script->values->elts)
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
421 == NULL)
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
422 {
4499
778ef9c3fd2d Fixed spelling in single-line comments.
Ruslan Ermilov <ru@nginx.com>
parents: 4494
diff changeset
423 /* simulate successful logging */
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
424 return len;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
425 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
426
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
427 log.data[log.len - 1] = '\0';
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
428 *name = log.data;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
429
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
430 ngx_log_debug1(NGX_LOG_DEBUG_STREAM, s->connection->log, 0,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
431 "stream log \"%s\"", log.data);
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
432
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
433 lscf = ngx_stream_get_module_srv_conf(s, ngx_stream_log_module);
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
434
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
435 ngx_memzero(&of, sizeof(ngx_open_file_info_t));
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
436
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
437 of.log = 1;
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
438 of.valid = lscf->open_file_cache_valid;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
439 of.min_uses = lscf->open_file_cache_min_uses;
2277
732bf367dc08 NGX_OPEN_FILE_DIRECTIO_OFF
Igor Sysoev <igor@sysoev.ru>
parents: 2261
diff changeset
440 of.directio = NGX_OPEN_FILE_DIRECTIO_OFF;
4494
13e09cf11d4e Disable symlinks: initialization of the "disable_symlinks" field in
Valentin Bartenev <vbart@nginx.com>
parents: 4478
diff changeset
441
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
442 if (ngx_open_cached_file(lscf->open_file_cache, &log, &of,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
443 s->connection->pool)
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
444 != NGX_OK)
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
445 {
6948
3fb9b5eb75c0 Fixed ngx_open_cached_file() error handling.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6927
diff changeset
446 if (of.err == 0) {
3fb9b5eb75c0 Fixed ngx_open_cached_file() error handling.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6927
diff changeset
447 /* simulate successful logging */
3fb9b5eb75c0 Fixed ngx_open_cached_file() error handling.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6927
diff changeset
448 return len;
3fb9b5eb75c0 Fixed ngx_open_cached_file() error handling.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6927
diff changeset
449 }
3fb9b5eb75c0 Fixed ngx_open_cached_file() error handling.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6927
diff changeset
450
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
451 ngx_log_error(NGX_LOG_CRIT, s->connection->log, ngx_errno,
2756
09cab3f8d92e *) of.test_only to not open file if only stat() is enough
Igor Sysoev <igor@sysoev.ru>
parents: 2536
diff changeset
452 "%s \"%s\" failed", of.failed, log.data);
4499
778ef9c3fd2d Fixed spelling in single-line comments.
Ruslan Ermilov <ru@nginx.com>
parents: 4494
diff changeset
453 /* simulate successful logging */
2077
479440385e35 fix error message
Igor Sysoev <igor@sysoev.ru>
parents: 2072
diff changeset
454 return len;
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
455 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
456
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
457 ngx_log_debug1(NGX_LOG_DEBUG_STREAM, s->connection->log, 0,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
458 "stream log #%d", of.fd);
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
459
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
460 n = ngx_write_fd(of.fd, buf, len);
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
461
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
462 return n;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
463 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
464
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
465
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
466 #if (NGX_ZLIB)
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
467
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
468 static ssize_t
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
469 ngx_stream_log_gzip(ngx_fd_t fd, u_char *buf, size_t len, ngx_int_t level,
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
470 ngx_log_t *log)
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
471 {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
472 int rc, wbits, memlevel;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
473 u_char *out;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
474 size_t size;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
475 ssize_t n;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
476 z_stream zstream;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
477 ngx_err_t err;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
478 ngx_pool_t *pool;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
479
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
480 wbits = MAX_WBITS;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
481 memlevel = MAX_MEM_LEVEL - 1;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
482
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
483 while ((ssize_t) len < ((1 << (wbits - 1)) - 262)) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
484 wbits--;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
485 memlevel--;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
486 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
487
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
488 /*
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
489 * This is a formula from deflateBound() for conservative upper bound of
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
490 * compressed data plus 18 bytes of gzip wrapper.
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
491 */
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
492
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
493 size = len + ((len + 7) >> 3) + ((len + 63) >> 6) + 5 + 18;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
494
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
495 ngx_memzero(&zstream, sizeof(z_stream));
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
496
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
497 pool = ngx_create_pool(256, log);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
498 if (pool == NULL) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
499 /* simulate successful logging */
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
500 return len;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
501 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
502
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
503 pool->log = log;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
504
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
505 zstream.zalloc = ngx_stream_log_gzip_alloc;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
506 zstream.zfree = ngx_stream_log_gzip_free;
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
507 zstream.opaque = pool;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
508
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
509 out = ngx_pnalloc(pool, size);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
510 if (out == NULL) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
511 goto done;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
512 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
513
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
514 zstream.next_in = buf;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
515 zstream.avail_in = len;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
516 zstream.next_out = out;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
517 zstream.avail_out = size;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
518
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
519 rc = deflateInit2(&zstream, (int) level, Z_DEFLATED, wbits + 16, memlevel,
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
520 Z_DEFAULT_STRATEGY);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
521
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
522 if (rc != Z_OK) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
523 ngx_log_error(NGX_LOG_ALERT, log, 0, "deflateInit2() failed: %d", rc);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
524 goto done;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
525 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
526
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
527 ngx_log_debug4(NGX_LOG_DEBUG_STREAM, log, 0,
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
528 "deflate in: ni:%p no:%p ai:%ud ao:%ud",
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
529 zstream.next_in, zstream.next_out,
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
530 zstream.avail_in, zstream.avail_out);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
531
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
532 rc = deflate(&zstream, Z_FINISH);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
533
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
534 if (rc != Z_STREAM_END) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
535 ngx_log_error(NGX_LOG_ALERT, log, 0,
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
536 "deflate(Z_FINISH) failed: %d", rc);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
537 goto done;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
538 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
539
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
540 ngx_log_debug5(NGX_LOG_DEBUG_STREAM, log, 0,
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
541 "deflate out: ni:%p no:%p ai:%ud ao:%ud rc:%d",
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
542 zstream.next_in, zstream.next_out,
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
543 zstream.avail_in, zstream.avail_out,
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
544 rc);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
545
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
546 size -= zstream.avail_out;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
547
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
548 rc = deflateEnd(&zstream);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
549
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
550 if (rc != Z_OK) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
551 ngx_log_error(NGX_LOG_ALERT, log, 0, "deflateEnd() failed: %d", rc);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
552 goto done;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
553 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
554
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
555 n = ngx_write_fd(fd, out, size);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
556
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
557 if (n != (ssize_t) size) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
558 err = (n == -1) ? ngx_errno : 0;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
559
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
560 ngx_destroy_pool(pool);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
561
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
562 ngx_set_errno(err);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
563 return -1;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
564 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
565
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
566 done:
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
567
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
568 ngx_destroy_pool(pool);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
569
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
570 /* simulate successful logging */
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
571 return len;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
572 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
573
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
574
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
575 static void *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
576 ngx_stream_log_gzip_alloc(void *opaque, u_int items, u_int size)
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
577 {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
578 ngx_pool_t *pool = opaque;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
579
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
580 ngx_log_debug2(NGX_LOG_DEBUG_STREAM, pool->log, 0,
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
581 "gzip alloc: n:%ud s:%ud", items, size);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
582
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
583 return ngx_palloc(pool, items * size);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
584 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
585
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
586
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
587 static void
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
588 ngx_stream_log_gzip_free(void *opaque, void *address)
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
589 {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
590 #if 0
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
591 ngx_pool_t *pool = opaque;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
592
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
593 ngx_log_debug1(NGX_LOG_DEBUG_STREAM, pool->log, 0,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
594 "gzip free: %p", address);
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
595 #endif
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
596 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
597
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
598 #endif
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
599
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
600
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
601 static void
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
602 ngx_stream_log_flush(ngx_open_file_t *file, ngx_log_t *log)
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
603 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
604 size_t len;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
605 ssize_t n;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
606 ngx_stream_log_buf_t *buffer;
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
607
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
608 buffer = file->data;
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
609
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
610 len = buffer->pos - buffer->start;
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
611
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
612 if (len == 0) {
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
613 return;
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
614 }
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
615
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
616 #if (NGX_ZLIB)
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
617 if (buffer->gzip) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
618 n = ngx_stream_log_gzip(file->fd, buffer->start, len, buffer->gzip,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
619 log);
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
620 } else {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
621 n = ngx_write_fd(file->fd, buffer->start, len);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
622 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
623 #else
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
624 n = ngx_write_fd(file->fd, buffer->start, len);
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
625 #endif
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
626
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
627 if (n == -1) {
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
628 ngx_log_error(NGX_LOG_ALERT, log, ngx_errno,
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
629 ngx_write_fd_n " to \"%s\" failed",
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
630 file->name.data);
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
631
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
632 } else if ((size_t) n != len) {
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
633 ngx_log_error(NGX_LOG_ALERT, log, 0,
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
634 ngx_write_fd_n " to \"%s\" was incomplete: %z of %uz",
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
635 file->name.data, n, len);
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
636 }
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
637
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
638 buffer->pos = buffer->start;
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
639
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
640 if (buffer->event && buffer->event->timer_set) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
641 ngx_del_timer(buffer->event);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
642 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
643 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
644
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
645
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
646 static void
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
647 ngx_stream_log_flush_handler(ngx_event_t *ev)
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
648 {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
649 ngx_log_debug0(NGX_LOG_DEBUG_EVENT, ev->log, 0,
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
650 "stream log buffer flush handler");
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
651
6927
c36d160cd4e0 Access log: removed dead ev->timedout check in flush timer handler.
Maxim Dounin <mdounin@mdounin.ru>
parents: 6840
diff changeset
652 ngx_stream_log_flush(ev->data, ev->log);
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
653 }
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
654
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
655
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
656 static u_char *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
657 ngx_stream_log_copy_short(ngx_stream_session_t *s, u_char *buf,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
658 ngx_stream_log_op_t *op)
479
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
659 {
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
660 size_t len;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
661 uintptr_t data;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
662
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
663 len = op->len;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
664 data = op->data;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
665
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
666 while (len--) {
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
667 *buf++ = (u_char) (data & 0xff);
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
668 data >>= 8;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
669 }
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
670
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
671 return buf;
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
672 }
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
673
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
674
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
675 static u_char *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
676 ngx_stream_log_copy_long(ngx_stream_session_t *s, u_char *buf,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
677 ngx_stream_log_op_t *op)
479
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
678 {
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
679 return ngx_cpymem(buf, (u_char *) op->data, op->len);
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
680 }
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
681
c52408583801 nginx-0.1.14-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 477
diff changeset
682
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
683 static ngx_int_t
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
684 ngx_stream_log_variable_compile(ngx_conf_t *cf, ngx_stream_log_op_t *op,
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
685 ngx_str_t *value, ngx_uint_t json)
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
686 {
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
687 ngx_int_t index;
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
688
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
689 index = ngx_stream_get_variable_index(cf, value);
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
690 if (index == NGX_ERROR) {
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
691 return NGX_ERROR;
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
692 }
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
693
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
694 op->len = 0;
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
695
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
696 if (json) {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
697 op->getlen = ngx_stream_log_json_variable_getlen;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
698 op->run = ngx_stream_log_json_variable;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
699
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
700 } else {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
701 op->getlen = ngx_stream_log_variable_getlen;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
702 op->run = ngx_stream_log_variable;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
703 }
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
704
509
9b8c906f6e63 nginx-0.1.29-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 505
diff changeset
705 op->data = index;
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
706
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
707 return NGX_OK;
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
708 }
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
709
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
710
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
711 static size_t
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
712 ngx_stream_log_variable_getlen(ngx_stream_session_t *s, uintptr_t data)
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
713 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
714 uintptr_t len;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
715 ngx_stream_variable_value_t *value;
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
716
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
717 value = ngx_stream_get_indexed_variable(s, data);
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
718
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
719 if (value == NULL || value->not_found) {
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
720 return 1;
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
721 }
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
722
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
723 len = ngx_stream_log_escape(NULL, value->data, value->len);
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
724
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
725 value->escape = len ? 1 : 0;
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
726
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
727 return value->len + len * 3;
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
728 }
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
729
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
730
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
731 static u_char *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
732 ngx_stream_log_variable(ngx_stream_session_t *s, u_char *buf,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
733 ngx_stream_log_op_t *op)
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
734 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
735 ngx_stream_variable_value_t *value;
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
736
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
737 value = ngx_stream_get_indexed_variable(s, op->data);
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
738
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
739 if (value == NULL || value->not_found) {
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
740 *buf = '-';
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
741 return buf + 1;
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
742 }
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
743
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
744 if (value->escape == 0) {
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
745 return ngx_cpymem(buf, value->data, value->len);
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
746
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
747 } else {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
748 return (u_char *) ngx_stream_log_escape(buf, value->data, value->len);
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
749 }
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
750 }
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
751
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
752
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
753 static uintptr_t
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
754 ngx_stream_log_escape(u_char *dst, u_char *src, size_t size)
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
755 {
3275
b344b68da8c5 optimize some cycles:
Igor Sysoev <igor@sysoev.ru>
parents: 3115
diff changeset
756 ngx_uint_t n;
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
757 static u_char hex[] = "0123456789ABCDEF";
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
758
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
759 static uint32_t escape[] = {
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
760 0xffffffff, /* 1111 1111 1111 1111 1111 1111 1111 1111 */
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
761
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
762 /* ?>=< ;:98 7654 3210 /.-, +*)( '&%$ #"! */
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
763 0x00000004, /* 0000 0000 0000 0000 0000 0000 0000 0100 */
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
764
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
765 /* _^]\ [ZYX WVUT SRQP ONML KJIH GFED CBA@ */
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
766 0x10000000, /* 0001 0000 0000 0000 0000 0000 0000 0000 */
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
767
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
768 /* ~}| {zyx wvut srqp onml kjih gfed cba` */
4191
08d8af70760c Improved access log escaping to better protect other software.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4133
diff changeset
769 0x80000000, /* 1000 0000 0000 0000 0000 0000 0000 0000 */
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
770
4191
08d8af70760c Improved access log escaping to better protect other software.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4133
diff changeset
771 0xffffffff, /* 1111 1111 1111 1111 1111 1111 1111 1111 */
08d8af70760c Improved access log escaping to better protect other software.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4133
diff changeset
772 0xffffffff, /* 1111 1111 1111 1111 1111 1111 1111 1111 */
08d8af70760c Improved access log escaping to better protect other software.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4133
diff changeset
773 0xffffffff, /* 1111 1111 1111 1111 1111 1111 1111 1111 */
08d8af70760c Improved access log escaping to better protect other software.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4133
diff changeset
774 0xffffffff, /* 1111 1111 1111 1111 1111 1111 1111 1111 */
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
775 };
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
776
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
777
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
778 if (dst == NULL) {
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
779
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
780 /* find the number of the characters to be escaped */
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
781
3115
204ea173234f style fix
Igor Sysoev <igor@sysoev.ru>
parents: 3038
diff changeset
782 n = 0;
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
783
3275
b344b68da8c5 optimize some cycles:
Igor Sysoev <igor@sysoev.ru>
parents: 3115
diff changeset
784 while (size) {
6626
b3682580c1bd Avoid left-shifting integers into the sign bit, which is undefined.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5927
diff changeset
785 if (escape[*src >> 5] & (1U << (*src & 0x1f))) {
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
786 n++;
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
787 }
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
788 src++;
3275
b344b68da8c5 optimize some cycles:
Igor Sysoev <igor@sysoev.ru>
parents: 3115
diff changeset
789 size--;
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
790 }
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
791
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
792 return (uintptr_t) n;
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
793 }
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
794
3275
b344b68da8c5 optimize some cycles:
Igor Sysoev <igor@sysoev.ru>
parents: 3115
diff changeset
795 while (size) {
6626
b3682580c1bd Avoid left-shifting integers into the sign bit, which is undefined.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5927
diff changeset
796 if (escape[*src >> 5] & (1U << (*src & 0x1f))) {
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
797 *dst++ = '\\';
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
798 *dst++ = 'x';
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
799 *dst++ = hex[*src >> 4];
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
800 *dst++ = hex[*src & 0xf];
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
801 src++;
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
802
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
803 } else {
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
804 *dst++ = *src++;
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
805 }
3275
b344b68da8c5 optimize some cycles:
Igor Sysoev <igor@sysoev.ru>
parents: 3115
diff changeset
806 size--;
2008
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
807 }
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
808
66dc85397a90 escape 0x00-0x1f, ", and \ in access log variables
Igor Sysoev <igor@sysoev.ru>
parents: 1640
diff changeset
809 return (uintptr_t) dst;
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
810 }
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
811
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
812
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
813 static size_t
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
814 ngx_stream_log_json_variable_getlen(ngx_stream_session_t *s, uintptr_t data)
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
815 {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
816 uintptr_t len;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
817 ngx_stream_variable_value_t *value;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
818
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
819 value = ngx_stream_get_indexed_variable(s, data);
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
820
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
821 if (value == NULL || value->not_found) {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
822 return 0;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
823 }
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
824
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
825 len = ngx_escape_json(NULL, value->data, value->len);
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
826
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
827 value->escape = len ? 1 : 0;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
828
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
829 return value->len + len;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
830 }
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
831
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
832
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
833 static u_char *
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
834 ngx_stream_log_json_variable(ngx_stream_session_t *s, u_char *buf,
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
835 ngx_stream_log_op_t *op)
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
836 {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
837 ngx_stream_variable_value_t *value;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
838
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
839 value = ngx_stream_get_indexed_variable(s, op->data);
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
841 if (value == NULL || value->not_found) {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
842 return buf;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
843 }
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
844
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
845 if (value->escape == 0) {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
846 return ngx_cpymem(buf, value->data, value->len);
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
847
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
848 } else {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
849 return (u_char *) ngx_escape_json(buf, value->data, value->len);
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
850 }
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
851 }
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
852
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
853
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
854 static void *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
855 ngx_stream_log_create_main_conf(ngx_conf_t *cf)
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
856 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
857 ngx_stream_log_main_conf_t *conf;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
858
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
859 conf = ngx_pcalloc(cf->pool, sizeof(ngx_stream_log_main_conf_t));
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
860 if (conf == NULL) {
2912
c7d57b539248 return NULL instead of NGX_CONF_ERROR on a create conf failure
Igor Sysoev <igor@sysoev.ru>
parents: 2756
diff changeset
861 return NULL;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
862 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
863
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
864 if (ngx_array_init(&conf->formats, cf->pool, 4,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
865 sizeof(ngx_stream_log_fmt_t))
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
866 != NGX_OK)
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
867 {
2912
c7d57b539248 return NULL instead of NGX_CONF_ERROR on a create conf failure
Igor Sysoev <igor@sysoev.ru>
parents: 2756
diff changeset
868 return NULL;
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
869 }
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
870
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
871 return conf;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
872 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
873
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
874
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
875 static void *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
876 ngx_stream_log_create_srv_conf(ngx_conf_t *cf)
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
877 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
878 ngx_stream_log_srv_conf_t *conf;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
879
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
880 conf = ngx_pcalloc(cf->pool, sizeof(ngx_stream_log_srv_conf_t));
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
881 if (conf == NULL) {
2912
c7d57b539248 return NULL instead of NGX_CONF_ERROR on a create conf failure
Igor Sysoev <igor@sysoev.ru>
parents: 2756
diff changeset
882 return NULL;
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
883 }
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
884
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
885 conf->open_file_cache = NGX_CONF_UNSET_PTR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
886
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
887 return conf;
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
888 }
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
889
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
890
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
891 static char *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
892 ngx_stream_log_merge_srv_conf(ngx_conf_t *cf, void *parent, void *child)
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
893 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
894 ngx_stream_log_srv_conf_t *prev = parent;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
895 ngx_stream_log_srv_conf_t *conf = child;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
896
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
897 if (conf->open_file_cache == NGX_CONF_UNSET_PTR) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
898
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
899 conf->open_file_cache = prev->open_file_cache;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
900 conf->open_file_cache_valid = prev->open_file_cache_valid;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
901 conf->open_file_cache_min_uses = prev->open_file_cache_min_uses;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
902
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
903 if (conf->open_file_cache == NGX_CONF_UNSET_PTR) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
904 conf->open_file_cache = NULL;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
905 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
906 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
907
1074
8164f479b362 fix "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 1071
diff changeset
908 if (conf->logs || conf->off) {
8164f479b362 fix "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 1071
diff changeset
909 return NGX_CONF_OK;
8164f479b362 fix "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 1071
diff changeset
910 }
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
911
2078
9acbc5e7bcbd fix variable access_log merging
Igor Sysoev <igor@sysoev.ru>
parents: 2077
diff changeset
912 conf->logs = prev->logs;
9acbc5e7bcbd fix variable access_log merging
Igor Sysoev <igor@sysoev.ru>
parents: 2077
diff changeset
913 conf->off = prev->off;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
914
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
915 return NGX_CONF_OK;
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
916 }
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
917
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
918
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
919 static char *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
920 ngx_stream_log_set_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
921 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
922 ngx_stream_log_srv_conf_t *lscf = conf;
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
923
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
924 ssize_t size;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
925 ngx_int_t gzip;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
926 ngx_uint_t i, n;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
927 ngx_msec_t flush;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
928 ngx_str_t *value, name, s;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
929 ngx_stream_log_t *log;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
930 ngx_syslog_peer_t *peer;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
931 ngx_stream_log_buf_t *buffer;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
932 ngx_stream_log_fmt_t *fmt;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
933 ngx_stream_script_compile_t sc;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
934 ngx_stream_log_main_conf_t *lmcf;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
935 ngx_stream_compile_complex_value_t ccv;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
936
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
937 value = cf->args->elts;
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
938
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
939 if (ngx_strcmp(value[1].data, "off") == 0) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
940 lscf->off = 1;
3038
cd8738e76610 strict testing "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 2912
diff changeset
941 if (cf->args->nelts == 2) {
cd8738e76610 strict testing "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 2912
diff changeset
942 return NGX_CONF_OK;
cd8738e76610 strict testing "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 2912
diff changeset
943 }
cd8738e76610 strict testing "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 2912
diff changeset
944
cd8738e76610 strict testing "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 2912
diff changeset
945 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
cd8738e76610 strict testing "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 2912
diff changeset
946 "invalid parameter \"%V\"", &value[2]);
cd8738e76610 strict testing "access_log off"
Igor Sysoev <igor@sysoev.ru>
parents: 2912
diff changeset
947 return NGX_CONF_ERROR;
427
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
948 }
0d08eabe5c7b nginx-0.0.10-2004-09-15-20:00:43 import
Igor Sysoev <igor@sysoev.ru>
parents: 415
diff changeset
949
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
950 if (lscf->logs == NULL) {
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
951 lscf->logs = ngx_array_create(cf->pool, 2, sizeof(ngx_stream_log_t));
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
952 if (lscf->logs == NULL) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
953 return NGX_CONF_ERROR;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
954 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
955 }
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
956
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
957 lmcf = ngx_stream_conf_get_module_main_conf(cf, ngx_stream_log_module);
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
958
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
959 log = ngx_array_push(lscf->logs);
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
960 if (log == NULL) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
961 return NGX_CONF_ERROR;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
962 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
963
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
964 ngx_memzero(log, sizeof(ngx_stream_log_t));
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
965
5702
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
966
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
967 if (ngx_strncmp(value[1].data, "syslog:", 7) == 0) {
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
968
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
969 peer = ngx_pcalloc(cf->pool, sizeof(ngx_syslog_peer_t));
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
970 if (peer == NULL) {
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
971 return NGX_CONF_ERROR;
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
972 }
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
973
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
974 if (ngx_syslog_process_conf(cf, peer) != NGX_CONF_OK) {
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
975 return NGX_CONF_ERROR;
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
976 }
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
977
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
978 log->syslog_peer = peer;
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
979
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
980 goto process_formats;
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
981 }
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
982
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
983 n = ngx_stream_script_variables_count(&value[1]);
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
984
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
985 if (n == 0) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
986 log->file = ngx_conf_open_file(cf->cycle, &value[1]);
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
987 if (log->file == NULL) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
988 return NGX_CONF_ERROR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
989 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
990
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
991 } else {
5330
314c3d7cc3a5 Backed out f1a91825730a and 7094bd12c1ff.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5317
diff changeset
992 if (ngx_conf_full_name(cf->cycle, &value[1], 0) != NGX_OK) {
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
993 return NGX_CONF_ERROR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
994 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
995
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
996 log->script = ngx_pcalloc(cf->pool, sizeof(ngx_stream_log_script_t));
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
997 if (log->script == NULL) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
998 return NGX_CONF_ERROR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
999 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1000
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1001 ngx_memzero(&sc, sizeof(ngx_stream_script_compile_t));
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1002
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1003 sc.cf = cf;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1004 sc.source = &value[1];
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1005 sc.lengths = &log->script->lengths;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1006 sc.values = &log->script->values;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1007 sc.variables = n;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1008 sc.complete_lengths = 1;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1009 sc.complete_values = 1;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1010
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1011 if (ngx_stream_script_compile(&sc) != NGX_OK) {
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1012 return NGX_CONF_ERROR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1013 }
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1014 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1015
5702
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
1016 process_formats:
777202558122 Added syslog support for error_log and access_log directives.
Vladimir Homutov <vl@nginx.com>
parents: 5653
diff changeset
1017
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1018 if (cf->args->nelts >= 3) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1019 name = value[2];
581
326634fb9d47 nginx-0.3.12-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1020
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1021 } else {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1022 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1023 "log format is not specified");
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1024 return NGX_CONF_ERROR;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1025 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1026
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1027 fmt = lmcf->formats.elts;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1028 for (i = 0; i < lmcf->formats.nelts; i++) {
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1029 if (fmt[i].name.len == name.len
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1030 && ngx_strcasecmp(fmt[i].name.data, name.data) == 0)
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1031 {
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1032 log->format = &fmt[i];
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1033 break;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1034 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1035 }
100
7ebc8b7fb816 nginx-0.0.1-2003-06-03-19:42:58 import
Igor Sysoev <igor@sysoev.ru>
parents: 99
diff changeset
1036
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1037 if (log->format == NULL) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1038 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1039 "unknown log format \"%V\"", &name);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1040 return NGX_CONF_ERROR;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1041 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1042
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1043 size = 0;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1044 flush = 0;
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1045 gzip = 0;
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1046
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1047 for (i = 3; i < cf->args->nelts; i++) {
487
31ff3e943e16 nginx-0.1.18-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 485
diff changeset
1048
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1049 if (ngx_strncmp(value[i].data, "buffer=", 7) == 0) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1050 s.len = value[i].len - 7;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1051 s.data = value[i].data + 7;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1052
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1053 size = ngx_parse_size(&s);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1054
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1055 if (size == NGX_ERROR || size == 0) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1056 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1057 "invalid buffer size \"%V\"", &s);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1058 return NGX_CONF_ERROR;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1059 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1060
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1061 continue;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1062 }
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1063
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1064 if (ngx_strncmp(value[i].data, "flush=", 6) == 0) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1065 s.len = value[i].len - 6;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1066 s.data = value[i].data + 6;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1067
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1068 flush = ngx_parse_time(&s, 0);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1069
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1070 if (flush == (ngx_msec_t) NGX_ERROR || flush == 0) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1071 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1072 "invalid flush time \"%V\"", &s);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1073 return NGX_CONF_ERROR;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1074 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1075
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1076 continue;
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1077 }
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1078
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1079 if (ngx_strncmp(value[i].data, "gzip", 4) == 0
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1080 && (value[i].len == 4 || value[i].data[4] == '='))
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1081 {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1082 #if (NGX_ZLIB)
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1083 if (size == 0) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1084 size = 64 * 1024;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1085 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1086
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1087 if (value[i].len == 4) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1088 gzip = Z_BEST_SPEED;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1089 continue;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1090 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1091
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1092 s.len = value[i].len - 5;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1093 s.data = value[i].data + 5;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1094
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1095 gzip = ngx_atoi(s.data, s.len);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1096
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1097 if (gzip < 1 || gzip > 9) {
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1098 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1099 "invalid compression level \"%V\"", &s);
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1100 return NGX_CONF_ERROR;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1101 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1102
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1103 continue;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1104
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1105 #else
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1106 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1107 "nginx was built without zlib support");
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1108 return NGX_CONF_ERROR;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1109 #endif
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1110 }
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1111
5653
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
1112 if (ngx_strncmp(value[i].data, "if=", 3) == 0) {
5833
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1113 s.len = value[i].len - 3;
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1114 s.data = value[i].data + 3;
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1115
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1116 ngx_memzero(&ccv, sizeof(ngx_stream_compile_complex_value_t));
5833
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1117
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1118 ccv.cf = cf;
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1119 ccv.value = &s;
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1120 ccv.complex_value = ngx_palloc(cf->pool,
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1121 sizeof(ngx_stream_complex_value_t));
5833
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1122 if (ccv.complex_value == NULL) {
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1123 return NGX_CONF_ERROR;
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1124 }
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1125
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1126 if (ngx_stream_compile_complex_value(&ccv) != NGX_OK) {
5833
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1127 return NGX_CONF_ERROR;
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1128 }
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1129
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1130 log->filter = ccv.complex_value;
e3016ee8dba3 Access log: fixed the "if=" parameter with buffering (ticket #625).
Valentin Bartenev <vbart@nginx.com>
parents: 5799
diff changeset
1131
5653
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
1132 continue;
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
1133 }
cb308813b453 Access log: the "if" parameter of the "access_log" directive.
Sergey Kandaurov <pluknet@nginx.com>
parents: 5361
diff changeset
1134
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1135 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1136 "invalid parameter \"%V\"", &value[i]);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1137 return NGX_CONF_ERROR;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1138 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1139
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1140 if (flush && size == 0) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1141 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1142 "no buffer is defined for access_log \"%V\"",
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1143 &value[1]);
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1144 return NGX_CONF_ERROR;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1145 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1146
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1147 if (size) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1148
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1149 if (log->script) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1150 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
4133
59b99f217c6d Replaced "can not" with "cannot" and "could not" in a bunch of places.
Ruslan Ermilov <ru@nginx.com>
parents: 3991
diff changeset
1151 "buffered logs cannot have variables in name");
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1152 return NGX_CONF_ERROR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1153 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1154
5799
b1f8285297a7 Access log: allowed logs to syslog with "if=" (ticket #596).
Maxim Dounin <mdounin@mdounin.ru>
parents: 5719
diff changeset
1155 if (log->syslog_peer) {
b1f8285297a7 Access log: allowed logs to syslog with "if=" (ticket #596).
Maxim Dounin <mdounin@mdounin.ru>
parents: 5719
diff changeset
1156 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
b1f8285297a7 Access log: allowed logs to syslog with "if=" (ticket #596).
Maxim Dounin <mdounin@mdounin.ru>
parents: 5719
diff changeset
1157 "logs to syslog cannot be buffered");
b1f8285297a7 Access log: allowed logs to syslog with "if=" (ticket #596).
Maxim Dounin <mdounin@mdounin.ru>
parents: 5719
diff changeset
1158 return NGX_CONF_ERROR;
b1f8285297a7 Access log: allowed logs to syslog with "if=" (ticket #596).
Maxim Dounin <mdounin@mdounin.ru>
parents: 5719
diff changeset
1159 }
b1f8285297a7 Access log: allowed logs to syslog with "if=" (ticket #596).
Maxim Dounin <mdounin@mdounin.ru>
parents: 5719
diff changeset
1160
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1161 if (log->file->data) {
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1162 buffer = log->file->data;
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1163
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1164 if (buffer->last - buffer->start != size
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1165 || buffer->flush != flush
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1166 || buffer->gzip != gzip)
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1167 {
4984
7737f0d788c1 Access log: fixed redundant buffer reallocation.
Valentin Bartenev <vbart@nginx.com>
parents: 4893
diff changeset
1168 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
7737f0d788c1 Access log: fixed redundant buffer reallocation.
Valentin Bartenev <vbart@nginx.com>
parents: 4893
diff changeset
1169 "access_log \"%V\" already defined "
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1170 "with conflicting parameters",
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1171 &value[1]);
4984
7737f0d788c1 Access log: fixed redundant buffer reallocation.
Valentin Bartenev <vbart@nginx.com>
parents: 4893
diff changeset
1172 return NGX_CONF_ERROR;
7737f0d788c1 Access log: fixed redundant buffer reallocation.
Valentin Bartenev <vbart@nginx.com>
parents: 4893
diff changeset
1173 }
7737f0d788c1 Access log: fixed redundant buffer reallocation.
Valentin Bartenev <vbart@nginx.com>
parents: 4893
diff changeset
1174
7737f0d788c1 Access log: fixed redundant buffer reallocation.
Valentin Bartenev <vbart@nginx.com>
parents: 4893
diff changeset
1175 return NGX_CONF_OK;
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1176 }
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1177
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1178 buffer = ngx_pcalloc(cf->pool, sizeof(ngx_stream_log_buf_t));
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1179 if (buffer == NULL) {
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1180 return NGX_CONF_ERROR;
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1181 }
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1182
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1183 buffer->start = ngx_pnalloc(cf->pool, size);
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1184 if (buffer->start == NULL) {
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1185 return NGX_CONF_ERROR;
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1186 }
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1187
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1188 buffer->pos = buffer->start;
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1189 buffer->last = buffer->start + size;
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1190
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1191 if (flush) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1192 buffer->event = ngx_pcalloc(cf->pool, sizeof(ngx_event_t));
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1193 if (buffer->event == NULL) {
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1194 return NGX_CONF_ERROR;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1195 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1196
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1197 buffer->event->data = log->file;
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1198 buffer->event->handler = ngx_stream_log_flush_handler;
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1199 buffer->event->log = &cf->cycle->new_log;
5897
dff86e2246a5 Access log: cancel the flush timer on graceful shutdown.
Valentin Bartenev <vbart@nginx.com>
parents: 5833
diff changeset
1200 buffer->event->cancelable = 1;
4986
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1201
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1202 buffer->flush = flush;
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1203 }
3efc49b156d9 Access log: the "flush" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4985
diff changeset
1204
4988
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1205 buffer->gzip = gzip;
3849bb380605 Access log: the "gzip" parameter of the "access_log" directive.
Valentin Bartenev <vbart@nginx.com>
parents: 4986
diff changeset
1206
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1207 log->file->flush = ngx_stream_log_flush;
4985
a0599b56e748 Reopening log files code moved to a separate function.
Valentin Bartenev <vbart@nginx.com>
parents: 4984
diff changeset
1208 log->file->data = buffer;
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1209 }
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1210
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 569
diff changeset
1211 return NGX_CONF_OK;
99
a059e1aa65d4 nginx-0.0.1-2003-06-02-19:24:30 import
Igor Sysoev <igor@sysoev.ru>
parents: 69
diff changeset
1212 }
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1213
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1214
497
d7c90bb5ce83 nginx-0.1.23-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 493
diff changeset
1215 static char *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1216 ngx_stream_log_set_format(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1217 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1218 ngx_stream_log_main_conf_t *lmcf = conf;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1219
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1220 ngx_str_t *value;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1221 ngx_uint_t i;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1222 ngx_stream_log_fmt_t *fmt;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1223
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1224 value = cf->args->elts;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1225
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1226 fmt = lmcf->formats.elts;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1227 for (i = 0; i < lmcf->formats.nelts; i++) {
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1228 if (fmt[i].name.len == value[1].len
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1229 && ngx_strcmp(fmt[i].name.data, value[1].data) == 0)
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1230 {
2036
1c009c5a163b fix error log message
Igor Sysoev <igor@sysoev.ru>
parents: 2008
diff changeset
1231 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
1c009c5a163b fix error log message
Igor Sysoev <igor@sysoev.ru>
parents: 2008
diff changeset
1232 "duplicate \"log_format\" name \"%V\"",
1c009c5a163b fix error log message
Igor Sysoev <igor@sysoev.ru>
parents: 2008
diff changeset
1233 &value[1]);
1c009c5a163b fix error log message
Igor Sysoev <igor@sysoev.ru>
parents: 2008
diff changeset
1234 return NGX_CONF_ERROR;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1235 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1236 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1237
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1238 fmt = ngx_array_push(&lmcf->formats);
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1239 if (fmt == NULL) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1240 return NGX_CONF_ERROR;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1241 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1242
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1243 fmt->name = value[1];
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1244
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1245 fmt->flushes = ngx_array_create(cf->pool, 4, sizeof(ngx_int_t));
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1246 if (fmt->flushes == NULL) {
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1247 return NGX_CONF_ERROR;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1248 }
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1249
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1250 fmt->ops = ngx_array_create(cf->pool, 16, sizeof(ngx_stream_log_op_t));
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1251 if (fmt->ops == NULL) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1252 return NGX_CONF_ERROR;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1253 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1254
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1255 return ngx_stream_log_compile_format(cf, fmt->flushes, fmt->ops,
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1256 cf->args, 2);
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1257 }
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1258
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1259
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1260 static char *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1261 ngx_stream_log_compile_format(ngx_conf_t *cf, ngx_array_t *flushes,
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1262 ngx_array_t *ops, ngx_array_t *args, ngx_uint_t s)
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1263 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1264 u_char *data, *p, ch;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1265 size_t i, len;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1266 ngx_str_t *value, var;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1267 ngx_int_t *flush;
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1268 ngx_uint_t bracket, json;
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1269 ngx_stream_log_op_t *op;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1270
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1271 json = 0;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1272 value = args->elts;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1273
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1274 if (s < args->nelts && ngx_strncmp(value[s].data, "escape=", 7) == 0) {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1275 data = value[s].data + 7;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1276
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1277 if (ngx_strcmp(data, "json") == 0) {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1278 json = 1;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1279
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1280 } else if (ngx_strcmp(data, "default") != 0) {
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1281 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1282 "unknown log format escaping \"%s\"", data);
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1283 return NGX_CONF_ERROR;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1284 }
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1285
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1286 s++;
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1287 }
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1288
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1289 for ( /* void */ ; s < args->nelts; s++) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1290
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1291 i = 0;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1292
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1293 while (i < value[s].len) {
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1294
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1295 op = ngx_array_push(ops);
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 499
diff changeset
1296 if (op == NULL) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1297 return NGX_CONF_ERROR;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1298 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1299
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1300 data = &value[s].data[i];
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1301
880
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1302 if (value[s].data[i] == '$') {
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1303
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1304 if (++i == value[s].len) {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1305 goto invalid;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1306 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1307
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1308 if (value[s].data[i] == '{') {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1309 bracket = 1;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1310
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1311 if (++i == value[s].len) {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1312 goto invalid;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1313 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1314
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1315 var.data = &value[s].data[i];
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1316
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1317 } else {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1318 bracket = 0;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1319 var.data = &value[s].data[i];
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1320 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1321
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1322 for (var.len = 0; i < value[s].len; i++, var.len++) {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1323 ch = value[s].data[i];
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1324
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1325 if (ch == '}' && bracket) {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1326 i++;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1327 bracket = 0;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1328 break;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1329 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1330
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1331 if ((ch >= 'A' && ch <= 'Z')
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1332 || (ch >= 'a' && ch <= 'z')
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1333 || (ch >= '0' && ch <= '9')
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1334 || ch == '_')
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1335 {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1336 continue;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1337 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1338
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1339 break;
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1340 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1341
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1342 if (bracket) {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1343 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1344 "the closing bracket in \"%V\" "
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1345 "variable is missing", &var);
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1346 return NGX_CONF_ERROR;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1347 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1348
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1349 if (var.len == 0) {
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1350 goto invalid;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1351 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1352
6840
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1353 if (ngx_stream_log_variable_compile(cf, op, &var, json)
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1354 != NGX_OK)
0cf4e82e7c48 Access log: support for json escaping.
Valentin Bartenev <vbart@nginx.com>
parents: 6693
diff changeset
1355 {
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1356 return NGX_CONF_ERROR;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1357 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1358
2261
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1359 if (flushes) {
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1360
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1361 flush = ngx_array_push(flushes);
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1362 if (flush == NULL) {
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1363 return NGX_CONF_ERROR;
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1364 }
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1365
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1366 *flush = op->data; /* variable index */
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1367 }
07bf557a2e40 *) log_subrequest
Igor Sysoev <igor@sysoev.ru>
parents: 2247
diff changeset
1368
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1369 continue;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1370 }
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1371
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1372 i++;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1373
880
3b763d36e055 axe old % log format
Igor Sysoev <igor@sysoev.ru>
parents: 667
diff changeset
1374 while (i < value[s].len && value[s].data[i] != '$') {
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1375 i++;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1376 }
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1377
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1378 len = &value[s].data[i] - data;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1379
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1380 if (len) {
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1381
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1382 op->len = len;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1383 op->getlen = NULL;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1384
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1385 if (len <= sizeof(uintptr_t)) {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1386 op->run = ngx_stream_log_copy_short;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1387 op->data = 0;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1388
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1389 while (len--) {
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1390 op->data <<= 8;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1391 op->data |= data[len];
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1392 }
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1393
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1394 } else {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1395 op->run = ngx_stream_log_copy_long;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1396
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 2036
diff changeset
1397 p = ngx_pnalloc(cf->pool, len);
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1398 if (p == NULL) {
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1399 return NGX_CONF_ERROR;
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1400 }
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1401
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1402 ngx_memcpy(p, data, len);
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1403 op->data = (uintptr_t) p;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1404 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1405 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1406 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1407 }
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1408
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1409 return NGX_CONF_OK;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1410
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1411 invalid:
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1412
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1413 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0, "invalid parameter \"%s\"", data);
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1414
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1415 return NGX_CONF_ERROR;
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1416 }
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1417
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1418
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1419 static char *
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1420 ngx_stream_log_open_file_cache(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1421 {
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1422 ngx_stream_log_srv_conf_t *lscf = conf;
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1423
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1424 time_t inactive, valid;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1425 ngx_str_t *value, s;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1426 ngx_int_t max, min_uses;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1427 ngx_uint_t i;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1428
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1429 if (lscf->open_file_cache != NGX_CONF_UNSET_PTR) {
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1430 return "is duplicate";
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1431 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1432
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1433 value = cf->args->elts;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1434
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1435 max = 0;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1436 inactive = 10;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1437 valid = 60;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1438 min_uses = 1;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1439
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1440 for (i = 1; i < cf->args->nelts; i++) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1441
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1442 if (ngx_strncmp(value[i].data, "max=", 4) == 0) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1443
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1444 max = ngx_atoi(value[i].data + 4, value[i].len - 4);
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1445 if (max == NGX_ERROR) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1446 goto failed;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1447 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1448
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1449 continue;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1450 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1451
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1452 if (ngx_strncmp(value[i].data, "inactive=", 9) == 0) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1453
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1454 s.len = value[i].len - 9;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1455 s.data = value[i].data + 9;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1456
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1457 inactive = ngx_parse_time(&s, 1);
4474
41f640a693de Time parsing cleanup.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
1458 if (inactive == (time_t) NGX_ERROR) {
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1459 goto failed;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1460 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1461
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1462 continue;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1463 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1464
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1465 if (ngx_strncmp(value[i].data, "min_uses=", 9) == 0) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1466
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1467 min_uses = ngx_atoi(value[i].data + 9, value[i].len - 9);
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1468 if (min_uses == NGX_ERROR) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1469 goto failed;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1470 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1471
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1472 continue;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1473 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1474
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1475 if (ngx_strncmp(value[i].data, "valid=", 6) == 0) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1476
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1477 s.len = value[i].len - 6;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1478 s.data = value[i].data + 6;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1479
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1480 valid = ngx_parse_time(&s, 1);
4474
41f640a693de Time parsing cleanup.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
1481 if (valid == (time_t) NGX_ERROR) {
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1482 goto failed;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1483 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1484
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1485 continue;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1486 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1487
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1488 if (ngx_strcmp(value[i].data, "off") == 0) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1489
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1490 lscf->open_file_cache = NULL;
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1491
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1492 continue;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1493 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1494
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1495 failed:
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1496
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1497 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1498 "invalid \"open_log_file_cache\" parameter \"%V\"",
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1499 &value[i]);
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1500 return NGX_CONF_ERROR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1501 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1502
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1503 if (lscf->open_file_cache == NULL) {
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1504 return NGX_CONF_OK;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1505 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1506
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1507 if (max == 0) {
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1508 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1509 "\"open_log_file_cache\" must have \"max\" parameter");
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1510 return NGX_CONF_ERROR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1511 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1512
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1513 lscf->open_file_cache = ngx_open_file_cache_init(cf->pool, max, inactive);
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1514
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1515 if (lscf->open_file_cache) {
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1516
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1517 lscf->open_file_cache_valid = valid;
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1518 lscf->open_file_cache_min_uses = min_uses;
2072
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1519
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1520 return NGX_CONF_OK;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1521 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1522
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1523 return NGX_CONF_ERROR;
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1524 }
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1525
ee2fecdfdef7 variables in access_log
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
1526
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1527 static ngx_int_t
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1528 ngx_stream_log_init(ngx_conf_t *cf)
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1529 {
6693
3908156a51fa Stream: phases.
Roman Arutyunyan <arut@nginx.com>
parents: 6678
diff changeset
1530 ngx_stream_handler_pt *h;
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1531 ngx_stream_core_main_conf_t *cmcf;
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1532
6678
0125b151c9a5 Stream: log module.
Vladimir Homutov <vl@nginx.com>
parents: 6626
diff changeset
1533 cmcf = ngx_stream_conf_get_module_main_conf(cf, ngx_stream_core_module);
573
58475592100c nginx-0.3.8-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1534
6693
3908156a51fa Stream: phases.
Roman Arutyunyan <arut@nginx.com>
parents: 6678
diff changeset
1535 h = ngx_array_push(&cmcf->phases[NGX_STREAM_LOG_PHASE].handlers);
3908156a51fa Stream: phases.
Roman Arutyunyan <arut@nginx.com>
parents: 6678
diff changeset
1536 if (h == NULL) {
3908156a51fa Stream: phases.
Roman Arutyunyan <arut@nginx.com>
parents: 6678
diff changeset
1537 return NGX_ERROR;
3908156a51fa Stream: phases.
Roman Arutyunyan <arut@nginx.com>
parents: 6678
diff changeset
1538 }
3908156a51fa Stream: phases.
Roman Arutyunyan <arut@nginx.com>
parents: 6678
diff changeset
1539
3908156a51fa Stream: phases.
Roman Arutyunyan <arut@nginx.com>
parents: 6678
diff changeset
1540 *h = ngx_stream_log_handler;
569
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1541
174f1e853e1e nginx-0.3.6-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 563
diff changeset
1542 return NGX_OK;
176
c0552e5ab567 nginx-0.0.1-2003-11-09-23:03:38 import; separate building
Igor Sysoev <igor@sysoev.ru>
parents: 119
diff changeset
1543 }