2 /***************************************************************************
3 * Copyright (C) 2003-2009 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the Free Software *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
22 class NewsletterModule
extends PLModule
27 'nl' => $this->make_hook('nl', AUTH_COOKIE
),
28 'nl/show' => $this->make_hook('nl_show', AUTH_COOKIE
),
29 'nl/submit' => $this->make_hook('nl_submit', AUTH_MDP
),
30 'admin/newsletter' => $this->make_hook('admin_nl', AUTH_MDP
, 'admin'),
31 'admin/newsletter/categories' => $this->make_hook('admin_nl_cat', AUTH_MDP
, 'admin'),
32 'admin/newsletter/edit' => $this->make_hook('admin_nl_edit', AUTH_MDP
, 'admin'),
36 function handler_nl(&$page, $action = null
)
38 require_once 'newsletter.inc.php';
40 $page->changeTpl('newsletter/index.tpl');
41 $page->setTitle('Lettres mensuelles');
44 case 'out': Newsletter
::unsubscribe(); break;
45 case 'in': Newsletter
::subscribe(); break;
49 $page->assign('nls', Newsletter
::subscriptionState());
50 $page->assign('nl_list', Newsletter
::listSent());
53 function handler_nl_show(&$page, $nid = 'last')
55 $page->changeTpl('newsletter/show.tpl');
57 require_once 'newsletter.inc.php';
60 $nl = new NewsLetter($nid);
61 if (Get
::has('text')) {
62 $nl->toText($page, S
::v('prenom'), S
::v('nom'), S
::v('femme'));
64 $nl->toHtml($page, S
::v('prenom'), S
::v('nom'), S
::v('femme'));
66 if (Post
::has('send')) {
67 $res = XDB
::query("SELECT hash
71 $nl->sendTo(S
::user()->login(), S
::user()->bestEmail(),
72 S
::v('prenom'), S
::v('nom'),
73 S
::v('femme'), S
::v('mail_fmt') != 'texte',
74 $res->fetchOneCell());
76 } catch (MailNotFound
$e) {
81 function handler_nl_submit(&$page)
83 $page->changeTpl('newsletter/submit.tpl');
85 require_once 'newsletter.inc.php';
86 $wp = new PlWikiPage('Xorg.LettreMensuelle');
89 if (Post
::has('see') ||
(Post
::has('valid') && (!trim(Post
::v('title')) ||
!trim(Post
::v('body'))))) {
90 if (!Post
::has('see')) {
91 $page->trigError("L'article doit avoir un titre et un contenu");
93 $art = new NLArticle(Post
::v('title'), Post
::v('body'), Post
::v('append'));
94 $page->assign('art', $art);
95 } elseif (Post
::has('valid')) {
96 require_once('validations.inc.php');
97 $art = new NLReq(S
::user(), Post
::v('title'),
98 Post
::v('body'), Post
::v('append'));
100 $page->assign('submited', true
);
102 $page->addCssLink('nl.css');
105 function handler_admin_nl(&$page, $new = false
) {
106 $page->changeTpl('newsletter/admin.tpl');
107 $page->setTitle('Administration - Newsletter : liste');
108 require_once("newsletter.inc.php");
111 Newsletter
::create();
112 pl_redirect("admin/newsletter");
115 $page->assign('nl_list', Newsletter
::listAll());
118 function handler_admin_nl_edit(&$page, $nid = 'last', $aid = null
, $action = 'edit') {
119 $page->changeTpl('newsletter/edit.tpl');
120 $page->addCssLink('nl.css');
121 $page->setTitle('Administration - Newsletter : Édition');
122 require_once 'newsletter.inc.php';
124 $nl = new NewsLetter($nid);
126 if($action == 'delete') {
127 $nl->delArticle($aid);
128 pl_redirect("admin/newsletter/edit/$nid");
131 if($aid == 'update') {
132 $nl->_title
= Post
::v('title');
133 $nl->_title_mail
= Post
::v('title_mail');
134 $nl->_date
= Post
::v('date');
135 $nl->_head
= Post
::v('head');
136 $nl->_shortname
= strlen(Post
::v('shortname')) ? Post
::v('shortname') : null
;
137 if (preg_match('/^[-a-z0-9]*$/i', $nl->_shortname
) && !is_numeric($nl->_shortname
)) {
140 $page->trigError("Le nom de la NL n'est pas valide.");
141 pl_redirect('admin/newsletter/edit/' . $nl->_id
);
145 if(Post
::v('save')) {
146 $art = new NLArticle(Post
::v('title'), Post
::v('body'), Post
::v('append'),
147 $aid, Post
::v('cid'), Post
::v('pos'));
148 $nl->saveArticle($art);
149 pl_redirect("admin/newsletter/edit/$nid");
152 if ($action == 'edit' && $aid != 'update') {
154 if(Post
::has('title')) {
155 $art = new NLArticle(Post
::v('title'), Post
::v('body'), Post
::v('append'),
156 $eaid, Post
::v('cid'), Post
::v('pos'));
158 $art = ($eaid == 'new') ?
new NLArticle() : $nl->getArt($eaid);
160 $page->assign('art', $art);
163 if ($aid == 'blacklist_check') {
165 $ips_to_check = array();
166 $blacklist_host_resolution_count = 0;
168 foreach ($nl->_arts
as $key => $articles) {
169 foreach ($articles as $article) {
170 $article_ips = $article->getLinkIps($blacklist_host_resolution_count);
171 if (!empty($article_ips)) {
172 $ips_to_check[$article->title()] = $article_ips;
177 $page->assign('ips_to_check', $ips_to_check);
178 if ($blacklist_host_resolution_count >= $globals->mail
->blacklist_host_resolution_limit
) {
179 $page->trigError("Toutes les url et adresses emails de la lettre"
180 . " n'ont pas été prises en compte car la"
181 . " limite du nombre de résolutions DNS"
182 . " autorisée a été atteinte.");
186 $page->assign_by_ref('nl', $nl);
189 function handler_admin_nl_cat(&$page, $action = 'list', $id = null
) {
190 $page->setTitle('Administration - Newsletter : Catégories');
191 $page->assign('title', 'Gestion des catégories de la newsletter');
192 $table_editor = new PLTableEditor('admin/newsletter/categories','newsletter_cat','cid');
193 $table_editor->describe('titre','intitulé',true
);
194 $table_editor->describe('pos','position',true
);
195 $table_editor->apply($page, $action, $id);
199 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: