X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2FMisc.pm;h=ff5723fd7a3cde18e7bbebe6df38f160ccd402c2;hb=0a91d21fcf8ebeb12cd71230d79153c1fa0d82a3;hp=eedc736ee8cb1df5f86ac3acb32e6885b087df5c;hpb=eb1796299a429ba5cd3b939a65bf5e95abf0086c;p=freeside.git diff --git a/FS/FS/Misc.pm b/FS/FS/Misc.pm index eedc736ee..ff5723fd7 100644 --- a/FS/FS/Misc.pm +++ b/FS/FS/Misc.pm @@ -254,13 +254,11 @@ sub send_email { } push @to, $options{bcc} if defined($options{bcc}); - # make sure - my @env_to = split(/\s*,\s*/, join(', ', @to)); - # strip display-name from envelope addresses - foreach (@env_to) { - s/^\s*//; - s/\s*$//; - s/^(.*)\s*<(.*@.*)>$/$2/; + # fully unpack all addresses found in @to (including Bcc) to make the + # envelope list + my @env_to; + foreach my $dest (@to) { + push @env_to, map { $_->address } Email::Address->parse($dest); } local $@; # just in case @@ -281,7 +279,7 @@ sub send_email { if ( $conf->exists('log_sent_mail') ) { my $cust_msg = FS::cust_msg->new({ 'env_from' => $options{'from'}, - 'env_to' => join(', ', @to), + 'env_to' => join(', ', @env_to), 'header' => $message->header_as_string, 'body' => $message->body_as_string, '_date' => $time,