b669a19415dd9b59aa97df6f96173e8229736add
[moodle.git] / badges / classes / output / issued_badge.php
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
17 /**
18  * Issued badge renderable.
19  *
20  * @package    core
21  * @subpackage badges
22  * @copyright  2012 onwards Totara Learning Solutions Ltd {@link http://www.totaralms.com/}
23  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24  * @author     Yuliya Bozhko <yuliya.bozhko@totaralms.com>
25  */
27 namespace core_badges\output;
29 defined('MOODLE_INTERNAL') || die();
31 require_once($CFG->libdir . '/badgeslib.php');
33 use renderable;
35 /**
36  * An issued badges for badge.php page
37  *
38  * @copyright  2012 onwards Totara Learning Solutions Ltd {@link http://www.totaralms.com/}
39  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
40  */
41 class issued_badge implements renderable {
42     /** @var issued badge */
43     public $issued;
45     /** @var badge recipient */
46     public $recipient;
48     /** @var badge class */
49     public $badgeclass;
51     /** @var badge visibility to others */
52     public $visible = 0;
54     /** @var badge class */
55     public $badgeid = 0;
57     /**
58      * Initializes the badge to display
59      *
60      * @param string $hash Issued badge hash
61      */
62     public function __construct($hash) {
63         global $DB;
65         $assertion = new \core_badges_assertion($hash);
66         $this->issued = $assertion->get_badge_assertion();
67         $this->badgeclass = $assertion->get_badge_class();
69         $rec = $DB->get_record_sql('SELECT userid, visible, badgeid
70                 FROM {badge_issued}
71                 WHERE ' . $DB->sql_compare_text('uniquehash', 40) . ' = ' . $DB->sql_compare_text(':hash', 40),
72                 array('hash' => $hash), IGNORE_MISSING);
73         if ($rec) {
74             // Get a recipient from database.
75             $namefields = get_all_user_name_fields(true, 'u');
76             $user = $DB->get_record_sql("SELECT u.id, $namefields, u.deleted, u.email
77                         FROM {user} u WHERE u.id = :userid", array('userid' => $rec->userid));
78             $this->recipient = $user;
79             $this->visible = $rec->visible;
80             $this->badgeid = $rec->badgeid;
81         }
82     }
83 }