X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FMailer.pm;h=a408b03b946518f7dcb9df4260b3e0983c5ebb18;hb=841762994976f7cdbdf1ab5c4bdcbf9daf8230e1;hp=67f46fe21a483fd584b10072361b81d876553c61;hpb=d63305ba3bea55eec4aac2df26149f439c086508;p=kivitendo-erp.git diff --git a/SL/Mailer.pm b/SL/Mailer.pm index 67f46fe21..a408b03b9 100644 --- a/SL/Mailer.pm +++ b/SL/Mailer.pm @@ -25,6 +25,7 @@ package Mailer; use Email::Address; use Email::MIME::Creator; +use Encode; use File::MimeInfo::Magic; use File::Slurp; use List::UtilsBy qw(bundle_by); @@ -56,6 +57,7 @@ my %type_to_table = ( letter => 'letter', purchase_delivery_order => 'delivery_orders', sales_delivery_order => 'delivery_orders', + dunning => 'dunning', ); sub new { @@ -150,8 +152,6 @@ sub _create_attachment_part { my $file_id = 0; my $email_journal = $::instance_conf->get_email_journal; - $::lxdebug->message(LXDebug->DEBUG2(), "mail5 att=" . $attachment . " email_journal=" . $email_journal . " id=" . $attachment->{id}); - if (ref($attachment) eq "HASH") { $attributes{filename} = $attachment->{name}; $file_id = $attachment->{id} || '0'; @@ -176,12 +176,9 @@ sub _create_attachment_part { $attachment_content ||= ' '; $attributes{charset} = $self->{charset} if $self->{charset} && ($attributes{content_type} =~ m{^text/}); - $::lxdebug->message(LXDebug->DEBUG2(), "mail6 mtype=" . $attributes{content_type} . " filename=" . $attributes{filename}); - my $ent; if ( $attributes{content_type} eq 'message/rfc822' ) { $ent = Email::MIME->new($attachment_content); - $ent->header_str_set('Content-disposition' => 'attachment; filename='.$attributes{filename}); } else { $ent = Email::MIME->create( attributes => \%attributes, @@ -189,6 +186,13 @@ sub _create_attachment_part { ); } + # Due to a bug in Email::MIME it's not enough to hand over the encoded file name in the "attributes" hash in the + # "create" call. Email::MIME iterates over the keys in the hash, and depending on which key it has already seen during + # the iteration it might revert the encoding. As Perl's hash key order is randomized for each Perl run, this means + # that the file name stays unencoded sometimes. + # Setting the header manually after the "create" call circumvents this problem. + $ent->header_set('Content-disposition' => 'attachment; filename="' . encode('MIME-Q', $attributes{filename}) . '"'); + push @{ $self->{mail_attachments}} , SL::DB::EmailJournalAttachment->new( name => $attributes{filename}, mime_type => $attributes{content_type}, @@ -204,12 +208,10 @@ sub _create_message { my @parts; - push @{ $self->{headers} }, (Type => "multipart/mixed"); - if ($self->{message}) { push @parts, Email::MIME->create( attributes => { - content_type => $self->{contenttype}, + content_type => $self->{content_type}, charset => $self->{charset}, encoding => 'quoted-printable', }, @@ -217,7 +219,7 @@ sub _create_message { ); push @{ $self->{headers} }, ( - 'Content-Type' => qq|$self->{contenttype}; charset="$self->{charset}"|, + 'Content-Type' => qq|$self->{content_type}; charset="$self->{charset}"|, ); } @@ -243,15 +245,15 @@ sub send { } # Set defaults & headers - $self->{charset} = 'UTF-8'; - $self->{contenttype} ||= "text/plain"; - $self->{headers} = [ - Subject => $self->{subject}, - 'Message-ID' => '<' . $self->_create_message_id . '>', - 'X-Mailer' => "kivitendo " . SL::Version->get_version, - ]; + $self->{charset} = 'UTF-8'; + $self->{content_type} ||= "text/plain"; + $self->{headers} ||= []; + push @{ $self->{headers} }, ( + Subject => $self->{subject}, + 'Message-ID' => '<' . $self->_create_message_id . '>', + 'X-Mailer' => "kivitendo " . SL::Version->get_version, + ); $self->{mail_attachments} = []; - $self->{content_by_name} = $::instance_conf->get_email_journal == 1 && $::instance_conf->get_doc_files; my $error; my $ok = eval { @@ -261,10 +263,6 @@ sub send { my $email = $self->_create_message; - #$::lxdebug->message(0, "message: " . $email->as_string); - # return "boom"; - - $::lxdebug->message(LXDebug->DEBUG2(), "mail1 from=".$self->{from}." to=".$self->{to}); my $from_obj = (Email::Address->parse($self->{from}))[0]; $self->{driver}->start_mail(from => $from_obj->address, to => [ $self->_all_recipients ]); @@ -368,7 +366,7 @@ SL::Mailer - Base class for sending mails from kivitendo =head1 OVERVIEW -Mail can be send from kivitendo via the sendmail command or the smtp protocol. +Mail can be sent from kivitendo via the sendmail command or the smtp protocol. =head1 INTERNAL DATA TYPES @@ -378,7 +376,7 @@ Mail can be send from kivitendo via the sendmail command or the smtp protocol. =item C<%mail_delivery_modules> - Currently two modules are supported either smtp or sendmail. + Currently two modules are supported: smtp or sendmail. =item C<%type_to_table> @@ -410,7 +408,7 @@ Mail can be send from kivitendo via the sendmail command or the smtp protocol. =item C - If a mail was send successfully the internal functions _store_in_journal + If a mail was sent successfully the internal function _store_in_journal is called if email journaling is enabled. If _store_in_journal was executed successfully and the calling form is already persistent (database id) a record_link will be created. @@ -423,7 +421,10 @@ Mail can be send from kivitendo via the sendmail command or the smtp protocol. If $self->{journalentry} and either $self->{record_id} or $::form->{id} (checked in - this order) exists a record link from record to email journal is created. + this order) exist a record link from record to email journal is created. + It is possible to provide an array reference with more than one id in + $self->{record_id} or $::form->{id}. In this case all records are linked to + the mail. Will fail silently if record_link creation wasn't successful (same behaviour as _store_in_journal).