92b821d9c7bd34d17a3ac6c68d2f802b99c3a5e2
2 /***************************************************************************
3 * Copyright (C) 2003-2011 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
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. *
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. *
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 *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
24 class MedalReq
extends ProfileValidate
34 public function __construct(User
$_user, Profile
$_profile, $_idmedal, $_subidmedal, $_stamp = 0)
36 parent
::__construct($_user, $_profile, false
, 'medal', $_stamp);
37 $this->mid
= $_idmedal;
38 $this->gid
= $_subidmedal;
39 if (is_null($this->gid
)) {
45 // {{{ function formu()
47 public function formu()
49 return 'include/form.valid.medals.tpl';
53 // {{{ function _mail_subj
55 protected function _mail_subj()
57 return '[Polytechnique.org/Décoration] Demande de décoration : ' . $this->medal_name();
61 // {{{ function _mail_body
63 protected function _mail_body($isok)
66 return ' La décoration ' . $this->medal_name() . ' vient d\'être ajoutée à ta fiche.';
68 return ' La demande que tu avais faite pour la décoration ' . $this->medal_name() . ' a été refusée.';
73 // {{{ function medal_name
75 public function medal_name()
77 $res = XDB
::query('SELECT m.text
78 FROM profile_medal_enum AS m
79 WHERE m.id = {?}', $this->mid
);
80 return $res->fetchOneCell();
84 // {{{ function submit()
86 public function submit()
88 $res = XDB
::query("SELECT FIND_IN_SET('validation', flags)
89 FROM profile_medal_enum
90 WHERE id = {?}", $this->mid
);
91 if ($res->fetchOneCell()) {
99 // {{{ function commit()
101 public function commit ()
103 return XDB
::execute('INSERT INTO profile_medals (pid, mid, gid)
104 VALUES ({?}, {?}, {?})
105 ON DUPLICATE KEY UPDATE gid = VALUES(gid)',
106 $this->profile
->id(), $this->mid
,
107 is_null($this->gid
) ?
0 : $this->gid
);
111 // {{{ function get_request($medal)
113 static public function get_request($pid, $type)
115 $reqs = parent
::get_typed_requests($pid, 'medal');
116 foreach ($reqs as &$req) {
117 if ($req->mid
== $type) {
129 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: