aboutsummaryrefslogtreecommitdiff
path: root/src/mail/ngx_mail_imap_module.c
diff options
context:
space:
mode:
authorMaxim Dounin <mdounin@mdounin.ru>2015-02-25 17:48:05 +0300
committerMaxim Dounin <mdounin@mdounin.ru>2015-02-25 17:48:05 +0300
commitfaec5477710c4ca15fd2588ee168d8fb2348ef6d (patch)
tree389954c725bba33fc08cd44f73a8ed3eedad6379 /src/mail/ngx_mail_imap_module.c
parent78e1a8ed7f33c55e7a24cbf4d0155bea6430dd59 (diff)
downloadnginx-faec5477710c4ca15fd2588ee168d8fb2348ef6d.tar.gz
nginx-faec5477710c4ca15fd2588ee168d8fb2348ef6d.zip
Mail: client SSL certificates support.
The "ssl_verify_client", "ssl_verify_depth", "ssl_client_certificate", "ssl_trusted_certificate", and "ssl_crl" directives introduced to control SSL client certificate verification in mail proxy module. If there is a certificate, detail of the certificate are passed to the auth_http script configured via Auth-SSL-Verify, Auth-SSL-Subject, Auth-SSL-Issuer, Auth-SSL-Serial, Auth-SSL-Fingerprint headers. If the auth_http_pass_client_cert directive is set, client certificate in PEM format will be passed in the Auth-SSL-Cert header (urlencoded). If there is no required certificate provided during an SSL handshake or certificate verification fails then a protocol-specific error is returned after the SSL handshake and the connection is closed. Based on previous work by Sven Peter, Franck Levionnois and Filipe Da Silva.
Diffstat (limited to 'src/mail/ngx_mail_imap_module.c')
-rw-r--r--src/mail/ngx_mail_imap_module.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/mail/ngx_mail_imap_module.c b/src/mail/ngx_mail_imap_module.c
index dc80b4fb4..d281070fb 100644
--- a/src/mail/ngx_mail_imap_module.c
+++ b/src/mail/ngx_mail_imap_module.c
@@ -52,7 +52,9 @@ static ngx_mail_protocol_t ngx_mail_imap_protocol = {
ngx_mail_imap_parse_command,
ngx_mail_imap_auth_state,
- ngx_string("* BAD internal server error" CRLF)
+ ngx_string("* BAD internal server error" CRLF),
+ ngx_string("* BYE SSL certificate error" CRLF),
+ ngx_string("* BYE No required SSL certificate" CRLF)
};