mirror of
https://github.com/moodle/moodle.git
synced 2025-01-18 05:58:34 +01:00
176 lines
7.5 KiB
PHP
176 lines
7.5 KiB
PHP
<?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/>.
|
|
|
|
/**
|
|
* Provide interface for topics AJAX course formats
|
|
*
|
|
* @copyright 1999 Martin Dougiamas http://dougiamas.com
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
* @package course
|
|
*/
|
|
|
|
if (!defined('AJAX_SCRIPT')) {
|
|
define('AJAX_SCRIPT', true);
|
|
}
|
|
require_once(dirname(__FILE__) . '/../config.php');
|
|
require_once($CFG->dirroot.'/course/lib.php');
|
|
|
|
// Initialise ALL the incoming parameters here, up front.
|
|
$courseid = required_param('courseId', PARAM_INT);
|
|
$class = required_param('class', PARAM_ALPHA);
|
|
$field = optional_param('field', '', PARAM_ALPHA);
|
|
$instanceid = optional_param('instanceId', 0, PARAM_INT);
|
|
$sectionid = optional_param('sectionId', 0, PARAM_INT);
|
|
$beforeid = optional_param('beforeId', 0, PARAM_INT);
|
|
$value = optional_param('value', 0, PARAM_INT);
|
|
$column = optional_param('column', 0, PARAM_ALPHA);
|
|
$id = optional_param('id', 0, PARAM_INT);
|
|
$summary = optional_param('summary', '', PARAM_RAW);
|
|
$sequence = optional_param('sequence', '', PARAM_SEQUENCE);
|
|
$visible = optional_param('visible', 0, PARAM_INT);
|
|
$pageaction = optional_param('action', '', PARAM_ALPHA); // Used to simulate a DELETE command
|
|
$title = optional_param('title', '', PARAM_TEXT);
|
|
|
|
$PAGE->set_url('/course/rest.php', array('courseId'=>$courseid,'class'=>$class));
|
|
|
|
//NOTE: when making any changes here please make sure it is using the same access control as course/mod.php !!
|
|
|
|
$course = $DB->get_record('course', array('id' => $courseid), '*', MUST_EXIST);
|
|
// Check user is logged in and set contexts if we are dealing with resource
|
|
if (in_array($class, array('resource'))) {
|
|
$cm = get_coursemodule_from_id(null, $id, $course->id, false, MUST_EXIST);
|
|
require_login($course, false, $cm);
|
|
$modcontext = context_module::instance($cm->id);
|
|
} else {
|
|
require_login($course);
|
|
}
|
|
$coursecontext = context_course::instance($course->id);
|
|
require_sesskey();
|
|
|
|
echo $OUTPUT->header(); // send headers
|
|
|
|
// OK, now let's process the parameters and do stuff
|
|
// MDL-10221 the DELETE method is not allowed on some web servers, so we simulate it with the action URL param
|
|
$requestmethod = $_SERVER['REQUEST_METHOD'];
|
|
if ($pageaction == 'DELETE') {
|
|
$requestmethod = 'DELETE';
|
|
}
|
|
|
|
switch($requestmethod) {
|
|
case 'POST':
|
|
|
|
switch ($class) {
|
|
case 'section':
|
|
|
|
if (!$DB->record_exists('course_sections', array('course'=>$course->id, 'section'=>$id))) {
|
|
throw new moodle_exception('AJAX commands.php: Bad Section ID '.$id);
|
|
}
|
|
|
|
switch ($field) {
|
|
case 'visible':
|
|
require_capability('moodle/course:sectionvisibility', $coursecontext);
|
|
$resourcestotoggle = set_section_visible($course->id, $id, $value);
|
|
echo json_encode(array('resourcestotoggle' => $resourcestotoggle));
|
|
break;
|
|
|
|
case 'move':
|
|
require_capability('moodle/course:movesections', $coursecontext);
|
|
move_section_to($course, $id, $value);
|
|
// See if format wants to do something about it
|
|
$response = course_get_format($course)->ajax_section_move();
|
|
if ($response !== null) {
|
|
echo json_encode($response);
|
|
}
|
|
break;
|
|
}
|
|
break;
|
|
|
|
case 'resource':
|
|
switch ($field) {
|
|
case 'visible':
|
|
require_capability('moodle/course:activityvisibility', $modcontext);
|
|
set_coursemodule_visible($cm->id, $value);
|
|
\core\event\course_module_updated::create_from_cm($cm, $modcontext)->trigger();
|
|
break;
|
|
|
|
case 'duplicate':
|
|
require_capability('moodle/course:manageactivities', $coursecontext);
|
|
require_capability('moodle/backup:backuptargetimport', $coursecontext);
|
|
require_capability('moodle/restore:restoretargetimport', $coursecontext);
|
|
if (!course_allowed_module($course, $cm->modname)) {
|
|
throw new moodle_exception('No permission to create that activity');
|
|
}
|
|
$sr = optional_param('sr', null, PARAM_INT);
|
|
$result = mod_duplicate_activity($course, $cm, $sr);
|
|
echo json_encode($result);
|
|
break;
|
|
|
|
case 'groupmode':
|
|
require_capability('moodle/course:manageactivities', $modcontext);
|
|
set_coursemodule_groupmode($cm->id, $value);
|
|
\core\event\course_module_updated::create_from_cm($cm, $modcontext)->trigger();
|
|
break;
|
|
|
|
case 'indent':
|
|
require_capability('moodle/course:manageactivities', $modcontext);
|
|
$cm->indent = $value;
|
|
if ($cm->indent >= 0) {
|
|
$DB->update_record('course_modules', $cm);
|
|
rebuild_course_cache($cm->course);
|
|
}
|
|
break;
|
|
|
|
case 'move':
|
|
require_capability('moodle/course:manageactivities', $modcontext);
|
|
if (!$section = $DB->get_record('course_sections', array('course'=>$course->id, 'section'=>$sectionid))) {
|
|
throw new moodle_exception('AJAX commands.php: Bad section ID '.$sectionid);
|
|
}
|
|
|
|
if ($beforeid > 0){
|
|
$beforemod = get_coursemodule_from_id('', $beforeid, $course->id);
|
|
$beforemod = $DB->get_record('course_modules', array('id'=>$beforeid));
|
|
} else {
|
|
$beforemod = NULL;
|
|
}
|
|
|
|
$isvisible = moveto_module($cm, $section, $beforemod);
|
|
echo json_encode(array('visible' => (bool) $isvisible));
|
|
break;
|
|
}
|
|
break;
|
|
|
|
case 'course':
|
|
switch($field) {
|
|
case 'marker':
|
|
require_capability('moodle/course:setcurrentsection', $coursecontext);
|
|
course_set_marker($course->id, $value);
|
|
break;
|
|
}
|
|
break;
|
|
}
|
|
break;
|
|
|
|
case 'DELETE':
|
|
switch ($class) {
|
|
case 'resource':
|
|
require_capability('moodle/course:manageactivities', $modcontext);
|
|
course_delete_module($cm->id);
|
|
break;
|
|
}
|
|
break;
|
|
}
|