On redirection addition, the antispam level is either set to the user's redirection...
[platal.git] / include / validations / homonymes.inc.php
index 684ef29..7256112 100644 (file)
@@ -26,17 +26,13 @@ class HomonymeReq extends Validate
     // {{{ properties
 
     public $loginbis;
-
     public $warning = true;
-
-    public $homonymes_hruid;
-
     public $rules = "Accepter, sauf cas particulier d'utilisateur dont l'homonymie est traité plus … manuellement.";
 
     // }}}
     // {{{ constructor
 
-    public function __construct(User &$_user, $_loginbis, $_homonymes_hruid, $warning=true)
+    public function __construct(User $_user, $_loginbis, $_homonymes_hruid, $warning=true)
     {
         $this->warning = $warning;
 
@@ -44,7 +40,6 @@ class HomonymeReq extends Validate
 
         $this->refuse = false;
         $this->loginbis = $_loginbis;
-        $this->homonymes_hruid = $_homonymes_hruid;
     }
 
     // }}}
@@ -68,10 +63,9 @@ class HomonymeReq extends Validate
 
     protected function _mail_subj()
     {
-        global $globals;
         return "[Polytechnique.org/Support] "
             . ($this->warning ? "Dans une semaine : suppression de l'alias " : "Mise en place du robot")
-            . " $loginbis@" . $globals->mail->domain;
+            . " $loginbis@" . $this->user->mainEmailDomain();
     }
 
     // }}}
@@ -79,16 +73,15 @@ class HomonymeReq extends Validate
 
     protected function _mail_body($isok)
     {
-        global $globals;
         return
 "
 Comme nous t'en avons informé par email il y a quelques temps,
 pour respecter nos engagements en terme d'adresses email devinables,
-tu te verras bientôt retirer l'alias ".$this->loginbis."@".$globals->mail->domain." pour
+tu te verras bientôt retirer l'alias " . $this->loginbis . "@" . $this->user->mainEmailDomain() . " pour
 ne garder que " . $this->user->forlifeEmail() . ".
 
-Toute personne qui écrira à ".$this->loginbis."@".$globals->mail->domain." recevra la
-réponse d'un robot qui l'informera que ".$this->loginbis."@".$globals->mail->domain."
+Toute personne qui écrira à " . $this->loginbis . "@" . $this->user->mainEmailDomain() . " recevra la
+réponse d'un robot qui l'informera que " . $this->loginbis . "@" . $this->user->mainEmailDomain() . "
 est ambigu pour des raisons d'homonymie et signalera ton email exact.";
     }
 
@@ -121,12 +114,18 @@ est ambigu pour des raisons d'homonymie et signalera ton email exact.";
     public function commit()
     {
         Platal::load('admin', 'homonyms.inc.php');
-        switch_bestalias($this->user, $this->loginbis);
         if (!$this->warning) {
-            XDB::execute("UPDATE aliases SET type = 'homonyme', expire = NOW() WHERE alias = {?}", $this->loginbis);
-            XDB::execute('INSERT IGNORE INTO  homonyms (homonyme_id, uid)
-                                      VALUES  ({?}, {?})',
-                         $this->user->id(), $this->user->id());
+            require_once 'emails.inc.php';
+
+            XDB::execute('DELETE FROM  email_source_account
+                                WHERE  email = {?} AND type = \'alias\'',
+                         $this->loginbis);
+            XDB::execute('INSERT INTO  email_source_other (hrmid, email, domain, type, expire)
+                               SELECT  {?}, {?}, id, \'homonym\', NOW()
+                                 FROM  email_virtual_domains
+                                WHERE  name = {?}',
+                         User::makeHomonymHrmid($this->loginbis), $this->loginbis, $this->user->mainEmailDomain());
+            fix_bestalias($this->user);
         }
 
         return true;