forked from openbadgefactory/moodle-local_obf
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathuserbadges.php
55 lines (46 loc) · 1.95 KB
/
userbadges.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Script for fetching user's badges via Ajax.
*
* @package local_obf
* @copyright 2013-2020, Open Badge Factory Oy
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
use classes\obf_assertion;
use classes\obf_blacklist;
use classes\obf_client;
use classes\obf_assertion_collection;
define('AJAX_SCRIPT', true);
require_once(__DIR__ . '/../../config.php');
require_once(__DIR__ . '/classes/obf_assertion.php');
require_once(__DIR__ . '/classes/blacklist.php');
require_once(__DIR__ . '/classes/obf_assertion_collection.php');
require_login(); // TODO: Handle login requirement more gracefully for more useful error messages?
$userid = required_param('userid', PARAM_INT);
$context = context_user::instance($userid);
$client = obf_client::get_instance();
$blacklist = new obf_blacklist($userid);
$assertions = new obf_assertion_collection();
$assertions->add_collection(obf_assertion::get_assertions_all($client, $DB->get_record('user', array('id' => $userid))->email));
$assertions->apply_blacklist($blacklist);
if ((int) $USER->id === $userid) {
require_capability('local/obf:viewownbackpack', $context);
} else {
// TODO: more specific capabilities?
require_capability('local/obf:viewbackpack', $context);
}
echo json_encode($assertions->toarray());