Mercurial > hg > nginx-vendor-0-5
comparison src/mail/ngx_mail_parse.c @ 324:7cf404023f50 NGINX_0_5_32
nginx 0.5.32
*) Change: now nginx tries to set the "worker_priority",
"worker_rlimit_nofile", "worker_rlimit_core", and
"worker_rlimit_sigpending" without super-user privileges.
*) Change: now nginx escapes space and "%" in request to a mail proxy
authentication server.
*) Change: now nginx escapes "%" in $memcached_key variable.
*) Change: the special make target "upgrade1" was defined for online
upgrade of 0.1.x versions.
*) Feature: the "add_header Last-Modified ..." directive changes the
"Last-Modified" response header line.
*) Feature: the mail proxy supports AUTHENTICATE in IMAP mode.
Thanks to Maxim Dounin.
*) Feature: the mail proxy supports STARTTLS in SMTP mode.
Thanks to Maxim Dounin.
*) Bugfix: nginx did not close directory file on HEAD request if
autoindex was used.
Thanks to Arkadiusz Patyk.
*) Bugfix: the "proxy_hide_header" and "fastcgi_hide_header" directives
did not hide response header lines whose name was longer than 32
characters.
Thanks to Manlio Perillo.
*) Bugfix: active connection counter always increased if mail proxy was
used.
*) Bugfix: if backend returned response header only using non-buffered
proxy, then nginx closed backend connection on timeout.
*) Bugfix: nginx did not support several "Connection" request header
lines.
*) Bugfix: a charset set by the "charset" directive was not appended to
the "Content-Type" header set by $r->send_http_header().
*) Bugfix: a segmentation fault might occur in worker process if
/dev/poll method was used.
*) Bugfix: nginx did not work on FreeBSD/sparc64.
*) Bugfix: a segmentation fault occurred in worker process if invalid
address was set in the "auth_http" directive.
*) Bugfix: now nginx uses default listen backlog value 511 on all
platforms except FreeBSD.
Thanks to Jiang Hong.
*) Bugfix: now Solaris sendfilev() is not used to transfer the client
request body to FastCGI-server via the unix domain socket.
*) Bugfix: if the same host without specified port was used as backend
for HTTP and HTTPS, then nginx used only one port - 80 or 443.
*) Bugfix: the "proxy_ignore_client_abort" and
"fastcgi_ignore_client_abort" directives did not work; bug appeared
in 0.5.13.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Mon, 24 Sep 2007 00:00:00 +0400 |
parents | f745bf973510 |
children | f70f2f565fe0 |
comparison
equal
deleted
inserted
replaced
323:85aeb2da6e4c | 324:7cf404023f50 |
---|---|
352 } else { | 352 } else { |
353 goto invalid; | 353 goto invalid; |
354 } | 354 } |
355 break; | 355 break; |
356 | 356 |
357 case 12: | |
358 if ((c[0] == 'A'|| c[0] == 'a') | |
359 && (c[1] == 'U'|| c[1] == 'u') | |
360 && (c[2] == 'T'|| c[2] == 't') | |
361 && (c[3] == 'H'|| c[3] == 'h') | |
362 && (c[4] == 'E'|| c[4] == 'e') | |
363 && (c[5] == 'N'|| c[5] == 'n') | |
364 && (c[6] == 'T'|| c[6] == 't') | |
365 && (c[7] == 'I'|| c[7] == 'i') | |
366 && (c[8] == 'C'|| c[8] == 'c') | |
367 && (c[9] == 'A'|| c[9] == 'a') | |
368 && (c[10] == 'T'|| c[10] == 't') | |
369 && (c[11] == 'E'|| c[11] == 'e')) | |
370 { | |
371 s->command = NGX_IMAP_AUTHENTICATE; | |
372 | |
373 } else { | |
374 goto invalid; | |
375 } | |
376 break; | |
377 | |
357 default: | 378 default: |
358 goto invalid; | 379 goto invalid; |
359 } | 380 } |
360 | 381 |
361 switch (ch) { | 382 switch (ch) { |
411 goto invalid; | 432 goto invalid; |
412 } | 433 } |
413 break; | 434 break; |
414 | 435 |
415 case sw_argument: | 436 case sw_argument: |
437 if (ch == ' ' && s->quoted) { | |
438 break; | |
439 } | |
440 | |
416 switch (ch) { | 441 switch (ch) { |
417 case '"': | 442 case '"': |
418 if (!s->quoted) { | 443 if (!s->quoted) { |
419 break; | 444 break; |
420 } | 445 } |
571 s->quoted = 0; | 596 s->quoted = 0; |
572 s->no_sync_literal = 0; | 597 s->no_sync_literal = 0; |
573 s->literal_len = 0; | 598 s->literal_len = 0; |
574 } | 599 } |
575 | 600 |
576 s->state = sw_start; | 601 s->state = (s->command != NGX_IMAP_AUTHENTICATE) ? sw_start : sw_argument; |
577 | 602 |
578 return NGX_OK; | 603 return NGX_OK; |
579 | 604 |
580 invalid: | 605 invalid: |
581 | 606 |
644 | 669 |
645 } else if (c0 == 'R' && c1 == 'S' && c2 == 'E' && c3 == 'T') | 670 } else if (c0 == 'R' && c1 == 'S' && c2 == 'E' && c3 == 'T') |
646 { | 671 { |
647 s->command = NGX_SMTP_RSET; | 672 s->command = NGX_SMTP_RSET; |
648 | 673 |
674 } else if (c0 == 'R' && c1 == 'C' && c2 == 'P' && c3 == 'T') | |
675 { | |
676 s->command = NGX_SMTP_RCPT; | |
677 | |
678 } else if (c0 == 'V' && c1 == 'R' && c2 == 'F' && c3 == 'Y') | |
679 { | |
680 s->command = NGX_SMTP_VRFY; | |
681 | |
682 } else if (c0 == 'E' && c1 == 'X' && c2 == 'P' && c3 == 'N') | |
683 { | |
684 s->command = NGX_SMTP_EXPN; | |
685 | |
686 } else if (c0 == 'H' && c1 == 'E' && c2 == 'L' && c3 == 'P') | |
687 { | |
688 s->command = NGX_SMTP_HELP; | |
689 | |
649 } else { | 690 } else { |
650 goto invalid; | 691 goto invalid; |
651 } | 692 } |
652 | 693 #if (NGX_MAIL_SSL) |
694 } else if (p - c == 8) { | |
695 | |
696 if ((c[0] == 'S'|| c[0] == 's') | |
697 && (c[1] == 'T'|| c[1] == 't') | |
698 && (c[2] == 'A'|| c[2] == 'a') | |
699 && (c[3] == 'R'|| c[3] == 'r') | |
700 && (c[4] == 'T'|| c[4] == 't') | |
701 && (c[5] == 'T'|| c[5] == 't') | |
702 && (c[6] == 'L'|| c[6] == 'l') | |
703 && (c[7] == 'S'|| c[7] == 's')) | |
704 { | |
705 s->command = NGX_SMTP_STARTTLS; | |
706 | |
707 } else { | |
708 goto invalid; | |
709 } | |
710 #endif | |
653 } else { | 711 } else { |
654 goto invalid; | 712 goto invalid; |
655 } | 713 } |
656 | 714 |
657 switch (ch) { | 715 switch (ch) { |