From 8bb2946e2ad38a935aea32c1000ccf71d88e8a9c Mon Sep 17 00:00:00 2001 From: ralf Date: Tue, 30 Jul 2024 08:43:07 +0200 Subject: [PATCH] fix error forwarding: implode(): Argument #1 ($array) must be of type array, string given --- mail/inc/class.mail_compose.inc.php | 30 ++++++++--------------------- 1 file changed, 8 insertions(+), 22 deletions(-) diff --git a/mail/inc/class.mail_compose.inc.php b/mail/inc/class.mail_compose.inc.php index edaebf2124..cc21d91470 100644 --- a/mail/inc/class.mail_compose.inc.php +++ b/mail/inc/class.mail_compose.inc.php @@ -2313,32 +2313,18 @@ class mail_compose //_debug_array($bodyParts); $styles = Mail::getStyles($bodyParts); - $fromAddress = implode(', ', $headers['FROM']); - - $toAddressA = array(); - $toAddress = ''; - foreach ($headers['TO'] as $mailheader) { - $toAddressA[] = $mailheader; - } - if (count($toAddressA)>0) + $fromAddress = $toAddress = $ccAddress = ''; + foreach(['FROM' => 'fromAddress', 'TO' => 'toAddress', 'CC' => 'ccAddress'] as $header => $var) { - $toAddress = implode(', ', $toAddressA); - $toAddress = htmlspecialchars(lang("to").": ".$toAddress).($bodyParts['0']['mimeType'] == 'text/html'?"
":"\r\n"); - } - $ccAddressA = array(); - $ccAddress = ''; - foreach ($headers['CC'] as $mailheader) { - $ccAddressA[] = $mailheader; - } - if (count($ccAddressA)>0) - { - $ccAddress = implode(', ', $ccAddressA); - $ccAddress = htmlspecialchars(lang("cc").": ".$ccAddress).($bodyParts['0']['mimeType'] == 'text/html'?"
":"\r\n"); + if (!empty($headers[$header])) + { + $$var = htmlspecialchars(lang($header).": ".implode(', ', (array)$headers[$header])). + ($bodyParts['0']['mimeType'] == 'text/html' ? "
" : "\r\n"); + } } // create original message header in users preferred font and -size $this->sessionData['body'] = self::wrapBlockWithPreferredFont( - htmlspecialchars(lang("from").": ".$fromAddress)."
". - $toAddress.$ccAddress. + $fromAddress.$toAddress.$ccAddress. htmlspecialchars(lang("date").": ".Mail::_strtotime($headers['DATE'],'r',true),ENT_QUOTES | ENT_IGNORE, Mail::$displayCharset, false), lang("original message"), 'originalMessage');