forked from bozoh/moodle-mod_simplecertificate
-
Notifications
You must be signed in to change notification settings - Fork 0
/
view.php
124 lines (104 loc) · 3.98 KB
/
view.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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?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/>.
/**
* Simple Certificate activity module
*
* @package mod
* @subpackage simplecertificate
* @copyright Carlos Alexandre S. da Fonseca <bozohhot@hotmail.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once(dirname(dirname(dirname(__FILE__))).'/config.php');
require_once("$CFG->dirroot/mod/simplecertificate/lib.php");
require_once("$CFG->libdir/pdflib.php");
require_once("$CFG->dirroot/mod/simplecertificate/locallib.php");
$id = required_param('id', PARAM_INT); // Course Module ID.
$action = optional_param('action', '', PARAM_ALPHA);
$tab = optional_param('tab', simplecertificate::DEFAULT_VIEW, PARAM_INT);
$type = optional_param('type', '', PARAM_ALPHA);
$page = optional_param('page', 0, PARAM_INT);
$perpage = optional_param('perpage', get_config('simplecertificate', 'perpage'), PARAM_INT);
$orderby = optional_param('orderby', 'username', PARAM_RAW);
$issuelist = optional_param('issuelist', null, PARAM_ALPHA);
$selectedusers = optional_param_array('selectedusers', null, PARAM_INT);
$cm = get_coursemodule_from_id( 'simplecertificate', $id);
if (!$cm) {
throw new moodle_exception('Course Module ID was incorrect');
}
$course = $DB->get_record('course', ['id' => $cm->course]);
if (!$course) {
throw new moodle_exception('course is misconfigured');
}
$certificate = $DB->get_record('simplecertificate', ['id' => $cm->instance]);
if (!$certificate) {
throw new moodle_exception('course module is incorrect');
}
$context = context_module::instance ($cm->id);
$url = new moodle_url('/mod/simplecertificate/view.php', [
'id' => $cm->id,
'tab' => $tab,
'page' => $page,
'perpage' => $perpage,
]);
if ($type) {
$url->param('type', $type);
}
if ($orderby) {
$url->param ('orderby', $orderby);
}
if ($action) {
$url->param ('action', $action);
}
if ($issuelist) {
$url->param ('issuelist', $issuelist);
}
// Initialize $PAGE, compute blocks.
$PAGE->set_url($url);
$PAGE->set_context($context);
$PAGE->set_cm($cm);
require_login( $course->id, false, $cm);
require_capability('mod/simplecertificate:view', $context);
$canmanage = has_capability('mod/simplecertificate:manage', $context);
// Log update.
$simplecertificate = new simplecertificate($context, $cm, $course);
$simplecertificate->set_instance($certificate);
$completion = new completion_info($course);
$completion->set_module_viewed($cm);
$PAGE->set_title(format_string($certificate->name));
$PAGE->set_heading(format_string($course->fullname));
switch ($tab) {
case $simplecertificate::ISSUED_CERTIFCADES_VIEW :
// Verify if user can access this page
// avoid the access by adding tab=1 in post/get.
if ($canmanage) {
$simplecertificate->view_issued_certificates($url, $selectedusers);
} else {
throw new moodle_exception('nopermissiontoviewpage');
}
break;
case $simplecertificate::BULK_ISSUE_CERTIFCADES_VIEW :
// Verify if user can access this page
// avoid the access by adding tab=1 in post/get.
if ($canmanage) {
$simplecertificate->view_bulk_certificates($url, $selectedusers);
} else {
throw new moodle_exception('nopermissiontoviewpage');
}
break;
default :
$simplecertificate->view_default($url, $canmanage);
break;
}