Merge remote branch 'origin/platal-0.10.2'
[platal.git] / include / validations / nomusage.inc.php
index ef6662f..9eb101f 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /***************************************************************************
- *  Copyright (C) 2003-2004 Polytechnique.org                              *
+ *  Copyright (C) 2003-2010 Polytechnique.org                              *
  *  http://opensource.polytechnique.org/                                   *
  *                                                                         *
  *  This program is free software; you can redistribute it and/or modify   *
@@ -25,59 +25,58 @@ class UsageReq extends Validate
 {
     // {{{ properties
 
-    var $unique = true;
+    public $unique = true;
 
-    var $nom_usage;
-    var $alias = '';
+    public $nom_usage;
+    public $alias = '';
 
-    var $oldusage;
-    var $oldalias;
+    public $oldusage;
+    public $oldalias;
 
-    var $homonyme;
-    
-    var $rules = "Refuser 
-    tout ce qui n'est visiblement pas un nom de famille (ce qui est 
-    extremement rare car à peu près n'importe quoi peut être un nom de 
-    famille...)";
+    public $homonyme;
+    public $reason;
+
+    public $rules = "Refuser
+    tout ce qui n'est visiblement pas un nom de famille (ce qui est
+    extremement rare car à peu près n'importe quoi peut être un nom de
+    famille&hellip;)";
 
     // }}}
     // {{{ constructor
 
-    function UsageReq($_uid, $_usage)
+    public function __construct(User &$_user, $_usage, $_reason)
     {
-        global $globals;
-        $this->Validate($_uid, true, 'usage');
-        $this->nom_usage  = $_usage;
-        $this->alias   = make_username($this->prenom, $this->nom_usage);
-        if (!$this->nom_usage) $this->alias = "";
+        parent::__construct($_user, true, 'usage');
+        $this->nom_usage = $_usage;
+        $this->reason = $_reason;
+
+        $res = XDB::query("SELECT prenom FROM auth_user_md5 WHERE user_id = {?}", $this->user->id());
+        $this->alias = make_username($res->fetchOneCell(), $this->nom_usage);
+        if (!$this->nom_usage) {
+            $this->alias = "";
+        }
 
-        $res = $globals->xdb->query("
+        $res = XDB::query("
                 SELECT  e.alias, u.nom_usage, a.id
                   FROM  auth_user_md5 as u
              LEFT JOIN  aliases       as e ON(e.type='alias' AND FIND_IN_SET('usage',e.flags) AND e.id = u.user_id)
              LEFT JOIN  aliases       as a ON(a.alias = {?} AND a.id != u.user_id)
-                 WHERE  u.user_id = {?}", $this->alias, $this->uid);
+                 WHERE  u.user_id = {?}", $this->alias, $this->user->id());
         list($this->oldalias, $this->oldusage, $this->homonyme) = $res->fetchOneRow();
     }
 
     // }}}
-    // {{{ function get_request()
+    // {{{ function formu()
 
-    function get_request($uid)
+    public function formu()
     {
-        return parent::get_request($uid,'usage');
+        return 'include/form.valid.nomusage.tpl';
     }
 
     // }}}
-    // {{{ function formu()
-
-    function formu()
-    { return 'include/form.valid.nomusage.tpl'; }
-
-    // }}}
     // {{{ function _mail_subj()
 
-    function _mail_subj()
+    protected function _mail_subj()
     {
         return "[Polytechnique.org/USAGE] Changement de nom d'usage";
     }
@@ -85,30 +84,43 @@ class UsageReq extends Validate
     // }}}
     // {{{ function _mail_body
 
-    function _mail_body($isok)
+    protected function _mail_body($isok)
     {
         global $globals;
         if ($isok) {
-            $res = "  La demande de changement de nom d'usage que tu as demandée vient d'être effectuée.";
+            $res = "  Le changement de nom d'usage que tu as demandé vient d'être effectué.";
             if ($this->oldalias) {
-                $res .= "\n\n  Les alias {$this->oldalias}@{$globals->mail->domain} et @{$globals->mail->domain2} ont été supprimés.";
+                $res .= "\n\n  Les alias {$this->oldalias}@{$globals->mail->domain} et @{$globals->mail->domain2} ont été supprimés.";
+            }
+            if ($this->nom_usage) {
+                $res .= "\n\n  Les alias {$this->alias}@{$globals->mail->domain} et @{$globals->mail->domain2} sont maintenant à ta disposition !";
             }
-            if ($nom_usage) {
-                $res .= "\n\n  Les alias {$this->alias}@{$globals->mail->domain} et @{$globals->mail->domain2} sont maintenant à ta disposition !";
+            if ($globals->mailstorage->googleapps_domain) {
+                require_once 'googleapps.inc.php';
+                $account = new GoogleAppsAccount($this->user);
+                if ($account->active()) {
+                    $res .= "\n\n  Si tu utilises Google Apps, tu peux changer ton nom d'usage sur https://mail.google.com/a/polytechnique.org/#settings/accounts";
+                }
             }
             return $res;
         } else {
-            return "  La demande de changement de nom d'usage que tu avais faite a été refusée.";
+            return "  La demande de changement de nom d'usage que tu avais faite a été refusée.";
         }
     }
 
     // }}}
     // {{{ function commit()
 
-    function commit()
+    public function commit()
     {
-        require_once('nomusage.inc.php');
-        set_new_usage($this->uid, $this->nom_usage, $this->alias);
+        require_once 'notifs.inc.php';
+        register_watch_op($this->user->id(), WATCH_FICHE, '', 'nom');
+        require_once('user.func.inc.php');
+        set_new_usage($this->user->id(), $this->nom_usage, $this->alias);
+
+        // Update the local User object, to pick up the new bestalias.
+        $this->user = User::getSilent($this->user->id());
+
         return true;
     }
 
@@ -116,5 +128,5 @@ class UsageReq 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:
 ?>