diff options
author | alecpl <alec@alec.pl> | 2008-10-08 08:42:59 +0000 |
---|---|---|
committer | alecpl <alec@alec.pl> | 2008-10-08 08:42:59 +0000 |
commit | acff900c5a3a7c89faaf1141eff706ec221a4dd3 (patch) | |
tree | 1e15045cd864047c300365c496a8ba294f233128 /program/steps/mail | |
parent | 89bafaeb61fbd6e4a894e6e487b17754bc99a009 (diff) |
#1485294: Add recipients address small validation
Diffstat (limited to 'program/steps/mail')
-rw-r--r-- | program/steps/mail/sendmail.inc | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/program/steps/mail/sendmail.inc b/program/steps/mail/sendmail.inc index 4706af22f..784d46a8f 100644 --- a/program/steps/mail/sendmail.inc +++ b/program/steps/mail/sendmail.inc @@ -145,10 +145,10 @@ $message_id = sprintf('<%s@%s>', md5(uniqid('rcmail'.rand(),true)), $RCMAIL->con $input_charset = $OUTPUT->get_charset(); $message_charset = isset($_POST['_charset']) ? $_POST['_charset'] : $input_charset; -$mailto_regexp = array('/[,;]\s*[\r\n]+/', '/[\r\n]+/', '/[,;]\s*$/m', '/;/'); -$mailto_replace = array(', ', ', ', '', ','); +$mailto_regexp = array('/[,;]\s*[\r\n]+/', '/[\r\n]+/', '/[,;]\s*$/m', '/;/', '/(\S{1})(<\S+@\S+>)/U'); +$mailto_replace = array(', ', ', ', '', ',', '\\1 \\2'); -// replace new lines and strip ending ', ' +// replace new lines and strip ending ', ', make address strings more valid also $mailto = preg_replace($mailto_regexp, $mailto_replace, get_input_value('_to', RCUBE_INPUT_POST, TRUE, $message_charset)); $mailcc = preg_replace($mailto_regexp, $mailto_replace, get_input_value('_cc', RCUBE_INPUT_POST, TRUE, $message_charset)); $mailbcc = preg_replace($mailto_regexp, $mailto_replace, get_input_value('_bcc', RCUBE_INPUT_POST, TRUE, $message_charset)); |