From 9d7e6ff3322d217af364eaab0f1be01ca0335d73 Mon Sep 17 00:00:00 2001 From: Laurent Destailleur Date: Wed, 20 Apr 2005 23:01:30 +0000 Subject: [PATCH] Ajout champ date_envoi et statut sur table des destinataires de mails --- scripts/mailing-send.php | 109 ++++++++++++++++++++++++++++----------- 1 file changed, 78 insertions(+), 31 deletions(-) diff --git a/scripts/mailing-send.php b/scripts/mailing-send.php index 6a2ace3267a..e06295383f6 100644 --- a/scripts/mailing-send.php +++ b/scripts/mailing-send.php @@ -38,10 +38,11 @@ */ + // Test si mode batch -$sapi_type = php_sapi_name(); -if (substr($sapi_type, 0, 3) == 'cgi') { - echo "Erreur: Vous utilisez l'interpreteur PHP pour le mode CGI. Pour executer mailing-send.php en ligne de commande, vous devez utiliser l'interpreteur PHP pour le mode CLI.\n"; +$sapi_type = php_sapi_name(); +if (substr($sapi_type, 0, 3) == 'cgi') { + echo "Erreur: Vous utilisez l'interpreteur PHP pour le mode CGI. Pour executer mailing-send.php en ligne de commande, vous devez utiliser l'interpreteur PHP pour le mode CLI.\n"; exit; } @@ -56,6 +57,8 @@ require_once (DOL_DOCUMENT_ROOT."/lib/dolibarrmail.class.php"); $error = 0; + +// On récupère données du mail $sql = "SELECT m.rowid, m.titre, m.sujet, m.body"; $sql .= " , m.email_from, m.email_replyto, m.email_errorsto"; $sql .= " FROM ".MAIN_DB_PREFIX."mailing as m"; @@ -63,14 +66,15 @@ $sql .= " WHERE m.statut >= 1"; $sql .= " AND m.rowid= ".$id; $sql .= " LIMIT 1"; -if ( $db->query($sql) ) +$resql=$db->query($sql); +if ($resql) { - $num = $db->num_rows(); + $num = $db->num_rows($resql); $i = 0; if ($num == 1) { - $obj = $db->fetch_object(); + $obj = $db->fetch_object($resql); dolibarr_syslog("mailing-send: mailing ".$id); @@ -81,46 +85,89 @@ if ( $db->query($sql) ) $errorsto = $obj->email_errorsto; $i++; - } } -$sql = "SELECT mc.nom, mc.prenom, mc.email"; + +$nbok=0; $nbko=0; + +// On choisit les mails non déjà envoyés pour ce mailing (statut=0) +// ou envoyés en erreur (statut=-1) +$sql = "SELECT mc.rowid, mc.nom, mc.prenom, mc.email"; $sql .= " FROM ".MAIN_DB_PREFIX."mailing_cibles as mc"; -$sql .= " WHERE mc.fk_mailing = ".$id; +$sql .= " WHERE mc.statut < 1 AND mc.fk_mailing = ".$id; -if ( $db->query($sql) ) +$resql=$db->query($sql); +if ($resql) { - $num = $db->num_rows(); - $i = 0; - - dolibarr_syslog("mailing-send: mailing $num cibles"); + $num = $db->num_rows($resql); - while ($i < $num ) + if ($num) { - $obj = $db->fetch_object(); + dolibarr_syslog("mailing-send: mailing $num cibles"); - $sendto = stripslashes($obj->prenom). " ".stripslashes($obj->nom) ."<".$obj->email.">"; + // Positionne date debut envoi + $sql="UPDATE ".MAIN_DB_PREFIX."mailing SET date_envoi=SYSDATE WHERE rowid=".$id; + $resql2=$db->query($sql); + if (! $resql2) + { + dolibarr_print_error($db); + } + + // Boucle sur chaque adresse et envoie le mail + $i = 0; + while ($i < $num ) + { + $obj = $db->fetch_object($resql); - $mail = new DolibarrMail($subject, - $sendto, - $from, - $message); - - $mail->errors_to = $errorsto; - - if ( $mail->sendfile() ) - { + $sendto = stripslashes($obj->prenom). " ".stripslashes($obj->nom) ."<".$obj->email.">"; + $mail = new DolibarrMail($subject, $sendto, $from, $message); + + $mail->errors_to = $errorsto; + + if ( $mail->sendfile() ) + { + // Mail envoye avec succes + $nbok++; + + $sql="UPDATE ".MAIN_DB_PREFIX."mailing_cibles SET statut=1, date_envoi=SYSDATE WHERE rowid=".$obj->rowid; + $resql2=$db->query($sql); + if (! $resql2) + { + dolibarr_print_error($db); + } + } + else + { + // Mail en echec + $nbko++; + + $sql="UPDATE ".MAIN_DB_PREFIX."mailing_cibles SET statut=1, date_envoi=SYSDATE WHERE rowid=".$obj->rowid; + $resql2=$db->query($sql); + if (! $resql2) + { + dolibarr_print_error($db); + } + } + + $i++; + } - } - - $i++; - + // Met a jour statut global du mail et date envoi + $statut=2; + $sql="UPDATE ".MAIN_DB_PREFIX."mailing SET statut=".$statut." WHERE rowid=".$id; + $resql2=$db->query($sql); + if (! $resql2) + { + dolibarr_print_error($db); + } + } } else { - dolibarr_syslog($db->error()); + dolibarr_syslog($db->error()); + dolibarr_print_error($db); } ?>