-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathattendeesview.php
89 lines (78 loc) · 3.48 KB
/
attendeesview.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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?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/>.
/**
* Prints a particular instance of jitsi
*
* You can have a rather longer description of the file as well,
* if you like, and it can span multiple lines.
*
* @package mod_jitsi
* @copyright 2024 Sergio Comerón <[email protected]>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once(dirname(dirname(dirname(__FILE__))).'/config.php');
require_once(dirname(__FILE__).'/lib.php');
// Allow CORS requests.
header('Access-Control-Allow-Origin: *');
global $USER;
$id = optional_param('id', 0, PARAM_INT);
$n = optional_param('n', 0, PARAM_INT);
$state = optional_param('state', null, PARAM_TEXT);
$deletejitsirecordid = optional_param('deletejitsirecordid', 0, PARAM_INT);
$hidejitsirecordid = optional_param('hidejitsirecordid', 0, PARAM_INT);
$showjitsirecordid = optional_param('showjitsirecordid', 0, PARAM_INT);
if ($id) {
$cm = get_coursemodule_from_id('jitsi', $id, 0, false, MUST_EXIST);
$course = $DB->get_record('course', ['id' => $cm->course], '*', MUST_EXIST);
$jitsi = $DB->get_record('jitsi', ['id' => $cm->instance], '*', MUST_EXIST);
$sesskey = optional_param('sesskey', null, PARAM_TEXT);
} else {
throw new \moodle_exception('Unable to find jitsi');
}
require_login($course, true, $cm);
$PAGE->set_url('/mod/jitsi/attendessview.php', ['id' => $cm->id]);
$PAGE->set_title(format_string($jitsi->name));
$PAGE->set_heading(format_string($course->fullname));
echo $OUTPUT->header();
$backurl = new moodle_url('/mod/jitsi/view.php', ['id' => $cm->id]);
echo html_writer::link($backurl, get_string('back'));
$cm = get_coursemodule_from_id('jitsi', $id, 0, false, MUST_EXIST);
$contextmodule = context_module::instance($cm->id);
$sqlusersconnected = 'SELECT DISTINCT userid FROM {logstore_standard_log}
WHERE contextid = :contextid AND action = \'participating\'';
$params = ['contextid' => $contextmodule->id];
$usersconnected = $DB->get_records_sql($sqlusersconnected, $params);
$table = new html_table();
$table->head = [get_string('name'), get_string('minutestoday', 'jitsi').
': '.date('d/m', strtotime('today midnight')), get_string('totalminutes', 'jitsi')];
$table->data = [];
$userids = [];
foreach ($usersconnected as $userconnected) {
if ($userconnected->userid != 0) {
$userids[] = $userconnected->userid;
}
}
$users = $DB->get_records_list('user', 'id', $userids);
foreach ($users as $user) {
$urluser = new moodle_url('/user/profile.php', ['id' => $user->id]);
$table->data[] = [
html_writer::link($urluser, fullname($user), ['data-toggle' =>
'tooltip', 'data-placement' => 'top', 'title' => $user->username]),
getminutesdates($id, $user->id, strtotime('today midnight'), strtotime('today midnight +1 day')),
getminutes($id, $user->id)];
}
echo html_writer::table($table);
echo $OUTPUT->footer();