annotate src/mail/ngx_mail_proxy_module.c @ 5923:2c10db908b8c

SPDY: push pending data while closing a stream as with keepalive. This helps to avoid delays in sending the last chunk of data because of bad interaction between Nagle's algorithm on nginx side and delayed ACK on the client side. Delays could also be caused by TCP_CORK/TCP_NOPUSH if SPDY was working without SSL and sendfile() was used.
author Valentin Bartenev <vbart@nginx.com>
date Fri, 21 Nov 2014 22:51:49 +0300
parents bb3dc21c89ef
children bf1655ae9a1c
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: 426
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: 426
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: 4273
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: 426
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: 426
diff changeset
6
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
7
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
10 #include <ngx_event.h>
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
11 #include <ngx_event_connect.h>
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
12 #include <ngx_mail.h>
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
13
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
14
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
15 typedef struct {
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
16 ngx_flag_t enable;
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
17 ngx_flag_t pass_error_message;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
18 ngx_flag_t xclient;
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
19 size_t buffer_size;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
20 ngx_msec_t timeout;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
21 } ngx_mail_proxy_conf_t;
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
22
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
23
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
24 static void ngx_mail_proxy_block_read(ngx_event_t *rev);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
25 static void ngx_mail_proxy_pop3_handler(ngx_event_t *rev);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
26 static void ngx_mail_proxy_imap_handler(ngx_event_t *rev);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
27 static void ngx_mail_proxy_smtp_handler(ngx_event_t *rev);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
28 static void ngx_mail_proxy_dummy_handler(ngx_event_t *ev);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
29 static ngx_int_t ngx_mail_proxy_read_response(ngx_mail_session_t *s,
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
30 ngx_uint_t state);
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
31 static void ngx_mail_proxy_handler(ngx_event_t *ev);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
32 static void ngx_mail_proxy_upstream_error(ngx_mail_session_t *s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
33 static void ngx_mail_proxy_internal_server_error(ngx_mail_session_t *s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
34 static void ngx_mail_proxy_close_session(ngx_mail_session_t *s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
35 static void *ngx_mail_proxy_create_conf(ngx_conf_t *cf);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
36 static char *ngx_mail_proxy_merge_conf(ngx_conf_t *cf, void *parent,
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
37 void *child);
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
38
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
39
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
40 static ngx_command_t ngx_mail_proxy_commands[] = {
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
41
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
42 { ngx_string("proxy"),
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
43 NGX_MAIL_MAIN_CONF|NGX_MAIL_SRV_CONF|NGX_CONF_FLAG,
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
44 ngx_conf_set_flag_slot,
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
45 NGX_MAIL_SRV_CONF_OFFSET,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
46 offsetof(ngx_mail_proxy_conf_t, enable),
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
47 NULL },
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
48
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
49 { ngx_string("proxy_buffer"),
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
50 NGX_MAIL_MAIN_CONF|NGX_MAIL_SRV_CONF|NGX_CONF_TAKE1,
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
51 ngx_conf_set_size_slot,
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
52 NGX_MAIL_SRV_CONF_OFFSET,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
53 offsetof(ngx_mail_proxy_conf_t, buffer_size),
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
54 NULL },
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
55
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
56 { ngx_string("proxy_timeout"),
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
57 NGX_MAIL_MAIN_CONF|NGX_MAIL_SRV_CONF|NGX_CONF_TAKE1,
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
58 ngx_conf_set_msec_slot,
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
59 NGX_MAIL_SRV_CONF_OFFSET,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
60 offsetof(ngx_mail_proxy_conf_t, timeout),
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
61 NULL },
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
62
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
63 { ngx_string("proxy_pass_error_message"),
4273
e444e8f6538b Fixed NGX_CONF_TAKE1/NGX_CONF_FLAG misuse.
Sergey Budnevitch <sb@waeme.net>
parents: 3516
diff changeset
64 NGX_MAIL_MAIN_CONF|NGX_MAIL_SRV_CONF|NGX_CONF_FLAG,
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
65 ngx_conf_set_flag_slot,
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
66 NGX_MAIL_SRV_CONF_OFFSET,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
67 offsetof(ngx_mail_proxy_conf_t, pass_error_message),
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
68 NULL },
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
69
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
70 { ngx_string("xclient"),
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
71 NGX_MAIL_MAIN_CONF|NGX_MAIL_SRV_CONF|NGX_CONF_FLAG,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
72 ngx_conf_set_flag_slot,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
73 NGX_MAIL_SRV_CONF_OFFSET,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
74 offsetof(ngx_mail_proxy_conf_t, xclient),
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
75 NULL },
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
76
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
77 ngx_null_command
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
78 };
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
79
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
80
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
81 static ngx_mail_module_t ngx_mail_proxy_module_ctx = {
1487
f69493e8faab ngx_mail_pop3_module, ngx_mail_imap_module, and ngx_mail_smtp_module
Igor Sysoev <igor@sysoev.ru>
parents: 1342
diff changeset
82 NULL, /* protocol */
f69493e8faab ngx_mail_pop3_module, ngx_mail_imap_module, and ngx_mail_smtp_module
Igor Sysoev <igor@sysoev.ru>
parents: 1342
diff changeset
83
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
84 NULL, /* create main configuration */
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
85 NULL, /* init main configuration */
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
86
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
87 ngx_mail_proxy_create_conf, /* create server configuration */
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
88 ngx_mail_proxy_merge_conf /* merge server configuration */
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
89 };
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
90
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
91
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
92 ngx_module_t ngx_mail_proxy_module = {
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
93 NGX_MODULE_V1,
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
94 &ngx_mail_proxy_module_ctx, /* module context */
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
95 ngx_mail_proxy_commands, /* module directives */
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
96 NGX_MAIL_MODULE, /* module type */
541
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 539
diff changeset
97 NULL, /* init master */
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
98 NULL, /* init module */
541
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 539
diff changeset
99 NULL, /* init process */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 539
diff changeset
100 NULL, /* init thread */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 539
diff changeset
101 NULL, /* exit thread */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 539
diff changeset
102 NULL, /* exit process */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 539
diff changeset
103 NULL, /* exit master */
b09ee85d0ac8 nginx-0.1.45-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 539
diff changeset
104 NGX_MODULE_V1_PADDING
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
105 };
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
106
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
107
2440
939b40aa9ab4 update r2439: make clear name
Igor Sysoev <igor@sysoev.ru>
parents: 2438
diff changeset
108 static u_char smtp_auth_ok[] = "235 2.0.0 OK" CRLF;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
109
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
110
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
111 void
3269
f0d596e84634 rename ngx_peer_addr_t to ngx_addr_t
Igor Sysoev <igor@sysoev.ru>
parents: 2912
diff changeset
112 ngx_mail_proxy_init(ngx_mail_session_t *s, ngx_addr_t *peer)
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
113 {
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
114 int keepalive;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
115 ngx_int_t rc;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
116 ngx_mail_proxy_ctx_t *p;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
117 ngx_mail_proxy_conf_t *pcf;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
118 ngx_mail_core_srv_conf_t *cscf;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
119
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
120 s->connection->log->action = "connecting to upstream";
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
121
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
122 cscf = ngx_mail_get_module_srv_conf(s, ngx_mail_core_module);
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
123
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
124 if (cscf->so_keepalive) {
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
125 keepalive = 1;
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
126
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
127 if (setsockopt(s->connection->fd, SOL_SOCKET, SO_KEEPALIVE,
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
128 (const void *) &keepalive, sizeof(int))
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
129 == -1)
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
130 {
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
131 ngx_log_error(NGX_LOG_ALERT, s->connection->log, ngx_socket_errno,
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
132 "setsockopt(SO_KEEPALIVE) failed");
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
133 }
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
134 }
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
135
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
136 p = ngx_pcalloc(s->connection->pool, sizeof(ngx_mail_proxy_ctx_t));
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
137 if (p == NULL) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
138 ngx_mail_session_internal_server_error(s);
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
139 return;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
140 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
141
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
142 s->proxy = p;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
143
884
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 857
diff changeset
144 p->upstream.sockaddr = peer->sockaddr;
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 857
diff changeset
145 p->upstream.socklen = peer->socklen;
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 857
diff changeset
146 p->upstream.name = &peer->name;
4d68c486fcb0 upstream choice modules
Igor Sysoev <igor@sysoev.ru>
parents: 857
diff changeset
147 p->upstream.get = ngx_event_get_peer;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
148 p->upstream.log = s->connection->log;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
149 p->upstream.log_error = NGX_ERROR_ERR;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
150
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
151 rc = ngx_event_connect_peer(&p->upstream);
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
152
543
511a89da35ad nginx-0.2.0-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 541
diff changeset
153 if (rc == NGX_ERROR || rc == NGX_BUSY || rc == NGX_DECLINED) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
154 ngx_mail_proxy_internal_server_error(s);
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
155 return;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
156 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
157
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
158 ngx_add_timer(p->upstream.connection->read, cscf->timeout);
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
159
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
160 p->upstream.connection->data = s;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
161 p->upstream.connection->pool = s->connection->pool;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
162
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
163 s->connection->read->handler = ngx_mail_proxy_block_read;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
164 p->upstream.connection->write->handler = ngx_mail_proxy_dummy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
165
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
166 pcf = ngx_mail_get_module_srv_conf(s, ngx_mail_proxy_module);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
167
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
168 s->proxy->buffer = ngx_create_temp_buf(s->connection->pool,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
169 pcf->buffer_size);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
170 if (s->proxy->buffer == NULL) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
171 ngx_mail_proxy_internal_server_error(s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
172 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
173 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
174
1981
65581f79e81b reset message
Igor Sysoev <igor@sysoev.ru>
parents: 1892
diff changeset
175 s->out.len = 0;
65581f79e81b reset message
Igor Sysoev <igor@sysoev.ru>
parents: 1892
diff changeset
176
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
177 switch (s->protocol) {
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
178
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
179 case NGX_MAIL_POP3_PROTOCOL:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
180 p->upstream.connection->read->handler = ngx_mail_proxy_pop3_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
181 s->mail_state = ngx_pop3_start;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
182 break;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
183
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
184 case NGX_MAIL_IMAP_PROTOCOL:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
185 p->upstream.connection->read->handler = ngx_mail_proxy_imap_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
186 s->mail_state = ngx_imap_start;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
187 break;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
188
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
189 default: /* NGX_MAIL_SMTP_PROTOCOL */
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
190 p->upstream.connection->read->handler = ngx_mail_proxy_smtp_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
191 s->mail_state = ngx_smtp_start;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
192 break;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
193 }
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
194 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
195
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
196
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
197 static void
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
198 ngx_mail_proxy_block_read(ngx_event_t *rev)
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
199 {
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
200 ngx_connection_t *c;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
201 ngx_mail_session_t *s;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
202
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
203 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0, "mail proxy block read");
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
204
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2311
diff changeset
205 if (ngx_handle_read_event(rev, 0) != NGX_OK) {
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
206 c = rev->data;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
207 s = c->data;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
208
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
209 ngx_mail_proxy_close_session(s);
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
210 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
211 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
212
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
213
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
214 static void
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
215 ngx_mail_proxy_pop3_handler(ngx_event_t *rev)
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
216 {
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
217 u_char *p;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
218 ngx_int_t rc;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
219 ngx_str_t line;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
220 ngx_connection_t *c;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
221 ngx_mail_session_t *s;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
222 ngx_mail_proxy_conf_t *pcf;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
223
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
224 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
225 "mail proxy pop3 auth handler");
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
226
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
227 c = rev->data;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
228 s = c->data;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
229
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
230 if (rev->timedout) {
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
231 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT,
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
232 "upstream timed out");
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
233 c->timedout = 1;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
234 ngx_mail_proxy_internal_server_error(s);
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
235 return;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
236 }
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
237
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
238 rc = ngx_mail_proxy_read_response(s, 0);
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
239
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
240 if (rc == NGX_AGAIN) {
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
241 return;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
242 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
243
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 547
diff changeset
244 if (rc == NGX_ERROR) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
245 ngx_mail_proxy_upstream_error(s);
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
246 return;
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
247 }
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
248
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
249 switch (s->mail_state) {
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
250
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
251 case ngx_pop3_start:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
252 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0, "mail proxy send user");
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
253
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
254 s->connection->log->action = "sending user name to upstream";
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
255
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
256 line.len = sizeof("USER ") - 1 + s->login.len + 2;
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 1981
diff changeset
257 line.data = ngx_pnalloc(c->pool, line.len);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
258 if (line.data == NULL) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
259 ngx_mail_proxy_internal_server_error(s);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
260 return;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
261 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
262
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
263 p = ngx_cpymem(line.data, "USER ", sizeof("USER ") - 1);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
264 p = ngx_cpymem(p, s->login.data, s->login.len);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
265 *p++ = CR; *p = LF;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
266
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
267 s->mail_state = ngx_pop3_user;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
268 break;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
269
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
270 case ngx_pop3_user:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
271 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0, "mail proxy send pass");
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
272
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
273 s->connection->log->action = "sending password to upstream";
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
274
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
275 line.len = sizeof("PASS ") - 1 + s->passwd.len + 2;
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 1981
diff changeset
276 line.data = ngx_pnalloc(c->pool, line.len);
501
d4ea69372b94 nginx-0.1.25-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 479
diff changeset
277 if (line.data == NULL) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
278 ngx_mail_proxy_internal_server_error(s);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
279 return;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
280 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
281
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
282 p = ngx_cpymem(line.data, "PASS ", sizeof("PASS ") - 1);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
283 p = ngx_cpymem(p, s->passwd.data, s->passwd.len);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
284 *p++ = CR; *p = LF;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
285
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
286 s->mail_state = ngx_pop3_passwd;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
287 break;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
288
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
289 case ngx_pop3_passwd:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
290 s->connection->read->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
291 s->connection->write->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
292 rev->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
293 c->write->handler = ngx_mail_proxy_handler;
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
294
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
295 pcf = ngx_mail_get_module_srv_conf(s, ngx_mail_proxy_module);
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
296 ngx_add_timer(s->connection->read, pcf->timeout);
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
297 ngx_del_timer(c->read);
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
298
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
299 c->log->action = NULL;
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
300 ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
301
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
302 ngx_mail_proxy_handler(s->connection->write);
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
303
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
304 return;
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
305
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
306 default:
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
307 #if (NGX_SUPPRESS_WARN)
3516
dd1570b6f237 ngx_str_set() and ngx_str_null()
Igor Sysoev <igor@sysoev.ru>
parents: 3505
diff changeset
308 ngx_str_null(&line);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
309 #endif
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
310 break;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
311 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
312
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
313 if (c->send(c, line.data, line.len) < (ssize_t) line.len) {
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
314 /*
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
315 * we treat the incomplete sending as NGX_ERROR
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
316 * because it is very strange here
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
317 */
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
318 ngx_mail_proxy_internal_server_error(s);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
319 return;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
320 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
321
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
322 s->proxy->buffer->pos = s->proxy->buffer->start;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
323 s->proxy->buffer->last = s->proxy->buffer->start;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
324 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
325
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
326
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
327 static void
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
328 ngx_mail_proxy_imap_handler(ngx_event_t *rev)
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
329 {
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
330 u_char *p;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
331 ngx_int_t rc;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
332 ngx_str_t line;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
333 ngx_connection_t *c;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
334 ngx_mail_session_t *s;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
335 ngx_mail_proxy_conf_t *pcf;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
336
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
337 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
338 "mail proxy imap auth handler");
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
339
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
340 c = rev->data;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
341 s = c->data;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
342
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
343 if (rev->timedout) {
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
344 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT,
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
345 "upstream timed out");
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
346 c->timedout = 1;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
347 ngx_mail_proxy_internal_server_error(s);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
348 return;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
349 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
350
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
351 rc = ngx_mail_proxy_read_response(s, s->mail_state);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
352
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
353 if (rc == NGX_AGAIN) {
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
354 return;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
355 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
356
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 547
diff changeset
357 if (rc == NGX_ERROR) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
358 ngx_mail_proxy_upstream_error(s);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
359 return;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
360 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
361
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
362 switch (s->mail_state) {
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
363
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
364 case ngx_imap_start:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
365 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
366 "mail proxy send login");
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
367
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
368 s->connection->log->action = "sending LOGIN command to upstream";
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
369
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
370 line.len = s->tag.len + sizeof("LOGIN ") - 1
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
371 + 1 + NGX_SIZE_T_LEN + 1 + 2;
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 1981
diff changeset
372 line.data = ngx_pnalloc(c->pool, line.len);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
373 if (line.data == NULL) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
374 ngx_mail_proxy_internal_server_error(s);
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
375 return;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
376 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
377
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
378 line.len = ngx_sprintf(line.data, "%VLOGIN {%uz}" CRLF,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
379 &s->tag, s->login.len)
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
380 - line.data;
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
381
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
382 s->mail_state = ngx_imap_login;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
383 break;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
384
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
385 case ngx_imap_login:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
386 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0, "mail proxy send user");
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
387
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
388 s->connection->log->action = "sending user name to upstream";
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
389
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
390 line.len = s->login.len + 1 + 1 + NGX_SIZE_T_LEN + 1 + 2;
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 1981
diff changeset
391 line.data = ngx_pnalloc(c->pool, line.len);
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
392 if (line.data == NULL) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
393 ngx_mail_proxy_internal_server_error(s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
394 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
395 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
396
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
397 line.len = ngx_sprintf(line.data, "%V {%uz}" CRLF,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
398 &s->login, s->passwd.len)
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
399 - line.data;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
400
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
401 s->mail_state = ngx_imap_user;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
402 break;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
403
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
404 case ngx_imap_user:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
405 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
406 "mail proxy send passwd");
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
407
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
408 s->connection->log->action = "sending password to upstream";
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
409
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
410 line.len = s->passwd.len + 2;
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 1981
diff changeset
411 line.data = ngx_pnalloc(c->pool, line.len);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
412 if (line.data == NULL) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
413 ngx_mail_proxy_internal_server_error(s);
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
414 return;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
415 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
416
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
417 p = ngx_cpymem(line.data, s->passwd.data, s->passwd.len);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
418 *p++ = CR; *p = LF;
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
419
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
420 s->mail_state = ngx_imap_passwd;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
421 break;
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
422
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
423 case ngx_imap_passwd:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
424 s->connection->read->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
425 s->connection->write->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
426 rev->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
427 c->write->handler = ngx_mail_proxy_handler;
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
428
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
429 pcf = ngx_mail_get_module_srv_conf(s, ngx_mail_proxy_module);
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
430 ngx_add_timer(s->connection->read, pcf->timeout);
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
431 ngx_del_timer(c->read);
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
432
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
433 c->log->action = NULL;
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
434 ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
435
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
436 ngx_mail_proxy_handler(s->connection->write);
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
437
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
438 return;
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
439
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
440 default:
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
441 #if (NGX_SUPPRESS_WARN)
3516
dd1570b6f237 ngx_str_set() and ngx_str_null()
Igor Sysoev <igor@sysoev.ru>
parents: 3505
diff changeset
442 ngx_str_null(&line);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
443 #endif
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
444 break;
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
445 }
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
446
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
447 if (c->send(c, line.data, line.len) < (ssize_t) line.len) {
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
448 /*
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
449 * we treat the incomplete sending as NGX_ERROR
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
450 * because it is very strange here
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
451 */
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
452 ngx_mail_proxy_internal_server_error(s);
422
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
453 return;
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
454 }
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
455
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
456 s->proxy->buffer->pos = s->proxy->buffer->start;
edaefb2a20fc nginx-0.0.10-2004-09-12-00:22:11 import
Igor Sysoev <igor@sysoev.ru>
parents: 419
diff changeset
457 s->proxy->buffer->last = s->proxy->buffer->start;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
458 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
459
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
460
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
461 static void
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
462 ngx_mail_proxy_smtp_handler(ngx_event_t *rev)
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
463 {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
464 u_char *p;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
465 ngx_int_t rc;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
466 ngx_str_t line;
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
467 ngx_buf_t *b;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
468 ngx_connection_t *c;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
469 ngx_mail_session_t *s;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
470 ngx_mail_proxy_conf_t *pcf;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
471 ngx_mail_core_srv_conf_t *cscf;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
472
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
473 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
474 "mail proxy smtp auth handler");
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
475
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
476 c = rev->data;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
477 s = c->data;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
478
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
479 if (rev->timedout) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
480 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
481 "upstream timed out");
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
482 c->timedout = 1;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
483 ngx_mail_proxy_internal_server_error(s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
484 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
485 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
486
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
487 rc = ngx_mail_proxy_read_response(s, s->mail_state);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
488
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
489 if (rc == NGX_AGAIN) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
490 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
491 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
492
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
493 if (rc == NGX_ERROR) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
494 ngx_mail_proxy_upstream_error(s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
495 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
496 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
497
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
498 switch (s->mail_state) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
499
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
500 case ngx_smtp_start:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
501 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0, "mail proxy send ehlo");
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
502
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
503 s->connection->log->action = "sending HELO/EHLO to upstream";
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
504
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
505 cscf = ngx_mail_get_module_srv_conf(s, ngx_mail_core_module);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
506
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
507 line.len = sizeof("HELO ") - 1 + cscf->server_name.len + 2;
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 1981
diff changeset
508 line.data = ngx_pnalloc(c->pool, line.len);
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
509 if (line.data == NULL) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
510 ngx_mail_proxy_internal_server_error(s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
511 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
512 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
513
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
514 pcf = ngx_mail_get_module_srv_conf(s, ngx_mail_proxy_module);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
515
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
516 p = ngx_cpymem(line.data,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
517 ((s->esmtp || pcf->xclient) ? "EHLO " : "HELO "),
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
518 sizeof("HELO ") - 1);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
519
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
520 p = ngx_cpymem(p, cscf->server_name.data, cscf->server_name.len);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
521 *p++ = CR; *p = LF;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
522
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
523 if (pcf->xclient) {
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
524 s->mail_state = ngx_smtp_helo_xclient;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
525
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
526 } else if (s->auth_method == NGX_MAIL_AUTH_NONE) {
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
527 s->mail_state = ngx_smtp_helo_from;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
528
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
529 } else {
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
530 s->mail_state = ngx_smtp_helo;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
531 }
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
532
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
533 break;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
534
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
535 case ngx_smtp_helo_xclient:
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
536 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
537 "mail proxy send xclient");
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
538
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
539 s->connection->log->action = "sending XCLIENT to upstream";
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
540
2497
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
541 line.len = sizeof("XCLIENT ADDR= LOGIN= NAME="
1892
057d362ee50e resolver in smtp proxy module
Igor Sysoev <igor@sysoev.ru>
parents: 1487
diff changeset
542 CRLF) - 1
057d362ee50e resolver in smtp proxy module
Igor Sysoev <igor@sysoev.ru>
parents: 1487
diff changeset
543 + s->connection->addr_text.len + s->login.len + s->host.len;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
544
5522
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
545 #if (NGX_HAVE_INET6)
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
546 if (s->connection->sockaddr->sa_family == AF_INET6) {
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
547 line.len += sizeof("IPV6:") - 1;
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
548 }
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
549 #endif
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
550
2049
2a92804f4109 *) back out r2040
Igor Sysoev <igor@sysoev.ru>
parents: 1981
diff changeset
551 line.data = ngx_pnalloc(c->pool, line.len);
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
552 if (line.data == NULL) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
553 ngx_mail_proxy_internal_server_error(s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
554 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
555 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
556
5522
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
557 p = ngx_cpymem(line.data, "XCLIENT ADDR=", sizeof("XCLIENT ADDR=") - 1);
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
558
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
559 #if (NGX_HAVE_INET6)
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
560 if (s->connection->sockaddr->sa_family == AF_INET6) {
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
561 p = ngx_cpymem(p, "IPV6:", sizeof("IPV6:") - 1);
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
562 }
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
563 #endif
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
564
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
565 p = ngx_copy(p, s->connection->addr_text.data,
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
566 s->connection->addr_text.len);
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
567
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
568 if (s->login.len) {
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
569 p = ngx_cpymem(p, " LOGIN=", sizeof(" LOGIN=") - 1);
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
570 p = ngx_copy(p, s->login.data, s->login.len);
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
571 }
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
572
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
573 p = ngx_cpymem(p, " NAME=", sizeof(" NAME=") - 1);
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
574 p = ngx_copy(p, s->host.data, s->host.len);
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
575
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
576 *p++ = CR; *p++ = LF;
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
577
bb3dc21c89ef Mail: fixed passing of IPv6 client address in XCLIENT.
Ruslan Ermilov <ru@nginx.com>
parents: 5399
diff changeset
578 line.len = p - line.data;
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
579
2497
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
580 if (s->smtp_helo.len) {
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
581 s->mail_state = ngx_smtp_xclient_helo;
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
582
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
583 } else if (s->auth_method == NGX_MAIL_AUTH_NONE) {
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
584 s->mail_state = ngx_smtp_xclient_from;
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
585
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
586 } else {
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
587 s->mail_state = ngx_smtp_xclient;
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
588 }
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
589
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
590 break;
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
591
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
592 case ngx_smtp_xclient_helo:
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
593 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
594 "mail proxy send client ehlo");
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
595
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
596 s->connection->log->action = "sending client HELO/EHLO to upstream";
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
597
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
598 line.len = sizeof("HELO " CRLF) - 1 + s->smtp_helo.len;
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
599
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
600 line.data = ngx_pnalloc(c->pool, line.len);
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
601 if (line.data == NULL) {
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
602 ngx_mail_proxy_internal_server_error(s);
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
603 return;
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
604 }
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
605
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
606 line.len = ngx_sprintf(line.data,
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
607 ((s->esmtp) ? "EHLO %V" CRLF : "HELO %V" CRLF),
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
608 &s->smtp_helo)
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
609 - line.data;
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
610
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
611 s->mail_state = (s->auth_method == NGX_MAIL_AUTH_NONE) ?
2497
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
612 ngx_smtp_helo_from : ngx_smtp_helo;
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
613
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
614 break;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
615
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
616 case ngx_smtp_helo_from:
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
617 case ngx_smtp_xclient_from:
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
618 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
619 "mail proxy send mail from");
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
620
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
621 s->connection->log->action = "sending MAIL FROM to upstream";
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
622
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
623 line.len = s->smtp_from.len + sizeof(CRLF) - 1;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
624 line.data = ngx_pnalloc(c->pool, line.len);
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
625 if (line.data == NULL) {
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
626 ngx_mail_proxy_internal_server_error(s);
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
627 return;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
628 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
629
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
630 p = ngx_cpymem(line.data, s->smtp_from.data, s->smtp_from.len);
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
631 *p++ = CR; *p = LF;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
632
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
633 s->mail_state = ngx_smtp_from;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
634
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
635 break;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
636
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
637 case ngx_smtp_from:
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
638 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, rev->log, 0,
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
639 "mail proxy send rcpt to");
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
640
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
641 s->connection->log->action = "sending RCPT TO to upstream";
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
642
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
643 line.len = s->smtp_to.len + sizeof(CRLF) - 1;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
644 line.data = ngx_pnalloc(c->pool, line.len);
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
645 if (line.data == NULL) {
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
646 ngx_mail_proxy_internal_server_error(s);
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
647 return;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
648 }
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
649
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
650 p = ngx_cpymem(line.data, s->smtp_to.data, s->smtp_to.len);
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
651 *p++ = CR; *p = LF;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
652
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
653 s->mail_state = ngx_smtp_to;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
654
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
655 break;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
656
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
657 case ngx_smtp_helo:
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
658 case ngx_smtp_xclient:
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
659 case ngx_smtp_to:
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
660
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
661 b = s->proxy->buffer;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
662
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
663 if (s->auth_method == NGX_MAIL_AUTH_NONE) {
2311
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
664 b->pos = b->start;
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
665
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
666 } else {
2440
939b40aa9ab4 update r2439: make clear name
Igor Sysoev <igor@sysoev.ru>
parents: 2438
diff changeset
667 ngx_memcpy(b->start, smtp_auth_ok, sizeof(smtp_auth_ok) - 1);
939b40aa9ab4 update r2439: make clear name
Igor Sysoev <igor@sysoev.ru>
parents: 2438
diff changeset
668 b->last = b->start + sizeof(smtp_auth_ok) - 1;
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
669 }
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
670
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
671 s->connection->read->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
672 s->connection->write->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
673 rev->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
674 c->write->handler = ngx_mail_proxy_handler;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
675
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
676 pcf = ngx_mail_get_module_srv_conf(s, ngx_mail_proxy_module);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
677 ngx_add_timer(s->connection->read, pcf->timeout);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
678 ngx_del_timer(c->read);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
679
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
680 c->log->action = NULL;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
681 ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
682
5398
04e43d03e153 Mail: smtp pipelining support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
683 if (s->buffer->pos == s->buffer->last) {
04e43d03e153 Mail: smtp pipelining support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
684 ngx_mail_proxy_handler(s->connection->write);
04e43d03e153 Mail: smtp pipelining support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
685
04e43d03e153 Mail: smtp pipelining support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
686 } else {
04e43d03e153 Mail: smtp pipelining support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
687 ngx_mail_proxy_handler(c->write);
04e43d03e153 Mail: smtp pipelining support.
Maxim Dounin <mdounin@mdounin.ru>
parents: 4412
diff changeset
688 }
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
689
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
690 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
691
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
692 default:
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
693 #if (NGX_SUPPRESS_WARN)
3516
dd1570b6f237 ngx_str_set() and ngx_str_null()
Igor Sysoev <igor@sysoev.ru>
parents: 3505
diff changeset
694 ngx_str_null(&line);
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
695 #endif
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
696 break;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
697 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
698
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
699 if (c->send(c, line.data, line.len) < (ssize_t) line.len) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
700 /*
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
701 * we treat the incomplete sending as NGX_ERROR
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
702 * because it is very strange here
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
703 */
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
704 ngx_mail_proxy_internal_server_error(s);
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
705 return;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
706 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
707
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
708 s->proxy->buffer->pos = s->proxy->buffer->start;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
709 s->proxy->buffer->last = s->proxy->buffer->start;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
710 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
711
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
712
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
713 static void
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
714 ngx_mail_proxy_dummy_handler(ngx_event_t *wev)
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
715 {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
716 ngx_connection_t *c;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
717 ngx_mail_session_t *s;
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
718
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
719 ngx_log_debug0(NGX_LOG_DEBUG_MAIL, wev->log, 0, "mail proxy dummy handler");
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
720
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2311
diff changeset
721 if (ngx_handle_write_event(wev, 0) != NGX_OK) {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
722 c = wev->data;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
723 s = c->data;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
724
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
725 ngx_mail_proxy_close_session(s);
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
726 }
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
727 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
728
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
729
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
730 static ngx_int_t
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
731 ngx_mail_proxy_read_response(ngx_mail_session_t *s, ngx_uint_t state)
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
732 {
5399
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
733 u_char *p, *m;
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
734 ssize_t n;
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
735 ngx_buf_t *b;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
736 ngx_mail_proxy_conf_t *pcf;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
737
587
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
738 s->connection->log->action = "reading response from upstream";
284cc140593b nginx-0.3.15-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 583
diff changeset
739
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
740 b = s->proxy->buffer;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
741
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
742 n = s->proxy->upstream.connection->recv(s->proxy->upstream.connection,
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
743 b->last, b->end - b->last);
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
744
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
745 if (n == NGX_ERROR || n == 0) {
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
746 return NGX_ERROR;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
747 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
748
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
749 if (n == NGX_AGAIN) {
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
750 return NGX_AGAIN;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
751 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
752
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
753 b->last += n;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
754
3505
c631ef8beaaa Zimbra IMAP server may return only 4 bytes: "+ \r\n"
Igor Sysoev <igor@sysoev.ru>
parents: 3269
diff changeset
755 if (b->last - b->pos < 4) {
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
756 return NGX_AGAIN;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
757 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
758
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
759 if (*(b->last - 2) != CR || *(b->last - 1) != LF) {
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
760 if (b->last == b->end) {
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
761 *(b->last - 1) = '\0';
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
762 ngx_log_error(NGX_LOG_ERR, s->connection->log, 0,
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
763 "upstream sent too long response line: \"%s\"",
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
764 b->pos);
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 547
diff changeset
765 return NGX_ERROR;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
766 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
767
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
768 return NGX_AGAIN;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
769 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
770
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
771 p = b->pos;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
772
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
773 switch (s->protocol) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
774
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
775 case NGX_MAIL_POP3_PROTOCOL:
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
776 if (p[0] == '+' && p[1] == 'O' && p[2] == 'K') {
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
777 return NGX_OK;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
778 }
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
779 break;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
780
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
781 case NGX_MAIL_IMAP_PROTOCOL:
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
782 switch (state) {
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
783
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
784 case ngx_imap_start:
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
785 if (p[0] == '*' && p[1] == ' ' && p[2] == 'O' && p[3] == 'K') {
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
786 return NGX_OK;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
787 }
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
788 break;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
789
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
790 case ngx_imap_login:
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
791 case ngx_imap_user:
529
e5d7d0334fdb nginx-0.1.39-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 527
diff changeset
792 if (p[0] == '+') {
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
793 return NGX_OK;
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
794 }
663
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
795 break;
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
796
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
797 case ngx_imap_passwd:
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
798 if (ngx_strncmp(p, s->tag.data, s->tag.len) == 0) {
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
799 p += s->tag.len;
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
800 if (p[0] == 'O' && p[1] == 'K') {
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
801 return NGX_OK;
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
802 }
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
803 }
6d5c1535bb9d nginx-0.3.53-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 589
diff changeset
804 break;
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
805 }
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
806
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
807 break;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
808
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
809 default: /* NGX_MAIL_SMTP_PROTOCOL */
5399
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
810
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
811 if (p[3] == '-') {
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
812 /* multiline reply, check if we got last line */
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
813
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
814 m = b->last - (sizeof(CRLF "200" CRLF) - 1);
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
815
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
816 while (m > p) {
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
817 if (m[0] == CR && m[1] == LF) {
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
818 break;
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
819 }
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
820
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
821 m--;
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
822 }
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
823
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
824 if (m <= p || m[5] == '-') {
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
825 return NGX_AGAIN;
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
826 }
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
827 }
d3e09aa03a7a Mail: handle smtp multiline replies.
Maxim Dounin <mdounin@mdounin.ru>
parents: 5398
diff changeset
828
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
829 switch (state) {
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
830
2311
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
831 case ngx_smtp_start:
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
832 if (p[0] == '2' && p[1] == '2' && p[2] == '0') {
1166
bde5e4134759 style fix: remove tabs
Igor Sysoev <igor@sysoev.ru>
parents: 1136
diff changeset
833 return NGX_OK;
bde5e4134759 style fix: remove tabs
Igor Sysoev <igor@sysoev.ru>
parents: 1136
diff changeset
834 }
bde5e4134759 style fix: remove tabs
Igor Sysoev <igor@sysoev.ru>
parents: 1136
diff changeset
835 break;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
836
2311
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
837 case ngx_smtp_helo:
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
838 case ngx_smtp_helo_xclient:
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
839 case ngx_smtp_helo_from:
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
840 case ngx_smtp_from:
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
841 if (p[0] == '2' && p[1] == '5' && p[2] == '0') {
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
842 return NGX_OK;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
843 }
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
844 break;
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
845
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
846 case ngx_smtp_xclient:
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
847 case ngx_smtp_xclient_from:
2497
1ab9cef4ff6c send HELO/EHLO after XCLIENT
Igor Sysoev <igor@sysoev.ru>
parents: 2440
diff changeset
848 case ngx_smtp_xclient_helo:
2309
8156bc03982a smtp_auth none
Igor Sysoev <igor@sysoev.ru>
parents: 2049
diff changeset
849 if (p[0] == '2' && (p[1] == '2' || p[1] == '5') && p[2] == '0') {
1166
bde5e4134759 style fix: remove tabs
Igor Sysoev <igor@sysoev.ru>
parents: 1136
diff changeset
850 return NGX_OK;
bde5e4134759 style fix: remove tabs
Igor Sysoev <igor@sysoev.ru>
parents: 1136
diff changeset
851 }
bde5e4134759 style fix: remove tabs
Igor Sysoev <igor@sysoev.ru>
parents: 1136
diff changeset
852 break;
2311
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
853
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
854 case ngx_smtp_to:
6bad42a41dd8 do not close session if SMTP backend returned an error on RCPT TO
Igor Sysoev <igor@sysoev.ru>
parents: 2309
diff changeset
855 return NGX_OK;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
856 }
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
857
1166
bde5e4134759 style fix: remove tabs
Igor Sysoev <igor@sysoev.ru>
parents: 1136
diff changeset
858 break;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
859 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
860
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
861 pcf = ngx_mail_get_module_srv_conf(s, ngx_mail_proxy_module);
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
862
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
863 if (pcf->pass_error_message == 0) {
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
864 *(b->last - 2) = '\0';
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
865 ngx_log_error(NGX_LOG_ERR, s->connection->log, 0,
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
866 "upstream sent invalid response: \"%s\"", p);
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
867 return NGX_ERROR;
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
868 }
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
869
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
870 s->out.len = b->last - p - 2;
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
871 s->out.data = p;
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
872
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
873 ngx_log_error(NGX_LOG_INFO, s->connection->log, 0,
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
874 "upstream sent invalid response: \"%V\"", &s->out);
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
875
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
876 s->out.len = b->last - b->pos;
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
877 s->out.data = b->pos;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
878
571
458b6c3fea65 nginx-0.3.7-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 547
diff changeset
879 return NGX_ERROR;
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
880 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
881
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
882
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
883 static void
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
884 ngx_mail_proxy_handler(ngx_event_t *ev)
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
885 {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
886 char *action, *recv_action, *send_action;
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
887 size_t size;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
888 ssize_t n;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
889 ngx_buf_t *b;
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
890 ngx_uint_t do_write;
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
891 ngx_connection_t *c, *src, *dst;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
892 ngx_mail_session_t *s;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
893 ngx_mail_proxy_conf_t *pcf;
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
894
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
895 c = ev->data;
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
896 s = c->data;
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
897
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
898 if (ev->timedout) {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
899 c->log->action = "proxying";
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
900
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
901 if (c == s->connection) {
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
902 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT,
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
903 "client timed out");
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
904 c->timedout = 1;
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
905
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
906 } else {
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
907 ngx_log_error(NGX_LOG_INFO, c->log, NGX_ETIMEDOUT,
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
908 "upstream timed out");
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
909 }
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
910
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
911 ngx_mail_proxy_close_session(s);
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
912 return;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
913 }
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
914
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
915 if (c == s->connection) {
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
916 if (ev->write) {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
917 recv_action = "proxying and reading from upstream";
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
918 send_action = "proxying and sending to client";
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
919 src = s->proxy->upstream.connection;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
920 dst = c;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
921 b = s->proxy->buffer;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
922
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
923 } else {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
924 recv_action = "proxying and reading from client";
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
925 send_action = "proxying and sending to upstream";
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
926 src = c;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
927 dst = s->proxy->upstream.connection;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
928 b = s->buffer;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
929 }
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
930
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
931 } else {
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
932 if (ev->write) {
589
d4e858a5751a nginx-0.3.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 587
diff changeset
933 recv_action = "proxying and reading from client";
d4e858a5751a nginx-0.3.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 587
diff changeset
934 send_action = "proxying and sending to upstream";
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
935 src = s->connection;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
936 dst = c;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
937 b = s->buffer;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
938
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
939 } else {
589
d4e858a5751a nginx-0.3.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 587
diff changeset
940 recv_action = "proxying and reading from upstream";
d4e858a5751a nginx-0.3.16-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 587
diff changeset
941 send_action = "proxying and sending to client";
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
942 src = c;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
943 dst = s->connection;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
944 b = s->proxy->buffer;
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
945 }
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
946 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
947
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
948 do_write = ev->write ? 1 : 0;
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
949
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
950 ngx_log_debug3(NGX_LOG_DEBUG_MAIL, ev->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
951 "mail proxy handler: %d, #%d > #%d",
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
952 do_write, src->fd, dst->fd);
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
953
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
954 for ( ;; ) {
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
955
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
956 if (do_write) {
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
957
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
958 size = b->last - b->pos;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
959
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
960 if (size && dst->write->ready) {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
961 c->log->action = send_action;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
962
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
963 n = dst->send(dst, b->pos, size);
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
964
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
965 if (n == NGX_ERROR) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
966 ngx_mail_proxy_close_session(s);
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
967 return;
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
968 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
969
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
970 if (n > 0) {
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
971 b->pos += n;
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
972
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
973 if (b->pos == b->last) {
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
974 b->pos = b->start;
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
975 b->last = b->start;
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
976 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
977 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
978 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
979 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
980
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
981 size = b->end - b->last;
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
982
423
fda5987b188d nginx-0.0.10-2004-09-13-20:18:09 import
Igor Sysoev <igor@sysoev.ru>
parents: 422
diff changeset
983 if (size && src->read->ready) {
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
984 c->log->action = recv_action;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
985
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
986 n = src->recv(src, b->last, size);
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
987
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
988 if (n == NGX_AGAIN || n == 0) {
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
989 break;
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
990 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
991
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
992 if (n > 0) {
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
993 do_write = 1;
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
994 b->last += n;
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
995
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
996 continue;
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
997 }
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
998
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
999 if (n == NGX_ERROR) {
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1000 src->read->eof = 1;
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
1001 }
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1002 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1003
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1004 break;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1005 }
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1006
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1007 c->log->action = "proxying";
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1008
1342
be2e13691c60 fix case when client has closed connection but upstream buffer is not empty
Igor Sysoev <igor@sysoev.ru>
parents: 1166
diff changeset
1009 if ((s->connection->read->eof && s->buffer->pos == s->buffer->last)
be2e13691c60 fix case when client has closed connection but upstream buffer is not empty
Igor Sysoev <igor@sysoev.ru>
parents: 1166
diff changeset
1010 || (s->proxy->upstream.connection->read->eof
be2e13691c60 fix case when client has closed connection but upstream buffer is not empty
Igor Sysoev <igor@sysoev.ru>
parents: 1166
diff changeset
1011 && s->proxy->buffer->pos == s->proxy->buffer->last)
be2e13691c60 fix case when client has closed connection but upstream buffer is not empty
Igor Sysoev <igor@sysoev.ru>
parents: 1166
diff changeset
1012 || (s->connection->read->eof
be2e13691c60 fix case when client has closed connection but upstream buffer is not empty
Igor Sysoev <igor@sysoev.ru>
parents: 1166
diff changeset
1013 && s->proxy->upstream.connection->read->eof))
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1014 {
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1015 action = c->log->action;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1016 c->log->action = NULL;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1017 ngx_log_error(NGX_LOG_INFO, c->log, 0, "proxied session done");
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1018 c->log->action = action;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1019
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1020 ngx_mail_proxy_close_session(s);
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1021 return;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1022 }
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1023
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2311
diff changeset
1024 if (ngx_handle_write_event(dst->write, 0) != NGX_OK) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1025 ngx_mail_proxy_close_session(s);
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1026 return;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1027 }
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1028
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2311
diff changeset
1029 if (ngx_handle_read_event(dst->read, 0) != NGX_OK) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1030 ngx_mail_proxy_close_session(s);
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1031 return;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1032 }
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1033
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2311
diff changeset
1034 if (ngx_handle_write_event(src->write, 0) != NGX_OK) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1035 ngx_mail_proxy_close_session(s);
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1036 return;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1037 }
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1038
2388
722b5aff05ae use "!= NGX_OK" instead of "== NGX_ERROR"
Igor Sysoev <igor@sysoev.ru>
parents: 2311
diff changeset
1039 if (ngx_handle_read_event(src->read, 0) != NGX_OK) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1040 ngx_mail_proxy_close_session(s);
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1041 return;
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1042 }
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1043
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1044 if (c == s->connection) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1045 pcf = ngx_mail_get_module_srv_conf(s, ngx_mail_proxy_module);
583
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1046 ngx_add_timer(c->read, pcf->timeout);
4e296b7d25bf nginx-0.3.13-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 577
diff changeset
1047 }
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1048 }
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1049
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1050
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1051 static void
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1052 ngx_mail_proxy_upstream_error(ngx_mail_session_t *s)
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1053 {
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1054 if (s->proxy->upstream.connection) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1055 ngx_log_debug1(NGX_LOG_DEBUG_MAIL, s->connection->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1056 "close mail proxy connection: %d",
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1057 s->proxy->upstream.connection->fd);
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1058
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1059 ngx_close_connection(s->proxy->upstream.connection);
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1060 }
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1061
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1062 if (s->out.len == 0) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1063 ngx_mail_session_internal_server_error(s);
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1064 return;
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1065 }
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1066
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1067 s->quit = 1;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1068 ngx_mail_send(s->connection->write);
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1069 }
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1070
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1071
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1072 static void
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1073 ngx_mail_proxy_internal_server_error(ngx_mail_session_t *s)
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1074 {
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1075 if (s->proxy->upstream.connection) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1076 ngx_log_debug1(NGX_LOG_DEBUG_MAIL, s->connection->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1077 "close mail proxy connection: %d",
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1078 s->proxy->upstream.connection->fd);
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1079
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1080 ngx_close_connection(s->proxy->upstream.connection);
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1081 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1082
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1083 ngx_mail_session_internal_server_error(s);
527
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1084 }
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1085
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1086
7fa11e5c6e96 nginx-0.1.38-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 521
diff changeset
1087 static void
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1088 ngx_mail_proxy_close_session(ngx_mail_session_t *s)
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1089 {
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1090 if (s->proxy->upstream.connection) {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1091 ngx_log_debug1(NGX_LOG_DEBUG_MAIL, s->connection->log, 0,
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1092 "close mail proxy connection: %d",
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1093 s->proxy->upstream.connection->fd);
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1094
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1095 ngx_close_connection(s->proxy->upstream.connection);
419
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
1096 }
47709bff4468 nginx-0.0.10-2004-09-09-19:40:48 import
Igor Sysoev <igor@sysoev.ru>
parents: 418
diff changeset
1097
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1098 ngx_mail_close_connection(s->connection);
418
cf072d26d6d6 nginx-0.0.10-2004-09-08-09:18:51 import
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1099 }
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1100
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1101
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1102 static void *
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1103 ngx_mail_proxy_create_conf(ngx_conf_t *cf)
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1104 {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1105 ngx_mail_proxy_conf_t *pcf;
577
4d9ea73a627a nginx-0.3.10-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 571
diff changeset
1106
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1107 pcf = ngx_pcalloc(cf->pool, sizeof(ngx_mail_proxy_conf_t));
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1108 if (pcf == NULL) {
2912
c7d57b539248 return NULL instead of NGX_CONF_ERROR on a create conf failure
Igor Sysoev <igor@sysoev.ru>
parents: 2497
diff changeset
1109 return NULL;
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1110 }
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1111
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1112 pcf->enable = NGX_CONF_UNSET;
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1113 pcf->pass_error_message = NGX_CONF_UNSET;
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1114 pcf->xclient = NGX_CONF_UNSET;
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
1115 pcf->buffer_size = NGX_CONF_UNSET_SIZE;
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
1116 pcf->timeout = NGX_CONF_UNSET_MSEC;
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1117
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1118 return pcf;
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1119 }
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1120
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1121
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1122 static char *
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1123 ngx_mail_proxy_merge_conf(ngx_conf_t *cf, void *parent, void *child)
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1124 {
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1125 ngx_mail_proxy_conf_t *prev = parent;
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1126 ngx_mail_proxy_conf_t *conf = child;
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1127
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
1128 ngx_conf_merge_value(conf->enable, prev->enable, 0);
857
739b997da512 proxy_pass_error_message
Igor Sysoev <igor@sysoev.ru>
parents: 663
diff changeset
1129 ngx_conf_merge_value(conf->pass_error_message, prev->pass_error_message, 0);
1136
68f30ab68bb7 Many changes:
Igor Sysoev <igor@sysoev.ru>
parents: 884
diff changeset
1130 ngx_conf_merge_value(conf->xclient, prev->xclient, 1);
539
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
1131 ngx_conf_merge_size_value(conf->buffer_size, prev->buffer_size,
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
1132 (size_t) ngx_pagesize);
371c1cee100d nginx-0.1.44-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 531
diff changeset
1133 ngx_conf_merge_msec_value(conf->timeout, prev->timeout, 24 * 60 * 60000);
521
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1134
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1135 return NGX_CONF_OK;
6f00349b98e5 nginx-0.1.35-RELEASE import
Igor Sysoev <igor@sysoev.ru>
parents: 509
diff changeset
1136 }