* Copyright (C) 2005-2008 Laurent Destailleur * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /** \file htdocs/comm/mailing/fiche.php \ingroup mailing \brief Fiche mailing, onglet général \version $Id$ */ require("./pre.inc.php"); require_once(DOL_DOCUMENT_ROOT."/lib/CMailFile.class.php"); $langs->load("mails"); if (! $user->rights->mailing->lire || $user->societe_id > 0) accessforbidden(); $message = ''; // Tableau des substitutions possibles $substitutionarray=array( '__ID__' => 'IdRecord', '__EMAIL__' => 'EMail', '__LASTNAME__' => 'Lastname', '__FIRSTNAME__' => 'Firstname' ); $substitutionarrayfortest=array( '__ID__' => 'TESTIdRecord', '__EMAIL__' => 'TESTEMail', '__LASTNAME__' => 'TESTLastname', '__FIRSTNAME__' => 'TESTFirstname' ); // Action envoi mailing pour tous if ($_POST["action"] == 'sendallconfirmed') { if (empty($conf->global->MAILING_LIMIT_SENDBYWEB)) { // Pour des raisons de sécurité, on ne permet pas cette fonction via l'IHM, // on affiche donc juste un message $message='
'.$langs->trans("MailingNeedCommand").'
'; $message.='
'; $message.='

