Merge branch 'MDL-80255-main' of https://github.com/aanabit/moodle
[moodle.git] / grade / import / key.php
blob34d7eb7f2c0a3945654f79bfe2ab060aa5f6db22
1 <?php
3 // This file is part of Moodle - http://moodle.org/
4 //
5 // Moodle is free software: you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation, either version 3 of the License, or
8 // (at your option) any later version.
9 //
10 // Moodle is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 // GNU General Public License for more details.
15 // You should have received a copy of the GNU General Public License
16 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
18 /**
19 * Import key management.
21 * @package moodlecore
22 * @copyright 2008 Nicolas Connault
23 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
26 require_once('../../config.php');
27 require_once('key_form.php');
28 require_once($CFG->dirroot.'/grade/lib.php');
30 /// get url variables
31 $courseid = optional_param('courseid', 0, PARAM_INT);
32 $id = optional_param('id', 0, PARAM_INT);
33 $delete = optional_param('delete', 0, PARAM_BOOL);
34 $confirm = optional_param('confirm', 0, PARAM_BOOL);
36 $url = new moodle_url('/grade/import/key.php', ['courseid' => $courseid, 'id' => $id]);
37 $PAGE->set_url($url);
39 if ($id) {
40 if (!$key = $DB->get_record('user_private_key', array('id' => $id))) {
41 throw new \moodle_exception('invalidgroupid');
43 if (empty($courseid)) {
44 $courseid = $key->instance;
46 } else if ($courseid != $key->instance) {
47 throw new \moodle_exception('invalidcourseid');
50 if (!$course = $DB->get_record('course', array('id' => $courseid))) {
51 throw new \moodle_exception('invalidcourseid');
54 } else {
55 if (!$course = $DB->get_record('course', array('id' => $courseid))) {
56 throw new \moodle_exception('invalidcourseid');
58 $key = new stdClass();
61 $key->courseid = $course->id;
63 require_login($course);
64 $context = context_course::instance($course->id);
65 require_capability('moodle/grade:import', $context);
67 // Check if the user has at least one grade publishing capability.
68 $plugins = grade_helper::get_plugins_import($course->id);
69 if (!isset($plugins['keymanager'])) {
70 throw new \moodle_exception('nopermissions');
73 // extra security check
74 if (!empty($key->userid) and $USER->id != $key->userid) {
75 throw new \moodle_exception('notownerofkey');
78 $returnurl = $CFG->wwwroot.'/grade/import/keymanager.php?id='.$course->id;
80 $strkeys = get_string('keymanager', 'userkey');
81 $strimportgrades = get_string('import', 'grades');
82 $PAGE->navbar->add($strimportgrades, new moodle_url(new moodle_url('/grade/import/index.php', ['id' => $courseid])));
83 $PAGE->navbar->add($strkeys, new moodle_url('/grade/import/keymanager.php', ['id' => $courseid]));
85 if ($id and $delete) {
86 if (!$confirm) {
87 $PAGE->set_title(get_string('deleteselectedkey'));
88 $PAGE->set_heading($course->fullname);
89 $PAGE->set_secondary_active_tab('grades');
90 $PAGE->navbar->add(get_string('deleteuserkey', 'userkey'));
92 echo $OUTPUT->header();
93 $optionsyes = array('id'=>$id, 'delete'=>1, 'courseid'=>$courseid, 'sesskey'=>sesskey(), 'confirm'=>1);
94 $optionsno = array('id'=>$courseid);
95 $formcontinue = new single_button(new moodle_url('key.php', $optionsyes), get_string('yes'), 'get');
96 $formcancel = new single_button(new moodle_url('keymanager.php', $optionsno), get_string('no'), 'get');
97 echo $OUTPUT->confirm(get_string('deletekeyconfirm', 'userkey', $key->value), $formcontinue, $formcancel);
98 echo $OUTPUT->footer();
99 die;
101 } else if (confirm_sesskey()){
102 $DB->delete_records('user_private_key', array('id' => $id));
103 redirect('keymanager.php?id='.$course->id);
107 /// First create the form
108 $editform = new key_form();
109 $editform->set_data($key);
111 if ($editform->is_cancelled()) {
112 redirect($returnurl);
114 } elseif ($data = $editform->get_data()) {
116 if ($data->id) {
117 $record = new stdClass();
118 $record->id = $data->id;
119 $record->iprestriction = $data->iprestriction;
120 $record->validuntil = $data->validuntil;
121 $DB->update_record('user_private_key', $record);
122 } else {
123 create_user_key('grade/import', $USER->id, $course->id, $data->iprestriction, $data->validuntil);
126 redirect($returnurl);
129 if ($id) {
130 $strheading = get_string('edituserkey', 'userkey');
131 } else {
132 $strheading = get_string('createuserkey', 'userkey');
135 $PAGE->navbar->add($strheading);
137 /// Print header
138 $PAGE->set_title($strkeys);
139 $PAGE->set_heading($course->fullname);
140 $PAGE->set_secondary_active_tab('grades');
141 echo $OUTPUT->header();
142 echo $OUTPUT->heading($strheading);
144 $editform->display();
145 echo $OUTPUT->footer();