Searching mentors in advanced search works back. (Closes #741)
[platal.git] / include / validations / listes.inc.php
index c97e7ea..ffa56ee 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /***************************************************************************
- *  Copyright (C) 2003-2006 Polytechnique.org                              *
+ *  Copyright (C) 2003-2007 Polytechnique.org                              *
  *  http://opensource.polytechnique.org/                                   *
  *                                                                         *
  *  This program is free software; you can redistribute it and/or modify   *
 class ListeReq extends Validate
 {
     // {{{ properties
-    
-    var $liste;
-    var $desc;
 
-    var $advertise;
-    var $modlevel;
-    var $inslevel;
+    public $liste;
+    public $desc;
 
-    var $owners;
-    var $members;
+    public $advertise;
+    public $modlevel;
+    public $inslevel;
 
-    var $rules = "Refuser les listes de binets si elles ne sont pas datées (oui : apv2002@, non : apv@).
-        Refuser également des listes qui pourraient nous servir (admin, postmaster,...)";
+    public $owners;
+    public $members;
+
+    public $rules = "Refuser les listes de binets si elles ne sont pas datées (oui : apv2002@, non : apv@).
+        Refuser également des listes qui pourraient nous servir (admin, postmaster,...)";
     // }}}
     // {{{ constructor
-    
-    function ListeReq($_uid, $_liste, $_desc, $_advertise, $_modlevel, $_inslevel, $_owners, $_members, $_stamp=0)
+
+    public function __construct($_uid, $_liste, $_desc, $_advertise, $_modlevel,
+                                $_inslevel, $_owners, $_members, $_stamp=0)
     {
-        global $globals;
-        $this->Validate($_uid, true, 'liste', $_stamp);
-        
+        parent::__construct($_uid, false, 'liste', $_stamp);
+
         $this->liste     = $_liste;
         $this->desc      = $_desc;
         $this->advertise = $_advertise;
@@ -57,13 +57,34 @@ class ListeReq extends Validate
     // }}}
     // {{{ function formu()
 
-    function formu()
-    { return 'include/form.valid.listes.tpl'; }
+    public function formu()
+    {
+        return 'include/form.valid.listes.tpl';
+    }
+
+    // }}}
+    // {{{ function editor()
+
+    public function editor()
+    {
+        return 'include/form.valid.edit-listes.tpl';
+    }
+
+    // }}}
+    // {{{ function handle_editor()
+
+    protected function handle_editor()
+    {
+        if (Env::has('listname')) {
+            $this->liste = trim(Env::v('listname'));
+        }
+        return true;
+    }
 
     // }}}
     // {{{ function _mail_subj
 
-    function _mail_subj()
+    protected function _mail_subj()
     {
         return "[Polytechnique.org/LISTES] Demande de la liste {$this->liste}";
     }
@@ -71,32 +92,28 @@ class ListeReq extends Validate
     // }}}
     // {{{ function _mail_body
 
-    function _mail_body($isok)
+    protected function _mail_body($isok)
     {
         if ($isok) {
-            return "  La mailing list {$this->liste} que tu avais demandée vient d'être créée.";
+            return "  La mailing list {$this->liste} que tu avais demandée vient d'être créée.";
         } else {
-            return "  La demande que tu avais faite pour la mailing list {$this->liste} a été refusée.";
+            return "  La demande que tu avais faite pour la mailing list {$this->liste} a été refusée.";
         }
     }
 
     // }}}
     // {{{ function commit()
-    
-    function commit()
+
+    public function commit()
     {
-        global $globals;
-        require_once('platal/xmlrpc-client.inc.php');
-        require_once('lists.inc.php');
-
-        $client =& lists_xmlrpc(Session::getInt('uid'), Session::get('password'));
-        $ret = $client->create_list($this->liste, $this->desc,
-            $this->advertise, $this->modlevel, $this->inslevel,
-            $this->owners, $this->members);
+        $list = new MMList(S::v('uid'), S::v('password'));
+        $ret = $list->create_list($this->liste, utf8_decode($this->desc), $this->advertise,
+                                  $this->modlevel, $this->inslevel,
+                                  $this->owners, $this->members);
         $liste = strtolower($this->liste);
         if ($ret) {
             foreach(Array($liste, $liste."-owner", $liste."-admin", $liste."-bounces") as $l) {
-                $globals->xdb->execute("INSERT INTO aliases (alias,type) VALUES({?}, 'liste')", $l);
+                XDB::execute("INSERT INTO aliases (alias,type) VALUES({?}, 'liste')", $l);
             }
         }
         return $ret;
@@ -107,5 +124,5 @@ class ListeReq extends Validate
 
 // }}}
 
-// vim:set et sw=4 sts=4 sws=4 foldmethod=marker:
+// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
 ?>