'.$langs->trans("MailingNeedCommand2").'
'; $_GET["action"]=''; } else { $id=$_GET['id']; $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"; $sql .= " WHERE m.statut >= 1"; $sql .= " AND m.rowid= ".$id; $sql .= " LIMIT 1"; $resql=$db->query($sql); if ($resql) { $num = $db->num_rows($resql); $i = 0; if ($num == 1) { $obj = $db->fetch_object($resql); dolibarr_syslog("mailing-send: mailing ".$id, LOG_DEBUG); $id = $obj->rowid; $subject = $obj->sujet; $message = $obj->body; $from = $obj->email_from; $errorsto = $obj->email_errorsto; // Le message est-il en html $msgishtml=-1; // Unknown by default if (eregi('[ \t]*',$message)) $msgishtml=1; $i++; } } $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.statut < 1 AND mc.fk_mailing = ".$id; $resql=$db->query($sql); if ($resql) { $num = $db->num_rows($resql); if ($num) { dolibarr_syslog("mailing-send: nb of targets = ".$num, LOG_DEBUG); // 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 && $i < $conf->global->MAILING_LIMIT_SENDBYWEB) { $res=1; $obj = $db->fetch_object($resql); // sendto en RFC2822 $sendto = $obj->prenom." ".$obj->nom." <".$obj->email.">"; // Pratique les substitutions sur le sujet et message $substitutionarray=array( '__ID__' => $obj->rowid, '__EMAIL__' => $obj->email, '__LASTNAME__' => $obj->nom, '__FIRSTNAME__' => $obj->prenom ); $substitutionisok=true; $newsubject=make_substitutions($subject,$substitutionarray); $newmessage=make_substitutions($message,$substitutionarray); // Fabrication du mail $mail = new CMailFile($newsubject, $sendto, $from, $newmessage, array(), array(), array(), '', '', 0, $msgishtml); $mail->errors_to = $errorsto; if ($mail->error) { $res=0; } if (! $substitutionisok) { $mail->error='Some substitution failed'; $res=0; } // Envoi du mail if ($res) { $res=$mail->sendfile(); } if ($res) { // Mail envoye avec succes $nbok++; dolibarr_syslog("mailing-send: ok for #".$i.($mail->error?' - '.$mail->error:''), LOG_DEBUG); $sql="UPDATE ".MAIN_DB_PREFIX."mailing_cibles"; $sql.=" 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++; dolibarr_syslog("mailing-send: error for #".$i.($mail->error?' - '.$mail->error:''), LOG_DEBUG); $sql="UPDATE ".MAIN_DB_PREFIX."mailing_cibles"; $sql.=" SET statut=-1, date_envoi=SYSDATE() WHERE rowid=".$obj->rowid; $resql2=$db->query($sql); if (! $resql2) { dolibarr_print_error($db); } } $i++; } } // Loop finished, set global statut of mail $statut=2; // By default status with error if (! $nbko) $statut=3; $sql="UPDATE ".MAIN_DB_PREFIX."mailing SET statut=".$statut." WHERE rowid=".$id; dolibarr_syslog("mailing-send: update global status sql=".$sql, LOG_DEBUG); $resql2=$db->query($sql); if (! $resql2) { dolibarr_print_error($db); } } else { dolibarr_syslog($db->error()); dolibarr_print_error($db); } $message=''; $_GET["action"] = ''; } } // Action envoi test mailing if ($_POST["action"] == 'send' && ! $_POST["cancel"]) { $mil = new Mailing($db); $result=$mil->fetch($_POST["mailid"]); $mil->sendto = $_POST["sendto"]; if (! $mil->sendto) { $message='
'.$langs->trans("ErrorFieldRequired",$langs->trans("MailTo")).'
'; } if ($mil->sendto) { $arr_file = array(); $arr_mime = array(); $arr_name = array(); // Le message est-il en html $msgishtml=-1; // Inconnu par defaut if (eregi('[ \t]*',$message)) $msgishtml=1; // Pratique les substitutions sur le sujet et message $mil->sujet=make_substitutions($mil->sujet,$substitutionarrayfortest); $mil->body=make_substitutions($mil->body,$substitutionarrayfortest); $mailfile = new CMailFile($mil->sujet,$mil->sendto,$mil->email_from,$mil->body, $arr_file,$arr_mime,$arr_name, '', '', 0, $msgishtml); $result=$mailfile->sendfile(); if ($result) { $message='
'.$langs->trans("MailSuccessfulySent",$mil->email_from,$mil->sendto).'
'; } else { $message='
'.$langs->trans("ResultKo").'
'.$mailfile->error.' '.$result.'
'; } $_GET["action"]=''; $_GET["id"]=$mil->id; } } // Action ajout mailing if ($_POST["action"] == 'add') { $message=''; $mil = new Mailing($db); $mil->email_from = trim($_POST["from"]); $mil->titre = trim($_POST["titre"]); $mil->sujet = trim($_POST["sujet"]); $mil->body = trim($_POST["body"]); if (! $mil->titre) $message.=($message?'
':'').$langs->trans("ErrorFieldRequired",$langs->trans("MailTitle")); if (! $mil->sujet) $message.=($message?'
':'').$langs->trans("ErrorFieldRequired",$langs->trans("MailTopic")); if (! $message) { if ($mil->create($user) >= 0) { Header("Location: fiche.php?id=".$mil->id); exit; } $message=$mil->error; } $message='
'.$message.'
'; $_GET["action"]="create"; } // Action mise a jour mailing if ($_POST["action"] == 'update') { $mil = new Mailing($db); $mil->id = $_POST["id"]; $mil->email_from = $_POST["from"]; $mil->titre = $_POST["titre"]; $mil->sujet = $_POST["sujet"]; $mil->body = $_POST["body"]; if ($mil->update()) { Header("Location: fiche.php?id=".$mil->id); } } // Action confirmation validation if ($_POST["action"] == 'confirm_valide') { if ($_POST["confirm"] == 'yes') { $mil = new Mailing($db); if ($mil->fetch($_GET["id"]) >= 0) { $mil->valid($user); Header("Location: fiche.php?id=".$mil->id); exit; } else { dolibarr_print_error($db); } } else { Header("Location: fiche.php?id=".$_GET["id"]); exit; } } if ($_POST["action"] == 'confirm_approve') { if ($_POST["confirm"] == 'yes') { $mil = new Mailing($db); if ($mil->fetch($_GET["id"]) >= 0) { $mil->approve($user); Header("Location: fiche.php?id=".$mil->id); exit; } else { dolibarr_print_error($db); } } else { Header("Location: fiche.php?id=".$_GET["id"]); exit; } } // Action confirmation suppression if ($_POST["action"] == 'confirm_delete') { if ($_POST["confirm"] == 'yes') { $mil = new Mailing($db); $mil->id = $_GET["id"]; if ($mil->delete($mil->id)) { Header("Location: index.php"); } } } if ($_POST["cancel"] == $langs->trans("Cancel")) { $action = ''; } llxHeader("","","Fiche Mailing"); /* * Mailing en mode création * */ $mil = new Mailing($db); if ($_GET["action"] == 'create') { print '
'."\n"; print ''; print_titre($langs->trans("NewMailing")); if ($message) print "$message
"; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print '
'.$langs->trans("MailFrom").'
'.$langs->trans("MailTitle").'
'.$langs->trans("MailTopic").'
'.$langs->trans("MailMessage").'
'; print '
'.$langs->trans("CommonSubstitutions").':
'; foreach($substitutionarray as $key => $val) { print $key.' = '.$langs->trans($val).'
'; } print '
'; // éditeur wysiwyg if ($conf->fckeditor->enabled && $conf->global->FCKEDITOR_ENABLE_MAILING) { require_once(DOL_DOCUMENT_ROOT."/lib/doleditor.class.php"); $doleditor=new DolEditor('body','',320,'dolibarr_mailings','',true,false); $doleditor->Create(); } else { print ''; } print '
'; print '
'; } else { $html = new Form($db); if ($mil->fetch($_GET["id"]) >= 0) { $h=0; $head[$h][0] = DOL_URL_ROOT."/comm/mailing/fiche.php?id=".$mil->id; $head[$h][1] = $langs->trans("MailCard"); $hselected = $h; $h++; $head[$h][0] = DOL_URL_ROOT."/comm/mailing/cibles.php?id=".$mil->id; $head[$h][1] = $langs->trans('MailRecipients'); $h++; /* $head[$h][0] = DOL_URL_ROOT."/comm/mailing/info.php?id=".$mil->id; $head[$h][1] = $langs->trans("MailHistory"); $h++; */ dolibarr_fiche_head($head, $hselected, $langs->trans("Mailing").": ".substr($mil->titre,0,20)); // Confirmation de la validation du mailing if ($_GET["action"] == 'valide') { $html->form_confirm("fiche.php?id=".$mil->id,$langs->trans("ValidMailing"),$langs->trans("ConfirmValidMailing"),"confirm_valide"); print '
'; } // Confirmation de la suppression if ($_GET["action"] == 'delete') { $html->form_confirm("fiche.php?id=".$mil->id,$langs->trans("DeleteAMailing"),$langs->trans("ConfirmDeleteMailing"),"confirm_delete"); print '
'; } if ($_GET["action"] != 'edit') { /* * Mailing en mode visu * */ if ($_GET["action"] == 'sendall') { if (empty($conf->global->MAILING_LIMIT_SENDBYWEB)) { // Pour des raisons de sécurité, on ne permet pas cette fonction via l'IHM, // on affiche donc juste un message $message='
'.$langs->trans("MailingNeedCommand").'
'; $message.='
'; $message.='

