Differences Between: [Versions 310 and 401] [Versions 310 and 402] [Versions 310 and 403]
1 <?php 2 3 /////////////////////////////////////////////////////////////////////////// 4 // // 5 // NOTICE OF COPYRIGHT // 6 // // 7 // Moodle - Modular Object-Oriented Dynamic Learning Environment // 8 // http://moodle.org // 9 // // 10 // Copyright (C) 1999 onwards Martin Dougiamas http://dougiamas.com // 11 // // 12 // This program is free software; you can redistribute it and/or modify // 13 // it under the terms of the GNU General Public License as published by // 14 // the Free Software Foundation; either version 2 of the License, or // 15 // (at your option) any later version. // 16 // // 17 // This program is distributed in the hope that it will be useful, // 18 // but WITHOUT ANY WARRANTY; without even the implied warranty of // 19 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // 20 // GNU General Public License for more details: // 21 // // 22 // http://www.gnu.org/copyleft/gpl.html // 23 // // 24 /////////////////////////////////////////////////////////////////////////// 25 26 /** 27 * Allow the administrator to look through a list of course requests and approve or reject them. 28 * 29 * @license http://www.gnu.org/copyleft/gpl.html GNU Public License 30 * @package course 31 */ 32 33 require_once(__DIR__ . '/../config.php'); 34 require_once($CFG->libdir . '/adminlib.php'); 35 require_once($CFG->dirroot . '/course/lib.php'); 36 require_once($CFG->dirroot . '/course/request_form.php'); 37 38 $approve = optional_param('approve', 0, PARAM_INT); 39 $reject = optional_param('reject', 0, PARAM_INT); 40 41 $baseurl = $CFG->wwwroot . '/course/pending.php'; 42 $context = context_system::instance(); 43 if (has_capability('moodle/site:approvecourse', $context)) { 44 // Similar to course management capabilities, if user has approve capability in system context 45 // we add the link to the admin menu. Otherwise we check if user has capability anywhere. 46 admin_externalpage_setup('coursespending'); 47 } else { 48 require_login(null, false); 49 $categories = core_course_category::make_categories_list('moodle/site:approvecourse'); 50 if (!$categories) { 51 require_capability('moodle/site:approvecourse', $context); 52 } 53 $PAGE->set_context($context); 54 $PAGE->set_url(new moodle_url('/course/pending.php')); 55 } 56 57 /// Process approval of a course. 58 if (!empty($approve) and confirm_sesskey()) { 59 /// Load the request. 60 $course = new course_request($approve); 61 $courseid = $course->approve(); 62 63 if ($courseid !== false) { 64 if (has_capability('moodle/course:update', context_course::instance($courseid))) { 65 redirect(new moodle_url('/course/edit.php', ['id' => $courseid, 'returnto' => 'pending'])); 66 } else { 67 redirect(new moodle_url('/course/view.php', ['id' => $courseid])); 68 } 69 } else { 70 print_error('courseapprovedfailed'); 71 } 72 } 73 74 /// Process rejection of a course. 75 if (!empty($reject)) { 76 // Load the request. 77 $course = new course_request($reject); 78 79 // Prepare the form. 80 $rejectform = new reject_request_form($baseurl); 81 $default = new stdClass(); 82 $default->reject = $course->id; 83 $rejectform->set_data($default); 84 85 /// Standard form processing if statement. 86 if ($rejectform->is_cancelled()){ 87 redirect($baseurl); 88 89 } else if ($data = $rejectform->get_data()) { 90 91 /// Reject the request 92 $course->reject($data->rejectnotice); 93 94 /// Redirect back to the course listing. 95 redirect($baseurl, get_string('courserejected')); 96 } 97 98 /// Display the form for giving a reason for rejecting the request. 99 echo $OUTPUT->header($rejectform->focus()); 100 $rejectform->display(); 101 echo $OUTPUT->footer(); 102 exit; 103 } 104 105 /// Print a list of all the pending requests. 106 echo $OUTPUT->header(); 107 108 $pending = $DB->get_records('course_request'); 109 if (empty($pending)) { 110 echo $OUTPUT->heading(get_string('nopendingcourses')); 111 } else { 112 echo $OUTPUT->heading(get_string('coursespending')); 113 $role = $DB->get_record('role', array('id' => $CFG->creatornewroleid), '*', MUST_EXIST); 114 echo $OUTPUT->notification(get_string('courserequestwarning', 'core', role_get_name($role)), 'notifyproblem'); 115 116 /// Build a table of all the requests. 117 $table = new html_table(); 118 $table->attributes['class'] = 'pendingcourserequests generaltable'; 119 $table->align = array('center', 'center', 'center', 'center', 'center', 'center'); 120 $table->head = array(get_string('shortnamecourse'), get_string('fullnamecourse'), get_string('requestedby'), 121 get_string('summary'), get_string('category'), get_string('requestreason'), get_string('action')); 122 123 foreach ($pending as $course) { 124 $course = new course_request($course); 125 126 // Check here for shortname collisions and warn about them. 127 $course->check_shortname_collision(); 128 129 if (!$course->can_approve()) { 130 continue; 131 } 132 $category = $course->get_category(); 133 134 $row = array(); 135 $row[] = format_string($course->shortname); 136 $row[] = format_string($course->fullname); 137 $row[] = fullname($course->get_requester()); 138 $row[] = format_text($course->summary, $course->summaryformat); 139 $row[] = $category->get_formatted_name(); 140 $row[] = format_string($course->reason); 141 $row[] = $OUTPUT->single_button(new moodle_url($baseurl, array('approve' => $course->id, 'sesskey' => sesskey())), get_string('approve'), 'get') . 142 $OUTPUT->single_button(new moodle_url($baseurl, array('reject' => $course->id)), get_string('rejectdots'), 'get'); 143 144 /// Add the row to the table. 145 $table->data[] = $row; 146 } 147 148 /// Display the table. 149 echo html_writer::table($table); 150 151 /// Message about name collisions, if necessary. 152 if (!empty($collision)) { 153 print_string('shortnamecollisionwarning'); 154 } 155 } 156 157 /// Finish off the page. 158 echo $OUTPUT->single_button($CFG->wwwroot . '/course/index.php', get_string('backtocourselisting')); 159 echo $OUTPUT->footer();
title
Description
Body
title
Description
Body
title
Description
Body
title
Body