Merge branch 'platal-0.9.17'
[platal.git] / include / validations / nomusage.inc.php
1 <?php
2 /***************************************************************************
3 * Copyright (C) 2003-2008 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
5 * *
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. *
10 * *
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. *
15 * *
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 *
18 * Foundation, Inc., *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
21
22 // {{{ class UsageReq
23
24 class UsageReq extends Validate
25 {
26 // {{{ properties
27
28 public $unique = true;
29
30 public $nom_usage;
31 public $alias = '';
32
33 public $oldusage;
34 public $oldalias;
35
36 public $homonyme;
37 public $reason;
38
39 public $rules = "Refuser
40 tout ce qui n'est visiblement pas un nom de famille (ce qui est
41 extremement rare car à peu près n'importe quoi peut être un nom de
42 famille...)";
43
44 // }}}
45 // {{{ constructor
46
47 public function __construct($_uid, $_usage, $_reason)
48 {
49 parent::__construct($_uid, true, 'usage');
50 $this->nom_usage = $_usage;
51 $this->reason = $_reason;
52 $this->alias = make_username($this->prenom, $this->nom_usage);
53 if (!$this->nom_usage) $this->alias = "";
54
55 $res = XDB::query("
56 SELECT e.alias, u.nom_usage, a.id
57 FROM auth_user_md5 as u
58 LEFT JOIN aliases as e ON(e.type='alias' AND FIND_IN_SET('usage',e.flags) AND e.id = u.user_id)
59 LEFT JOIN aliases as a ON(a.alias = {?} AND a.id != u.user_id)
60 WHERE u.user_id = {?}", $this->alias, $this->uid);
61 list($this->oldalias, $this->oldusage, $this->homonyme) = $res->fetchOneRow();
62 }
63
64 // }}}
65 // {{{ function formu()
66
67 public function formu()
68 {
69 return 'include/form.valid.nomusage.tpl';
70 }
71
72 // }}}
73 // {{{ function _mail_subj()
74
75 protected function _mail_subj()
76 {
77 return "[Polytechnique.org/USAGE] Changement de nom d'usage";
78 }
79
80 // }}}
81 // {{{ function _mail_body
82
83 protected function _mail_body($isok)
84 {
85 global $globals;
86 if ($isok) {
87 $res = " Le changement de nom d'usage que tu as demandé vient d'être effectué.";
88 if ($this->oldalias) {
89 $res .= "\n\n Les alias {$this->oldalias}@{$globals->mail->domain} et @{$globals->mail->domain2} ont été supprimés.";
90 }
91 if ($this->nom_usage) {
92 $res .= "\n\n Les alias {$this->alias}@{$globals->mail->domain} et @{$globals->mail->domain2} sont maintenant à ta disposition !";
93 }
94 if ($globals->mailstorage->googleapps_domain) {
95 require_once 'googleapps.inc.php';
96 $account = new GoogleAppsAccount($this->uid, $this->forlife);
97 if ($account->active()) {
98 $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";
99 }
100 }
101 return $res;
102 } else {
103 return " La demande de changement de nom d'usage que tu avais faite a été refusée.";
104 }
105 }
106
107 // }}}
108 // {{{ function commit()
109
110 public function commit()
111 {
112 require_once 'notifs.inc.php';
113 register_watch_op($this->uid, WATCH_FICHE, '', 'nom');
114 require_once('user.func.inc.php');
115 $this->bestalias = set_new_usage($this->uid, $this->nom_usage, $this->alias);
116 return true;
117 }
118
119 // }}}
120 }
121 // }}}
122
123 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
124 ?>