'.$langs->trans("MailingNeedCommand2").'
'; $_GET["action"]=''; } else { $text=$langs->trans('ConfirmSendingEmailing',$conf->global->MAILING_LIMIT_SENDBYWEB); $html->form_confirm($_SERVER['PHP_SELF'].'?id='.$_REQUEST['id'],$langs->trans('SendMailing'),$text,'sendallconfirmed'); print '
'; } } print ''; print ''; print ''; print ''; print ''; print ''; $uc = new User($db, $mil->user_creat); $uc->fetch(); print ''; print ''; print ''; if ($mil->statut > 0) { $uv = new User($db, $mil->user_valid); $uv->fetch(); print ''; print ''; print ''; } if ($mil->statut > 1) { print ''; print ''; print ''; } // Sujet print ''; // Message print ''; print ''; print ''; print '
'.$langs->trans("Ref").''.$mil->id.'
'.$langs->trans("MailTitle").''.$mil->titre.'
'.$langs->trans("MailFrom").''.htmlentities($mil->email_from).'
'.$langs->trans("Status").''.$mil->getLibStatut(4).'
'.$langs->trans("TotalNbOfDistinctRecipients").''.($mil->nbemail?$mil->nbemail:''.$langs->trans("NoTargetYet").'').'
'.$langs->trans("CreatedBy").''.$uc->getNomUrl(1).''.$langs->trans("Date").''.dolibarr_print_date($mil->date_creat,"dayhour").'
'.$langs->trans("ValidatedBy").''.$uv->getNomUrl(1).''.$langs->trans("Date").''.dolibarr_print_date($mil->date_valid,"dayhour").'
'.$langs->trans("SentBy").''.$langs->trans("Unknown").''.$langs->trans("Date").''.dolibarr_print_date($mil->date_envoi,"dayhour").'
'.$langs->trans("MailTopic").''.$mil->sujet.'
'.$langs->trans("MailMessage").''; print nl2br($mil->body); print '
'; print ""; if ($_GET["action"] == 'sendall') { // Pour des raisons de sécurité, on ne permet pas cette fonction via l'IHM, // on affiche donc juste un message $message='
'.$langs->trans("MailingNeedCommand").'
'; $message.='
'; } if ($message) print "$message
"; /* * Boutons d'action */ if ($_GET["action"] == '') { print "\n\n
\n"; if ($mil->statut == 0 && $user->rights->mailing->creer) { print ''.$langs->trans("EditMailing").''; } //print ''.$langs->trans("PreviewMailing").''; print ''.$langs->trans("TestMailing").''; if ($mil->statut == 0 && $mil->nbemail > 0 && $user->rights->mailing->valider) { print ''.$langs->trans("ValidMailing").''; } if (($mil->statut == 1 || $mil->statut == 2) && $mil->nbemail > 0 && $user->rights->mailing->valider) { print ''.$langs->trans("SendMailing").''; } if ($mil->statut <= 1 && $user->rights->mailing->supprimer) { print ''.$langs->trans("DeleteMailing").''; } print '

