source: spip-zone/_plugins_/spip-listes/spip-listes_1_9_3/inc/spiplistes_meleuse.php @ 48128

Last change on this file since 48128 was 48128, checked in by paladin@…, 10 years ago

Permet d'interpréter le cookie abonné dans le courrier.

  • Property svn:keywords set to LastChangedBy LastChangedDate LastChangedRevision
File size: 27.8 KB
Line 
1<?php
2/**
3 * La meleuse s'occupe des envois de courriers dont les etiquettes ont
4 * ete preparees par la trieuse, ou dont les courriers ont ete prepares
5 * via le back-office (cas des envois de test).
6 *
7 * Pour en savoir plus,
8 * voir la documentation sur la fonction {@link spiplistes_meleuse()}.
9 * @package spiplistes
10 */
11 // $LastChangedRevision: 48128 $
12 // $LastChangedBy: paladin@quesaco.org $
13 // $LastChangedDate: 2011-05-26 09:05:00 +0000 (Thu, 26 May 2011) $
14
15/******************************************************************************************/
16/* SPIP-Listes est un systeme de gestion de listes d'abonnes et d'envoi d'information     */
17/* par email pour SPIP. http://bloog.net/spip-listes                                      */
18/* Copyright (C) 2004 Vincent CARON  v.caron<at>laposte.net                               */
19/*                                                                                        */
20/* Ce programme est libre, vous pouvez le redistribuer et/ou le modifier selon les termes */
21/* de la Licence Publique Generale GNU publiee par la Free Software Foundation            */
22/* (version 2).                                                                           */
23/*                                                                                        */
24/* Ce programme est distribue car potentiellement utile, mais SANS AUCUNE GARANTIE,       */
25/* ni explicite ni implicite, y compris les garanties de commercialisation ou             */
26/* d'adaptation dans un but specifique. Reportez-vous a la Licence Publique Generale GNU  */
27/* pour plus de details.                                                                  */
28/*                                                                                        */
29/* Vous devez avoir recu une copie de la Licence Publique Generale GNU                    */
30/* en meme temps que ce programme ; si ce n'est pas le cas, ecrivez a la                  */
31/* Free Software Foundation,                                                              */
32/* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, Etats-Unis.                   */
33/******************************************************************************************/
34
35if (!defined('_ECRIRE_INC_VERSION')) return;
36
37include_spip('inc/spiplistes_api_globales');
38
39/**
40 * Envoie le courrier pret au depart
41 *
42 * Prend dans le panier des courriers a envoyer (spip_courriers) les encours
43 * - formate le titre, texte pour l'envoi
44 *
45 *
46 * les etiquettes sont dans la queue d'envois (spip_auteurs_courriers)
47 * - id_auteur (pour reprendre l'adresse mail de id_auteur)
48 * - id_courrier (le courrier a dupliquer/envoyer)
49 *
50 * la queue (spip_auteurs_courriers) a ete remplie par cron_spiplistes_cron()
51 * se sert de la queue pour ventiler les envois par lots
52
53 * le courrier (spip_courriers) doit avoir date <= time() et statut 'encour'
54 * si email_test, la meleuse envoie le courrier a email_test,
55 *  supprime email_test du courrier
56 *  et repositionne le statut du courrier en 'redac'
57 * si pas email_test mais id_liste,
58 *  regarde la queue d'envois (spip_auteurs_courriers)
59 *  et passe le statut du courrier (spip_courriers) a :
60 *              'publie' si type == 'nl' (newsletter)
61 *              'auto' si type == 'auto' (liste programmee)
62 *      et envoie les courriers precises aux abonnes de cette liste
63 *      et supprime l'identifiant du courrier dans la queue d'envois (spip_auteurs_courriers)
64
65 * renvoie:
66 * - nul, si la tache n'a pas a etre effectuee
67 * - positif, si la tache a ete effectuee
68 * - negatif, si la tache doit etre poursuivie ou recommencee
69 *
70 * @param int $last_time
71 * @return int
72 */
73function spiplistes_meleuse ($last_time) {
74
75        //spiplistes_debug_log('spiplistes_meleuse()');
76       
77        include_spip('inc/meta');
78        include_spip('inc/texte');
79        include_spip('inc/filtres');
80        include_spip('inc/acces');
81        include_spip('inc/spiplistes_api');
82        include_spip('inc/spiplistes_api_courrier');
83       
84        include_once(_DIR_PLUGIN_SPIPLISTES.'inc/spiplistes_mail.inc.php');
85
86        // initialise les options (preferences)
87        foreach(array(
88                'opt_simuler_envoi'
89                , 'opt_suspendre_meleuse'
90                , 'opt_lien_en_tete_courrier', 'lien_patron'
91                , 'opt_ajout_pied_courrier', 'pied_patron'
92                , 'opt_ajout_tampon_editeur'
93                , 'opt_personnaliser_courrier'
94                , 'opt_log_voir_destinataire'
95                , 'opt_ajout_lien_desabo'
96                ) as $key) {
97                $$key = spiplistes_pref_lire($key);
98        }
99       
100        $sql_vide = sql_quote('');
101        $nb_etiquettes = spiplistes_courriers_en_queue_compter('etat='.$sql_vide);
102       
103       
104        $prefix_log = _SPIPLISTES_PREFIX_LOG;
105       
106        // si meleuse suspendue, signale en log
107        if($opt_suspendre_meleuse == 'oui') {
108                spiplistes_log($prefix_log.'SUSPEND MODE !!!');
109                return(0 - $last_time);
110        }
111
112        if($nb_etiquettes) {
113               
114                $eol = "\n";
115                $eol2 =$eol.$eol;
116                $body_html_debut = '<html>'
117                        . $eol2
118                        . '<body TOPMARGIN=0 LEFTMARGIN=0 MARGINHEIGHT=0 MARGINWIDTH=0 style="margin:0;padding:0;">'
119                        . $eol2;
120                $body_html_fin = $eol2.'</body></html>';
121                $charset_spip = $GLOBALS['meta']['charset'];
122                $charset_dest = $GLOBALS['meta']['spiplistes_charset_envoi'];
123
124                spiplistes_log($prefix_log.$nb_etiquettes.' job(s), distribution...');
125               
126                $log_voir_destinataire = ($opt_log_voir_destinataire == 'oui');
127                $simuler_envoi = ($opt_simuler_envoi == 'oui');
128               
129                // signale en log si mode simulation
130                if($simuler_envoi) {
131                        spiplistes_log($prefix_log.'SIMULATION MODE !!!');
132                }
133
134                // prepare le tampon editeur
135                if($opt_ajout_tampon_editeur == 'oui')
136                {
137                        list($tampon_html, $tampon_texte) = spiplistes_tampon_assembler_patron();
138                }
139                else {
140                        $tampon_html = $tampon_texte = '';
141                }
142               
143                // prendre la premiere etiquette sur le tas et traiter son courrier
144                $sql_courrier_select = array(
145                        'titre', 'texte', 'message_texte', 'type'
146                        , 'id_courrier', 'id_liste', 'email_test', 'total_abonnes', 'date_debut_envoi'
147                        );
148                if($id_courrier = 
149                        intval(spiplistes_courriers_en_queue_premier('id_courrier', 'etat='.$sql_vide))
150                ) {
151                        $sql_courrier_a_traiter = spiplistes_courriers_casier_premier(
152                                  $sql_courrier_select
153                                , 'id_courrier='.sql_quote($id_courrier)
154                        );
155                        spiplistes_debug_log ($prefix_log.'etiquette en cours pour id_courrier #'.$id_courrier);
156                } else {
157                        // un vieux bug dans une ancienne version, eradique depuis (j'espere ;-)
158                        //spiplistes_log($prefix_log."premiere etiquette en erreur. id_courier = 0. Supprimer cette etiquette manuellement !");
159                        spiplistes_log(_T('spiplistes:erreur_queue_supprimer_courrier'
160                                                          , array('s' => $prefix_log))
161                                                   );
162                }
163               
164                // boucle (sur LIMIT 1) pour pouvoir sortir par break si erreur
165                while($row = sql_fetch($sql_courrier_a_traiter)) {
166               
167                        foreach($sql_courrier_select as $key) {
168                                $$key = $row[$key];
169                        }
170                        foreach(array('id_courrier','id_liste','total_abonnes') as $key) {
171                                $$key = intval($$key);
172                        }
173                        // objet (subject) ne peut pas être en html ?!
174                        // sauf pour le webmail (et encore)
175                        $objet_html = filtrer_entites(typo(spiplistes_calculer_balise_titre(extraire_multi($titre))));
176                        $page_html = stripslashes($texte);
177                        $message_texte = stripslashes($message_texte);
178                       
179                        $nb_emails = array();
180                       
181                        // compteur pour la session uniquement
182                        // le total de chaque sera ajoute en fin de session
183                        $nb_emails_envoyes =
184                                $nb_emails_echec = 
185                                $nb_emails_non_envoyes = 
186                                $nb_emails['texte'] = 
187                                $nb_emails['html'] = 0
188                                ;
189                       
190                        $str_log = 'id_courrier #'.$id_courrier;
191                       
192                        //////////////////////////
193                        // Determiner email de l emetteur
194                        if($is_a_test = email_valide($email_test)) {
195                                // courrier a destination adresse email de test
196                                $str_log .= ' TO: '.$email_test.' (TEST)';
197                        } 
198                        else if($id_liste > 0) {
199                                // courrier a destination des abonnes d'une liste
200                                $total_abonnes = spiplistes_listes_nb_abonnes_compter($id_liste);
201                                $str_log .= ' TO id_liste #'.$id_liste.' ('.$total_abonnes.' users)';
202       
203                                $lang = spiplistes_listes_langue($id_liste);
204
205                                if($lang != '') {
206                                        $GLOBALS['spip_lang'] = $lang;
207                                }
208                               
209                                $contexte = array('lang' => $lang);
210                               
211                                list($pied_html, $pied_texte) = spiplistes_pied_page_assembler_patron($id_liste, $lang);
212                        }
213                        else {
214                                // erreur dans un script d'appel ? Ou url ? Ou base erreur ?
215                                $str_log .= ' [ERROR] MISSING PARAMS (id_liste AND email_test)';
216                                spiplistes_courrier_statut_modifier($id_courrier, _SPIPLISTES_COURRIER_STATUT_ERREUR);
217                                // quitte while() principal
218                                break;
219                        }
220                       
221                        //////////////////////////////
222                        // email emetteur
223                        $email_envoi = spiplistes_listes_email_emetteur($id_liste);
224                        if(!$is_a_test && !($email_envoi)) { 
225                                $str_log .= ' [ERROR] ID_LISTE #'.$id_liste.' or from email MISSING'; 
226                                spiplistes_courrier_statut_modifier($id_courrier, _SPIPLISTES_COURRIER_STATUT_ERREUR);
227                                // quitte while() principal
228                                break;
229                        }
230                        $from = $email_envoi;
231                        if($from_valide = email_valide($from)) {
232                                if(strpos($from, '<') === false) {
233                                        $fromname = spiplistes_nom_site_texte ($lang);
234                                        $fromname = extraire_multi($GLOBALS['meta']['nom_site']);
235                                        if ($charset_dest!=$charset_spip)
236                                        {
237                                                include_spip('inc/charsets');
238                                                $fromname = unicode2charset(charset2unicode($fromname),$charset_dest);
239                                        }
240                                }
241                        }
242                        else {
243                                spiplistes_log('[ERROR] from address incorrect: '.$from);
244                                if($is_a_test) {
245                                        spiplistes_courriers_statut_redac ($id_courrier);
246                                }
247                                // break; // garder pour incrementer les erreurs des listes
248                        }
249                       
250                        $email_reply_to = spiplistes_pref_lire_defaut('email_reply_to', $from);
251                       
252                        $return_path = spiplistes_pref_lire_defaut('email_return_path_defaut', $from);
253                       
254                        ////////////////////////////////////
255                        // Prepare la version texte
256                        $objet_texte = $titre;
257                        $page_texte = ($message_texte !='')
258                                ? $message_texte
259                                : spiplistes_courrier_version_texte($page_html)
260                                ;
261                       
262                        ////////////////////////////////////
263                        // Ajoute lien tete de courrier
264                        if(
265                                ($opt_lien_en_tete_courrier == 'oui') 
266                                && !empty($lien_patron)
267                        ) {
268                                list($lien_html, $lien_texte) = spiplistes_courriers_assembler_patron (
269                                        _SPIPLISTES_PATRONS_TETE_DIR . $lien_patron
270                                        , array('id_courrier' => $id_courrier
271                                                        , 'lang' => $lang)
272                                        );
273                                $page_html = $lien_html . $page_html;
274                                $page_texte = $lien_texte . $page_texte;
275                        }
276
277                        ////////////////////////////////////
278                        // La petite ligne du renvoi du cookie pour modifier son abonnement
279                        //$pied_rappel_html = _T('spiplistes:modif_abonnement_html');
280                        //$pied_rappel_texte = _T('spiplistes:modif_abonnement_text');
281                       
282                        // transcrire le contenu
283                        if ($charset_dest != $charset_spip)
284                        {
285                                spiplistes_debug_log ('TRANSLATION '.$charset_spip.' TO '.$charset_dest);
286                               
287                                include_spip('inc/charsets');
288                                foreach(array(
289                                          'objet_html', 'objet_texte'
290                                        , 'page_html', 'page_texte'
291                                        , 'pied_html', 'pied_texte'
292                                        //, 'pied_rappel_html', 'pied_rappel_texte'
293                                        , 'tampon_html', 'tampon_texte') as $key) 
294                                {
295                                        if(!empty($$key)) {
296                                                $$key = spiplistes_translate_2_charset(
297                                                        $$key
298                                                        , $charset_dest
299                                                        , (strpos($key, 'texte') === false)
300                                                        );
301                                        }
302                                }
303                        }
304                       
305                        // corrige les liens relatifs (celui de texte a deja ete corrige par la trieuse (cron)
306                        foreach(array('pied_html', 'pied_texte'
307                                //, 'pied_rappel_html', 'pied_rappel_texte'
308                                , 'tampon_html', 'tampon_texte') as $key) {
309                                if(!empty($$key)) {
310                                        $$key = spiplistes_liens_absolus ($$key);
311                                }
312                        }
313
314                        /**
315                         * Adapter le CSS
316                         */
317                        foreach(array(
318                                  'objet_html'
319                                , 'page_html'
320                                , 'pied_html'
321                                //, 'pied_rappel_html', 'pied_rappel_texte'
322                                , 'tampon_html') as $key) 
323                        {
324                                if(!empty($$key)) {
325                                        $$key = spiplistes_html_styles_inline ($$key);
326                                }
327                        }
328                       
329                        $email_a_envoyer = array();
330                        $email_a_envoyer['texte'] = new phpMail('', $objet_texte, ''
331                                                                                                        , $page_texte, $charset_dest);
332                        $email_a_envoyer['texte']->From = $from ; 
333                        if($fromname) $email_a_envoyer['texte']->FromName = $fromname ;
334                        // Errors-To:,    Non-standard @see: http://www.ietf.org/rfc/rfc2076.txt
335                        //$email_a_envoyer['texte']->AddCustomHeader('Errors-To: '.$return_path);
336                        $email_a_envoyer['texte']->AddCustomHeader('Reply-To: '.$email_reply_to); 
337                        $email_a_envoyer['texte']->AddCustomHeader('Return-Path: '.$return_path); 
338                        $email_a_envoyer['texte']->SMTPKeepAlive = true;
339
340                        //$email_a_envoyer['html'] = new phpMail('', $objet_html, $page_html, $page_texte, $charset_dest);
341                        $email_a_envoyer['html'] = new phpMail(''
342                                                                                                   , $objet_html
343                                                                                                   , $page_html
344                                                                                                   , $page_texte
345                                                                                                   , $charset_dest
346                                                                                                   );
347                        $email_a_envoyer['html']->From = $from ; 
348                        if($fromname) {
349                                $email_a_envoyer['html']->FromName = $fromname ;
350                        }
351                        //$email_a_envoyer['html']->AddCustomHeader('Errors-To: '.$return_path);
352                        $email_a_envoyer['html']->AddCustomHeader('Reply-To: '.$email_reply_to); 
353                        $email_a_envoyer['html']->AddCustomHeader('Return-Path: '.$return_path);       
354                        $email_a_envoyer['html']->SMTPKeepAlive = true;
355               
356                        $str_log .= ' REPLY-TO: '.$email_reply_to.' RETURN-PATH: '.$return_path;
357                       
358                        if($total_abonnes) {
359               
360                                $limit = intval($GLOBALS['meta']['spiplistes_lots']); // nombre de messages envoyes par boucles.       
361                               
362                                if($is_a_test) {
363                                        $sql_adresses_dest = sql_select('id_auteur,nom,email', 'spip_auteurs'
364                                                , 'email='.sql_quote($email_test).' LIMIT 1');
365                                }
366                                else {
367                                        // Pour memo: les etiquettes sont creees par la trieuse
368                                        // ou directement en backoffice
369                                        // - pour les envois de test
370                                        // - pour les envoyer maintenant des courriers
371                                       
372                                        // Traitement d'une liasse d'etiquettes
373                                        // un id pour ce processus (le tampon est unique par liasse)
374                                        $id_process = intval(substr(creer_uniqid(),0,5));
375                                        $prefix_log .= '['.$id_process.'] ';
376                       
377                                        // un coup de tampon sur les etiquettes
378                                        // des courriers qui vont partir
379                                        spiplistes_courriers_en_queue_modifier(
380                                                array(
381                                                          'etat' => sql_quote($id_process))
382                                                        , 'etat='.$sql_vide.' AND id_courrier='.sql_quote($id_courrier).' LIMIT '.$limit
383                                        );
384                                       
385                                        // prendre la liasse des etiquettes tamponnees
386                                        $sql_adresses_dest = sql_select(
387                                                  array('a.nom', 'a.id_auteur', 'a.email')
388                                                , array('spip_auteurs AS a', 'spip_auteurs_courriers AS b')
389                                                , array(
390                                                        'etat='.sql_quote($id_process)
391                                                        , 'a.id_auteur=b.id_auteur'
392                                                        , 'b.id_courrier='.sql_quote($id_courrier)
393                                                        )
394                                                , 'a.email'
395                                        );
396                                }
397                                       
398                                $nb_destinataires = sql_count($sql_adresses_dest);
399                                spiplistes_log($prefix_log.'nb etiquettes a traiter: '.$nb_destinataires);
400                                if($nb_destinataires > 0) {
401
402                                        spiplistes_debug_log($prefix_log.'total_abos: '.$total_abonnes.', en cours: '.$nb_destinataires.', limit: '.$limit);
403
404/*
405// CP:20100215: inutile de compter AVANT
406// si process en //, le chiffre est faux
407                                        // replacer les compteurs
408                                        if($row = sql_fetch(sql_select(
409                                                "nb_emails_envoyes,nb_emails_echec,nb_emails_non_envoyes,nb_emails_texte,nb_emails_html"
410                                                , 'spip_courriers'
411                                                , 'id_courrier='.sql_quote($id_courrier)
412                                                , '', '', 1
413                                                ))
414                                        ) {
415                                                $nb_emails_envoyes = intval($row['nb_emails_envoyes']);
416                                                $nb_emails_echec = intval($row['nb_emails_echec']);
417                                                $nb_emails_non_envoyes = intval($row['nb_emails_non_envoyes']);
418                                                $nb_emails['texte'] = intval($row['nb_emails_texte']);
419                                                $nb_emails['html'] = intval($row['nb_emails_html']);
420                                        }
421*/
422
423                                        //envoyer le lot d'emails selectionne' (la liasse)
424                                        while($adresse = sql_fetch($sql_adresses_dest)) {
425
426                                                if($log_voir_destinataire) {
427                                                        $str_temp = '';
428                                                }
429
430                                                $id_auteur = intval($adresse['id_auteur']);
431                                                $nom_auteur = $adresse['nom'];
432                                                $email = $adresse['email'];
433
434                                                // Marquer le debut de l'envoi
435                                                if(!intval($date_debut_envoi)) {
436                                                        spiplistes_courrier_modifier ($id_courrier, array('date_debut_envoi' => 'NOW()'), false);
437                                                }
438                               
439                                                $format_abo = spiplistes_format_abo_demande($id_auteur);
440
441                                                $total++;
442                                                if($log_voir_destinataire) {
443                                                        $str_temp .= $nom_auteur.'('.$format_abo.') - '.$email;
444                                                }
445                                                unset ($cookie);
446               
447                                                if(($format_abo=='html') || ($format_abo=='texte')) {
448                                                        $cookie = creer_uniqid();
449                                                        spiplistes_auteurs_cookie_oubli_updateq($cookie, $email);
450               
451                                                        if($from_valide) {
452                                                                //$_url = generer_url_public('abonnement','d='.$cookie);
453                                                               
454                                                                if($opt_personnaliser_courrier == 'oui') {
455                                                                        list($ventre_html, $ventre_texte) = spiplistes_personnaliser_courrier(
456                                                                                                                                                        $page_html
457                                                                                                                                                        , $page_texte
458                                                                                                                                                        , $id_auteur
459                                                                                                                                                        , $format_abo
460                                                                                                                                                );
461                                                                }
462                                                                else {
463                                                                        $ventre_html = $page_html;
464                                                                        $ventre_texte = $page_texte;
465                                                                }
466                                                                // le &amp; semble poser probleme sur certains MUA. A suivre...
467                                                                //$_url = preg_replace(',(&amp;),','&', $_url);
468                                                               
469                                                               
470                                                                /**
471                                                                 * Insérer le pied de rappel
472                                                                 * qui permet de gérer l'abonnement
473                                                                 *
474                                                                 * Rajoute le lien si la pseudo
475                                                                 * balise _COOKIE_ABONNE_ est absente du courrier
476                                                                 */
477                                                                $new_html = spiplistes_personnaliser_cookie (
478                                                                                $ventre_html
479                                                                                , $cookie);
480                                                                if ($new_html === FALSE)
481                                                                {
482                                                                        /**
483                                                                         * Pour le moment (27/03/2011), un seul patron connu
484                                                                         */
485                                                                        $lien_rappel = 'lien_standard';
486                                                                       
487                                                                        list($pied_rappel_html, $pied_rappel_texte) = spiplistes_courriers_assembler_patron (
488                                                                                _SPIPLISTES_PATRONS_LIEN_DIR . $lien_rappel
489                                                                                , array('id_courrier' => $id_courrier
490                                                                                                , 'id_liste' => $id_liste
491                                                                                                , '_url' => generer_url_public('')
492                                                                                                , 'lang' => $lang
493                                                                                                , 'd' => $cookie
494                                                                                                , 'lien_desabo' => ($opt_ajout_lien_desabo == 'oui')
495                                                                                                )
496                                                                        );
497                                                                        $pied_rappel_texte = spiplistes_translate_2_charset ($pied_rappel_texte
498                                                                                                                                                                                 , $charset_dest
499                                                                                                                                                                                 , true);
500                                                                }
501                                                                else {
502                                                                        $ventre_html = $new_html;
503                                                                        $ventre_texte = spiplistes_personnaliser_cookie (
504                                                                                $ventre_texte
505                                                                                , $cookie);
506                                                                }
507                                                       
508                                                                switch($format_abo) {
509                                                                        case 'html':
510                                                                                // Si on ne trouve pas les tags HTML alors on les ajoutes
511                                                                                if (FALSE === strpos($ventre_html, '</html>')) {
512                                                                                        $email_a_envoyer[$format_abo]->Body =
513                                                                                                  $body_html_debut . $eol
514                                                                                                . $ventre_html . $eol
515                                                                                                . $pied_html . $eol
516                                                                                                . $pied_rappel_html . $eol
517                                                                                                . $tampon_html . $eol
518                                                                                                . $body_html_fin
519                                                                                                ;                                                                               
520                                                                                } else {
521                                                                                        // Si on trouve les tags HTML cela veut dire que l'auteur
522                                                                                        // veut pouvoir gerer lui meme la partie <head> ainsi que le lien de desabonnement
523                                                                                        // donc on ne prend en compte que la partie ventre_html.
524                                                                                        $tags_perso = array('http://%URL_ABONNEMENT%' => generer_url_public('abonnement','d='.$cookie),);
525                                                                                        $email_a_envoyer[$format_abo]->Body = str_replace(array_keys($tags_perso), array_values($tags_perso), $ventre_html);
526                                                                                }
527                                                                                // la version alternative texte
528                                                                                $email_a_envoyer[$format_abo]->AltBody = 
529                                                                                        $ventre_texte .$eol2
530                                                                                        . $pied_texte . $eol2
531                                                                                        . $pied_rappel_texte . $eol2
532                                                                                        . $tampon_texte
533                                                                                        ;
534                                                                                break;
535                                                                        case 'texte':
536                                                                                $email_a_envoyer[$format_abo]->Body =
537                                                                                        $ventre_texte .$eol2
538                                                                                        . $pied_texte . $eol2
539                                                                                        . $pied_rappel_texte . $eol2
540                                                                                        . $tampon_texte
541                                                                                        ;
542                                                                                break;
543                                                                }
544
545                                                                $email_a_envoyer[$format_abo]->SetAddress($email, $nom_auteur);
546                                                                // envoie le mail                                                                                                                               
547                                                                if($simuler_envoi || $email_a_envoyer[$format_abo]->send()) {
548                                                                        $nb_emails_envoyes++;
549                                                                        $nb_emails[$format_abo]++;
550                                                                        if($log_voir_destinataire) {
551                                                                                $str_temp .= '  [OK]';
552                                                                        }
553                                                                }
554                                                                else {
555                                                                        $nb_emails_echec++;
556                                                                        if($log_voir_destinataire) {
557                                                                                $str_temp .= _T('spiplistes:erreur_mail');
558                                                                        }
559                                                                }
560                                                        }
561                                                        else {
562                                                                $nb_emails_echec++;
563                                                                if($log_voir_destinataire) {
564                                                                        $str_temp .= _T('spiplistes:sans_adresse');
565                                                                }
566                                                        } 
567                                                       
568                                                } // end if(($format_abo=='html') || ($format_abo=='texte'))
569                                                else { 
570                                                        $nb_emails_non_envoyes++; 
571                                                        if($log_voir_destinataire) {
572                                                                $str_temp .= ' '._T('spiplistes:msg_abonne_sans_format');
573                                                        }
574                                                        // prevenir qu'il manque le format
575                                                        spiplistes_log($prefix_log.' destination format MISSING FOR ID_AUTEUR #'.$id_auteur);
576                                                } /* fin abo*/
577                                               
578                                                if($log_voir_destinataire) {
579                                                        spiplistes_log($prefix_log.$str_temp);
580                                                }
581                                               
582                                        } // fin while
583                                       
584                                        // supprime la liasse de la queue d'envois
585                                        spiplistes_debug_log($prefix_log."envoi OK. Supprimer queue $id_process");
586                                        spiplistes_courriers_en_queue_supprimer('etat='.sql_quote($id_process));
587                                       
588                                        // si c'est un test on repasse le courrier en redac
589                                        if($is_a_test) {
590                                                spiplistes_courriers_statut_redac ($id_courrier);
591                                        }
592                                        $email_a_envoyer['texte']->SmtpClose();
593                                        $email_a_envoyer['html']->SmtpClose();
594                                } // end if
595                        }
596                        else {
597                                //aucun destinataire connu pour ce message
598                                spiplistes_debug_log($prefix_log._T('spiplistes:erreur_sans_destinataire')
599                                                                         . '---' . _T('spiplistes:envoi_annule')
600                                                                         );
601                                spiplistes_courrier_statut_modifier($id_courrier, _SPIPLISTES_COURRIER_STATUT_IGNORE);
602                                spiplistes_courrier_supprimer_queue_envois('id_courrier', $id_courrier);
603                                $str_log .= ' END #'.$id_courrier;
604                                //
605                                break;
606                        }
607
608                        if(!$is_a_test) {
609                                // faire le bilan apres l'envoi d'un lot
610                                $sql_set_array = array(
611                                          'nb_emails_envoyes' => sql_quote('nb_emails_envoyes').'+'.$nb_emails_envoyes
612                                        , 'nb_emails_texte' => sql_quote('nb_emails_texte').'+'.$nb_emails['texte']
613                                        , 'nb_emails_html' => sql_quote('nb_emails_html').'+'.$nb_emails['html']
614                                );
615                                if($nb_emails_echec) {
616                                        $sql_set_array['nb_emails_echec'] = sql_quote('nb_emails_echec').'+'.$nb_emails_echec;
617                                }
618                                if($nb_emails_non_envoyes) {
619                                        $sql_set_array['nb_emails_non_envoyes'] = sql_quote('nb_emails_non_envoyes').'+'.$nb_emails_non_envoyes;
620                                }
621
622                                spiplistes_log($prefix_log.$str_log);
623                               
624                                $str_log = spiplistes_trace_compteur ($id_courrier
625                                                                                                   , $nb_emails_envoyes
626                                                                                                   , $nb_emails['html']
627                                                                                                   , $nb_emails['texte']
628                                                                                                   , $nb_emails_non_envoyes
629                                                                                                   , $nb_emails_echec
630                                                                                                   , 'SESSION');
631
632                                // si courrier pas termine, redemande la main au CRON, sinon nettoyage.
633                                if($t = spiplistes_courriers_en_queue_compter('id_courrier='.sql_quote($id_courrier))) {
634                                        $str_log .= ' LEFT '.$t.' jobs'; 
635                                }
636                                else {
637                                        $statut = ($type == _SPIPLISTES_COURRIER_TYPE_NEWSLETTER) ? _SPIPLISTES_COURRIER_STATUT_PUBLIE : _SPIPLISTES_COURRIER_STATUT_AUTO;
638                                        spiplistes_debug_log($prefix_log."nouveau statut $statut");
639                                        $sql_set_array['statut'] = sql_quote($statut);
640                                        $sql_set_array['date_fin_envoi'] = 'NOW()';
641                                        $str_log .= ' END #'.$id_courrier;
642                                }
643                                spiplistes_courrier_modifier($id_courrier, $sql_set_array, false);
644                               
645                                // placer en log le suivi des compteurs si mode debug
646                                if (spiplistes_debug_log())
647                                {                                       
648                                        if ($row = sql_fetch(sql_select(
649                                                'nb_emails_envoyes,nb_emails_echec,nb_emails_non_envoyes,nb_emails_texte,nb_emails_html'
650                                                , 'spip_courriers'
651                                                , 'id_courrier='.sql_quote($id_courrier)
652                                                , '', '', 1
653                                                ))
654                                        ) {
655                                                spiplistes_log($prefix_log.$str_log);
656                                               
657                                                $str_log = spiplistes_trace_compteur ($id_courrier
658                                                                                                   , $row['nb_emails_envoyes']
659                                                                                                   , $row['nb_emails_html']
660                                                                                                   , $row['nb_emails_texte']
661                                                                                                   , $row['nb_emails_non_envoyes']
662                                                                                                   , $row['nb_emails_echec']
663                                                                                                   , 'FROM_DB')
664                                                                                                . ' END #'.$id_courrier;
665                                                                                                ;
666                                        }
667                                }
668                               
669                        }
670                } // end while()
671        } // end if($nb_etiquettes)
672        else {
673                $str_log = 'no job'; 
674        }
675
676        spiplistes_log($prefix_log.$str_log);
677
678        if(($ii = spiplistes_courriers_total_abonnes()) > 0) {
679                // il en reste apres la meleuse ? Signale au CRON tache non terminee
680                $nb_etiquettes = spiplistes_courriers_en_queue_compter('etat='.$sql_vide);
681                spiplistes_log($prefix_log.'courriers prets au depart ('.$nb_etiquettes.'/'.$ii.')');
682                $last_time = -$last_time;
683        }
684       
685        return($last_time);
686} // end spiplistes_meleuse()
687
688
689
690/**
691 * Remplacer les url_site
692 *
693 * Ex., pour url_site = "foo.bar" :
694 * _HREF_AUTEUR_URL_SITE_ = "href='http://foo.bar'"
695 * _AUTEUR_URL_SITE_ = "foo.bar"
696 *
697 * @author CP
698 * @version 20090426
699 * @return string
700 */
701function spiplistes_personnaliser_courrier_urls ($txt, $url) {
702
703        // commencer par href (voir patron details_auteurs pour exemple)
704        if(!empty($url)) {
705                $txt = preg_replace("@(_HREF_AUTEUR_URL_SITE_)@"
706                                                        , " href='" . ((!preg_match(',^https?://.+$,', $url)) ? "http://" : "") . $url . "'"
707                                                        , $txt);
708        }
709        // et url_site seul
710        $txt = preg_replace("@(_AUTEUR_URL_SITE_)@", $url, $txt);
711        return($txt);
712}
713
714/**
715 * Personnalisation du courrier
716 *
717 * Recherche/remplace les tags _AUTEUR_CLE_ dans le corps du message.
718 * (toutes les cles presentes dans la table *_auteur sont utilisables)
719 * @author CP
720 * @version 20080608
721 * @param string $page_html
722 * @param string $page_texte
723 * @param int $id_auteur
724 * @param string $format_abo
725 * @return array
726 */
727function spiplistes_personnaliser_courrier ($page_html, $page_texte, $id_auteur, $format_abo) {
728
729        $result_html = $result_texte = "";
730       
731        //if($auteur = sql_fetsel("*", 'spip_auteurs', "id_auteur=".sql_quote($id_auteur), '','', 1)) {
732        if ($auteur = spiplistes_auteurs_auteur_select ('*', 'id_auteur='.sql_quote($id_auteur)))
733        {
734                $ii = 0;
735                $pattern = array();
736                $replace = array();
737                krsort($auteur);
738                foreach($auteur as $key => $val) {
739                        if($key == "url_site") continue;
740                        $pattern[$ii] = ",(_AUTEUR_" . strtoupper($key) .")_,";
741                        $replace[$ii] = $auteur[$key];
742                        $ii++;
743                }
744                $url = trim($auteur['url_site']);
745               
746                if($format_abo == 'html') {
747                        $result_html = preg_replace($pattern, $replace, $page_html);
748                       
749                        // traiter url_site a part (href et corrige' par l'assembleur ou un filtre en amont)
750                        $result_html = spiplistes_personnaliser_courrier_urls ($result_html, $url);
751                }
752               
753                $result_texte = preg_replace($pattern, $replace, $page_texte);
754                $result_texte = spiplistes_personnaliser_courrier_urls($result_texte, $url);
755               
756                spiplistes_debug_log(_SPIPLISTES_PREFIX_LOG.'personnalisation du courrier pour id_auteur #'.$id_auteur);
757        } 
758        return(array($result_html, $result_texte));
759}
760
761/**
762 * Si la pseudo balise _COOKIE_ABONNE_ est détectée
763 * dans le courrier, remplace par le cookie
764 * et confirme la modification pour éviter
765 * l'insertion du pied de rappel
766 *
767 * @param string $texte
768 * @param string $cookie
769 * @staticvar string $tag
770 * @return bool|string
771 */
772function spiplistes_personnaliser_cookie ($texte, $cookie) {
773       
774        static $tag = '_COOKIE_ABONNE_';
775       
776        if (($r = strpos($texte, $tag)) !== FALSE)
777        {
778                $r = str_replace ($tag, $cookie, $texte);
779        }
780        return ($r);
781}
782
783/**
784 * Repasse un courrier en mode redac (en general, un test d'envoi)
785 *
786 * Change le statut d'un courrier pour <em>en cours</em>.
787 * @param int $id_courrier
788 * @return boolean
789 */
790function spiplistes_courriers_statut_redac ($id_courrier) {
791        spiplistes_courrier_modifier(
792                $id_courrier
793                , array(
794                        'email_test' => ''
795                        , 'total_abonnes' => 0
796                        , 'statut' => _SPIPLISTES_COURRIER_STATUT_REDAC
797                )                                               
798        );
799        spiplistes_debug_log(_SPIPLISTES_PREFIX_LOG.'repasse document en statut redac');
800        return(true);
801}
802
803/**
804 * Renvoie une ligne pour tracer les envois dans le log
805 *
806 * Permet de completer le log par les compteurs d'envoi
807 * (nb mails envoyes, dans quel format, ...)
808 * @author CP
809 * @version 20110421
810 * @param int $id identificateur du courrier
811 * @param int $sent nombre de mails envoyes
812 * @param int $html au format html
813 * @param int $text
814 * @param int $none sans format
815 * @param int $echec nombre d'echecs
816 * @param string $type
817 * @return string
818*/
819function spiplistes_trace_compteur ($id, $sent, $html, $text, $none, $echec, $type='TOTAL')
820{
821        $str = $type.': id_courrier #'.$id
822                // nombre total de courrier transmis
823                .' SENT: '.$sent
824                // dont aux formats
825                .' (HTML: '.$html.', TEXT: '.$text
826                // dont ceux sans format pour le destinataire
827                .', NONE: '.$none
828                // et ceux en echec
829                .', ECHEC: '.$echec
830                .')';
831        return($str);
832}
Note: See TracBrowser for help on using the repository browser.