forked from danmarsden/moodle-mod_attendance
-
Notifications
You must be signed in to change notification settings - Fork 0
/
password.php
85 lines (70 loc) · 2.93 KB
/
password.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
<?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/>.
/**
* Displays help via AJAX call or in a new page
*
* Use {@see core_renderer::help_icon()} or {@see addHelpButton()} to display
* the help icon.
*
* @copyright 2017 Dan Marsden
* @package mod_attendance
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once(dirname(__FILE__).'/../../config.php');
require_once(dirname(__FILE__).'/locallib.php');
require_once($CFG->libdir.'/tcpdf/tcpdf_barcodes_2d.php'); // Used for generating qrcode.
$session = required_param('session', PARAM_INT);
$session = $DB->get_record('attendance_sessions', ['id' => $session], '*', MUST_EXIST);
$cm = get_coursemodule_from_instance('attendance', $session->attendanceid);
require_login($cm->course, $cm);
$context = context_module::instance($cm->id);
$capabilities = ['mod/attendance:manageattendances', 'mod/attendance:takeattendances', 'mod/attendance:changeattendances'];
if (!has_any_capability($capabilities, $context)) {
exit;
}
if (optional_param('returnpasswords', 0, PARAM_INT) == 1) {
header('Content-Type: application/json');
echo attendance_return_passwords($session);
exit;
}
$PAGE->set_url('/mod/attendance/password.php');
$PAGE->set_pagelayout('popup');
$PAGE->set_context(context_system::instance());
$PAGE->set_title(get_string('password', 'attendance'));
echo $OUTPUT->header();
$showpassword = (isset($session->studentpassword) && strlen($session->studentpassword) > 0);
$showqr = (isset($session->includeqrcode) && $session->includeqrcode == 1);
$rotateqr = (isset($session->rotateqrcode) && $session->rotateqrcode == 1);
if ($rotateqr) {
$showpassword = false;
}
if ($showpassword) {
if ($showqr) {
echo html_writer::div("<h2>".get_string('qrcodeandpasswordheader', 'attendance'), 'qrcodeheader')."</h2>";
} else {
echo html_writer::div("<h2>".get_string('passwordheader', 'attendance'), 'qrcodeheader')."</h2>";
}
echo html_writer::span($session->studentpassword, 'student-password');
echo html_writer::div(' ');
}
if ($rotateqr) {
echo html_writer::div(get_string('qrcodeheader', 'attendance'), 'qrcodeheader');
attendance_generate_passwords($session);
attendance_renderqrcoderotate($session);
} else if ($showqr) {
attendance_renderqrcode($session);
}
echo $OUTPUT->footer();