'; } // Affichage formulaire de TEST if ($_GET["action"] == 'test') { print_titre($langs->trans("TestMailing")); // Créé l'objet formulaire mail include_once("../../html.formmail.class.php"); $formmail = new FormMail($db); $formmail->fromname = $mil->email_from; $formmail->frommail = $mil->email_from; $formmail->withsubstit=1; $formmail->withfrom=0; $formmail->withto=$user->email?$user->email:1; $formmail->withtocc=0; $formmail->withtopic=0; $formmail->withtopicreadonly=1; $formmail->withfile=0; $formmail->withbody=0; $formmail->withbodyreadonly=1; $formmail->withcancel=1; // Tableau des substitutions $formmail->substit=$substitutionarrayfortest; // Tableau des paramètres complémentaires du post $formmail->param["action"]="send"; $formmail->param["models"]="body"; $formmail->param["mailid"]=$mil->id; $formmail->param["returnurl"]=DOL_URL_ROOT."/comm/mailing/fiche.php?id=".$mil->id; $formmail->show_form(); print '
'; } } else { /* * Mailing en mode edition */ print '
'."\n"; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print '
'.$langs->trans("Ref").''.$mil->id.'
'.$langs->trans("MailTitle").'
'.$langs->trans("MailFrom").'
'.$langs->trans("MailTopic").'
'.$langs->trans("MailMessage").'
'; print '
'.$langs->trans("CommonSubstitutions").':
'; print '__ID__ = '.$langs->trans("IdRecord").'
'; print '__EMAIL__ = '.$langs->trans("EMail").'
'; print '__LASTNAME__ = '.$langs->trans("Lastname").'
'; print '__FIRSTNAME__ = '.$langs->trans("Firstname").'
'; print '
'; // éditeur wysiwyg if ($conf->fckeditor->enabled && $conf->global->FCKEDITOR_ENABLE_MAILING) { require_once(DOL_DOCUMENT_ROOT."/lib/doleditor.class.php"); $doleditor=new DolEditor('body',$mil->body,320,'dolibarr_mailings','',true,false); $doleditor->Create(); } else { print ''; } print '
'; print '
'; print ""; } } } $db->close(); llxFooter('$Date$ - $Revision$'); ?>