Bug 12532: (follow-up) Send email to guarantor using the CC field

In This patch the CC field is used to send the message to the guarantors. If the «to» field is empty (the guarantee has no address) we send the message «to» the garantors.

Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>
This commit is contained in:
Hammat Wele 2023-08-25 23:39:24 +00:00 committed by Tomas Cohen Arazi
parent 82a4d40890
commit 54c9b488dc
Signed by: tomascohen
GPG key ID: 0A272EA1B2F3C15F
2 changed files with 31 additions and 30 deletions

View file

@ -40,6 +40,7 @@ use Koha::Patrons;
use Koha::SMS::Providers;
use Koha::SMTP::Servers;
use Koha::Subscriptions;
use Data::Dumper;
use constant SERIALIZED_EMAIL_CONTENT_TYPE => 'message/rfc822';
@ -1317,12 +1318,23 @@ sub _send_message_by_email {
my $message = shift or return;
my ( $username, $password, $method, $smtp_transports ) = @_;
my $patron;
my $patron = Koha::Patrons->find( $message->{borrowernumber} );
my $to_address = $message->{'to_address'};
my $use_garantor = C4::Context->preference('RedirectGuaranteeEmail');
if($use_garantor eq 'yes' || !$to_address) {
$patron = Koha::Patrons->find( $message->{borrowernumber} );
unless ($patron or $to_address) {
my $cc_address;
my @guarantor_address;
my $count_guarantor_address;
if (C4::Context->preference('RedirectGuaranteeEmail') eq 'yes' && $patron) {
#Get guanrantor adresses
my $guarantor_relationships = $patron->guarantor_relationships;
my @guarantors = $guarantor_relationships->guarantors->as_list;
foreach my $guarantor (@guarantors) {
my $address = $guarantor->notice_email_address;
push( @guarantor_address, $address ) if $address;
}
$count_guarantor_address = scalar @guarantor_address;
}
unless ($to_address) {
if (!$patron && !$count_guarantor_address) {
warn "FAIL: No 'to_address' and INVALID borrowernumber ($message->{borrowernumber})";
_set_message_status(
{
@ -1336,7 +1348,7 @@ sub _send_message_by_email {
if ($patron) {
$to_address = $patron->notice_email_address;
}
unless ($to_address) {
if (!$to_address && !$count_guarantor_address) {
# warn "FAIL: No 'to_address' and no email for " . ($member->{surname} ||'') . ", borrowernumber ($message->{borrowernumber})";
# warning too verbose for this more common case?
_set_message_status(
@ -1348,8 +1360,12 @@ sub _send_message_by_email {
);
return;
}
if (!$to_address && $count_guarantor_address) {
$to_address = shift @guarantor_address;
}
}
$cc_address = join( ',', @guarantor_address );
# Skip this message if we exceed domain limits in this run
if( Koha::Notice::Util->exceeds_limit({ to => $to_address, limits => $domain_limits }) ) {
# Save the to_address if you delay the message so that we dont need to look it up again
@ -1404,6 +1420,11 @@ sub _send_message_by_email {
? ( bcc => C4::Context->preference('NoticeBcc') )
: ()
),
(
$cc_address
? ( cc => $cc_address )
: ()
),
from => $from_address,
reply_to => $message->{'reply_address'} || $branch_replyto,
sender => $branch_returnpath,

View file

@ -1579,36 +1579,16 @@ Returns the empty string if no email address.
=cut
sub notice_email_address {
my ($self) = @_;
my $address;
my $guarantor_address;
sub notice_email_address{
my ( $self ) = @_;
my $which_address = C4::Context->preference("EmailFieldPrimary");
# if syspref is set to 'first valid' (value == OFF), look up email address
if ( $which_address eq 'OFF' ) {
$address = $self->first_valid_email_address;
}
else {
$address = $self->$which_address || '';
return $self->first_valid_email_address;
}
my $use_guarantor = C4::Context->preference('RedirectGuaranteeEmail');
if ($use_guarantor) {
my @guarantors =
map { $_->guarantors->as_list } $self->guarantor_relationships();
if (@guarantors) {
foreach my $guarantor (@guarantors) {
$guarantor_address = $guarantor->notice_email_address;
if ($address) {
$address .= ', ';
}
$address .= $guarantor_address if $guarantor_address;
}
}
}
return $address;
return $self->$which_address || '';
}
=head3 first_valid_email_address