AnonSec Team
Server IP : 103.11.96.170  /  Your IP : 18.118.31.32
Web Server : Microsoft-IIS/10.0
System : Windows NT WIN-F6SLGVICLOP 10.0 build 17763 (Windows Server 2016) AMD64
User : elibrary.unsap.ac.id ( 0)
PHP Version : 7.4.19
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : OFF  |  Perl : OFF  |  Python : OFF
Directory (0777) :  D:/localhost/lms/course/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : D:/localhost/lms/course/rest.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(__DIR__ . '/../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);
$sectionid  = optional_param('sectionId', 0, PARAM_INT);
$beforeid   = optional_param('beforeId', 0, PARAM_INT);
$value      = optional_param('value', 0, PARAM_INT);
$id         = optional_param('id', 0, PARAM_INT);

$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

if ($class === 'section' && $field === 'move') {
    if (!$DB->record_exists('course_sections', array('course' => $course->id, 'section' => $id))) {
        throw new moodle_exception('AJAX commands.php: Bad Section ID ' . $id);
    }

    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);
    }

} else if ($class === 'resource' && $field === '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));
}

AnonSec - 2021