X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=modules%2Fnewsletter.php;h=ee6447edadf819e825a67f8cb46c6d1d67eeb671;hb=8a43972f58f0a77015ae9e509f1c073d188874d2;hp=42b31b510a63ab10b1ab74f6da2511b20f6e2d68;hpb=143ba7c95f06868f6a8dc7a4408d4ff04ded4ff0;p=platal.git diff --git a/modules/newsletter.php b/modules/newsletter.php index 42b31b5..ee6447e 100644 --- a/modules/newsletter.php +++ b/modules/newsletter.php @@ -1,6 +1,6 @@ $this->make_hook('nl', AUTH_COOKIE), - 'nl/show' => $this->make_hook('nl_show', AUTH_COOKIE), - 'nl/submit' => $this->make_hook('nl_submit', AUTH_MDP), - 'admin/newsletter' => $this->make_hook('admin_nl', AUTH_MDP, 'admin'), - 'admin/newsletter/categories' => $this->make_hook('admin_nl_cat', AUTH_MDP, 'admin'), + 'nl' => $this->make_hook('nl', AUTH_COOKIE), + 'nl/show' => $this->make_hook('nl_show', AUTH_COOKIE), + 'nl/submit' => $this->make_hook('nl_submit', AUTH_MDP), + 'admin/newsletter' => $this->make_hook('admin_nl', AUTH_MDP, 'admin'), + 'admin/newsletter/categories' => $this->make_hook('admin_nl_cat', AUTH_MDP, 'admin'), 'admin/newsletter/edit' => $this->make_hook('admin_nl_edit', AUTH_MDP, 'admin'), ); } @@ -38,7 +38,7 @@ class NewsletterModule extends PLModule require_once 'newsletter.inc.php'; $page->changeTpl('newsletter/index.tpl'); - $page->setTitle('Polytechnique.org - Lettres mensuelles'); + $page->setTitle('Lettres mensuelles'); switch ($action) { case 'out': Newsletter::unsubscribe(); break; @@ -56,18 +56,25 @@ class NewsletterModule extends PLModule require_once 'newsletter.inc.php'; - $nl = new NewsLetter($nid); - if (Get::has('text')) { - $nl->toText($page, S::v('prenom'), S::v('nom'), S::v('femme')); - } else { - $nl->toHtml($page, S::v('prenom'), S::v('nom'), S::v('femme')); - } - if (Post::has('send')) { - $res = XDB::query("SELECT hash FROM newsletter_ins WHERE user_id = {?}", S::i('uid')); - $nl->sendTo(S::v('prenom'), S::v('nom'), - S::v('bestalias'), S::v('femme'), - S::v('mail_fmt') != 'texte', - $res->fetchOneCell()); + try { + $nl = new NewsLetter($nid); + if (Get::has('text')) { + $nl->toText($page, S::v('prenom'), S::v('nom'), S::v('femme')); + } else { + $nl->toHtml($page, S::v('prenom'), S::v('nom'), S::v('femme')); + } + if (Post::has('send')) { + $res = XDB::query("SELECT hash + FROM newsletter_ins + WHERE user_id = {?}", + S::i('uid')); + $nl->sendTo(S::user()->login(), S::user()->bestEmail(), + S::v('prenom'), S::v('nom'), + S::v('femme'), S::v('mail_fmt') != 'texte', + $res->fetchOneCell()); + } + } catch (MailNotFound $e) { + return PL_NOT_FOUND; } } @@ -76,8 +83,8 @@ class NewsletterModule extends PLModule $page->changeTpl('newsletter/submit.tpl'); require_once 'newsletter.inc.php'; - require_once 'wiki.inc.php'; - wiki_require_page('Xorg.LettreMensuelle'); + $wp = new PlWikiPage('Xorg.LettreMensuelle'); + $wp->buildCache(); if (Post::has('see') || (Post::has('valid') && (!trim(Post::v('title')) || !trim(Post::v('body'))))) { if (!Post::has('see')) { @@ -87,7 +94,7 @@ class NewsletterModule extends PLModule $page->assign('art', $art); } elseif (Post::has('valid')) { require_once('validations.inc.php'); - $art = new NLReq(S::v('uid'), Post::v('title'), + $art = new NLReq(S::user(), Post::v('title'), Post::v('body'), Post::v('append')); $art->submit(); $page->assign('submited', true); @@ -97,7 +104,7 @@ class NewsletterModule extends PLModule function handler_admin_nl(&$page, $new = false) { $page->changeTpl('newsletter/admin.tpl'); - $page->setTitle('Polytechnique.org - Administration - Newsletter : liste'); + $page->setTitle('Administration - Newsletter : liste'); require_once("newsletter.inc.php"); if($new) { @@ -111,8 +118,8 @@ class NewsletterModule extends PLModule function handler_admin_nl_edit(&$page, $nid = 'last', $aid = null, $action = 'edit') { $page->changeTpl('newsletter/edit.tpl'); $page->addCssLink('nl.css'); - $page->setTitle('Polytechnique.org - Administration - Newsletter : Edition'); - require_once("newsletter.inc.php"); + $page->setTitle('Administration - Newsletter : Édition'); + require_once 'newsletter.inc.php'; $nl = new NewsLetter($nid); @@ -144,11 +151,14 @@ class NewsletterModule extends PLModule if($action == 'edit' && $aid != 'update') { $eaid = $aid; - if(Post::has('title')) { + if (Post::has('title')) { $art = new NLArticle(Post::v('title'), Post::v('body'), Post::v('append'), - $eaid, Post::v('cid'), Post::v('pos')); + $eaid, Post::v('cid'), Post::v('pos')); } else { - $art = ($eaid == 'new') ? new NLArticle() : $nl->getArt($eaid); + $art = ($eaid == 'new') ? new NLArticle() : $nl->getArt($eaid); + } + if ($art && !$art->check()) { + $page->trigError("Cet article est trop long."); } $page->assign('art', $art); } @@ -157,7 +167,7 @@ class NewsletterModule extends PLModule } function handler_admin_nl_cat(&$page, $action = 'list', $id = null) { - $page->setTitle('Polytechnique.org - Administration - Newsletter : Catégories'); + $page->setTitle('Administration - Newsletter : Catégories'); $page->assign('title', 'Gestion des catégories de la newsletter'); $table_editor = new PLTableEditor('admin/newsletter/categories','newsletter_cat','cid'); $table_editor->describe('titre','intitulé',true);