Anzeige Empfänger bei Mailversand

This commit is contained in:
aschwarz
2023-05-19 14:13:40 +02:00
parent 81dcbeff7c
commit a38e8450af
3 changed files with 132 additions and 4 deletions

View File

@ -1,13 +1,15 @@
<?php
require_once("../config.inc.php");
#require('../phpmailer/class.phpmailer.php');
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;
require '../PHPMailer6/src/Exception.php';
require '../PHPMailer6/src/PHPMailer.php';
require '../PHPMailer6/src/SMTP.php';
$function = $_POST['function'];
if ($function == 'sendmail') {
$mailjumi = get_parameter(1);
$absender = get_parameter(2);
$mailpwd = get_parameter(3);
@ -114,9 +116,76 @@ try {
save_mail($mail);
echo '<div class="alert alert-success"><i class="fa fa-fw fa-thumbs-up"></i> Mail wurde versendet!</div>|***|success';
exit;
}
catch (Exception $e) {
echo "<div class='alert alert-danger'><i class='fa fa-fw fa-thumbs-down'></i> Es konnte <b>keine Mail</b> verschickt werden! Mailer Error: {$mail->ErrorInfo}</div>|***|error";
exit;
}
}
if ($function == 'showmail') {
$empfaenger = $_POST['empfaenger'];
# $empfaenger = "S-1";
$mail_bcc = array();
for ($i = 0; $i < sizeof($empfaenger); $i++) {
$trenner = explode("-", $empfaenger[$i]);
if ($trenner[0] == 'S') {
$query = "select mail, vorname, nachname
from jumi_admin a, jumi_admin_rollen_user_zuord b
where a.uid=b.uid
and b.rid=$trenner[1]";
$result = $db->query($query) or die("Cannot execute query");
while ($row = $result->fetch_array()) {
array_push($mail_bcc, "$row[vorname] $row[nachname]|$row[mail]");
}
}
if ($trenner[0] == 'C') {
$query1 = "select mail, vorname, nachname
from jumi_chor_saenger";
$result1 = $db->query($query1) or die("Cannot execute query1");
while ($row1 = $result1->fetch_array()) {
array_push($mail_bcc, "$row1[vorname] $row1[nachname]|$row1[mail]");
}
}
if ($trenner[0] == 'V') {
$query2 = "select mail, vorname, nachname
from jumi_mailverteiler a, jumi_mailverteiler_entries b, jumi_mailverteiler_user_zuord c
where a.mvid=c.mvid
and b.mveid=c.mveid
and c.mvid=$trenner[1]";
$result2 = $db->query($query2) or die("Cannot execute query2");
while ($row2 = $result2->fetch_array()) {
array_push($mail_bcc, "$row2[vorname] $row2[nachname]|$row2[mail]");
}
}
}
# Doppelte Mailadressen entfernen. Fall jemand in mehreren Gruppen aktiv ist.
$mail_bcc = array_unique($mail_bcc);
$out = array_reduce($mail_bcc, function($left, $right) {
// array_reduce startet "vor" dem ersten Wert, mit $left=null und $right="a".
// Ohne diesen bedingten Ausdruck wuerde man entsprechend in der Rueckgabe ein Komma vor dem "a" erhalten.
return ($left===null ? $right : "$left,$right");
});
echo $out;
#echo "Mailadressen";
}
?>