Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 4.1.x will end 13 November 2023 (12 months).
  • Bug fixes for security issues in 4.1.x will end 10 November 2025 (36 months).
  • PHP version: minimum PHP 7.4.0 Note: minimum PHP version has increased since Moodle 4.0. PHP 8.0.x is supported too.
<?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/>.

/**
 * Delete question page.
 *
 * This code is based on question/classes/bank/view.php
 *
 * @package    qbank_deletequestion
 * @copyright  2021 Catalyst IT Australia Pty Ltd
 * @author     Safat Shahin <safatshahin@catalyst-au.net>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

require_once(__DIR__ . '/../../../config.php');
require_once(__DIR__ . '/../../editlib.php');
global $DB, $OUTPUT, $PAGE, $COURSE;

$deleteselected = optional_param('deleteselected', false, PARAM_BOOL);
$returnurl = optional_param('returnurl', 0, PARAM_LOCALURL);
$cmid = optional_param('cmid', 0, PARAM_INT);
$courseid = optional_param('courseid', 0, PARAM_INT);
> $deleteall = optional_param('deleteall', false, PARAM_BOOL);
if ($returnurl) { $returnurl = new moodle_url($returnurl); } \core_question\local\bank\helper::require_plugin_enabled('qbank_deletequestion'); if ($cmid) { list($module, $cm) = get_module_from_cmid($cmid); require_login($cm->course, false, $cm); $thiscontext = context_module::instance($cmid); } else if ($courseid) { require_login($courseid, false); $thiscontext = context_course::instance($courseid); } else { throw new moodle_exception('missingcourseorcmid', 'question'); } $contexts = new core_question\local\bank\question_edit_contexts($thiscontext); $url = new moodle_url('/question/bank/deletequestion/delete.php'); $PAGE->set_url($url); $streditingquestions = get_string('deletequestion', 'qbank_deletequestion'); $PAGE->set_title($streditingquestions); $PAGE->set_heading($COURSE->fullname); $PAGE->activityheader->disable(); $PAGE->set_secondary_active_tab("questionbank"); // Unhide a question. if (($unhide = optional_param('unhide', '', PARAM_INT)) and confirm_sesskey()) { question_require_capability_on($unhide, 'edit'); $DB->set_field('question_versions', 'status', \core_question\local\bank\question_version_status::QUESTION_STATUS_READY, ['questionid' => $unhide]); // Purge these questions from the cache. \question_bank::notify_question_edited($unhide); redirect($returnurl); } // If user has already confirmed the action. if ($deleteselected && ($confirm = optional_param('confirm', '', PARAM_ALPHANUM)) && confirm_sesskey()) { $deleteselected = required_param('deleteselected', PARAM_RAW); if ($confirm == md5($deleteselected)) { if ($questionlist = explode(',', $deleteselected)) {
< // For each question either hide it if it is in use or delete it. < foreach ($questionlist as $questionid) { < $questionid = (int)$questionid; < question_require_capability_on($questionid, 'edit'); < question_delete_question($questionid); < }
> \qbank_deletequestion\helper::delete_questions($questionlist, $deleteall);
} redirect($returnurl); } else { throw new \moodle_exception('invalidconfirm', 'question'); } } echo $OUTPUT->header(); if ($deleteselected) { // Make a list of all the questions that are selected. $rawquestions = $_REQUEST; // This code is called by both POST forms and GET links, so cannot use data_submitted. $questionlist = ''; // Comma separated list of ids of questions to be deleted.
< $questionnames = ''; // String with names of questions separated by <br/> with an asterix in front of those that are in use. < $inuse = false; // Set to true if at least one of the questions is in use.
foreach ($rawquestions as $key => $value) { // Parse input for question ids. if (preg_match('!^q([0-9]+)$!', $key, $matches)) { $key = $matches[1]; $questionlist .= $key.','; question_require_capability_on((int)$key, 'edit');
< if (questions_in_use(array($key))) { < $questionnames .= '* '; < $inuse = true; < } < $questionnames .= $DB->get_field('question', 'name', array('id' => $key)) . '<br />';
} } if (!$questionlist) { // No questions were selected. redirect($returnurl); } $questionlist = rtrim($questionlist, ',');
< // Add an explanation about questions in use. < if ($inuse) { < $questionnames .= '<br />'.get_string('questionsinuse', 'question'); < } < $deleteurl = new \moodle_url('/question/bank/deletequestion/delete.php', < array('deleteselected' => $questionlist, 'confirm' => md5($questionlist), < 'sesskey' => sesskey(), 'returnurl' => $returnurl, 'cmid' => $cmid, 'courseid' => $courseid)); <
> $deleteurl = new \moodle_url('/question/bank/deletequestion/delete.php', [ > 'deleteselected' => $questionlist, 'deleteall' => $deleteall, 'confirm' => md5($questionlist), > 'sesskey' => sesskey(), 'returnurl' => $returnurl, 'cmid' => $cmid, 'courseid' => $courseid, > ]);
$continue = new \single_button($deleteurl, get_string('delete'), 'post');
< echo $OUTPUT->confirm(get_string('deletequestionscheck', 'question', $questionnames), $continue, $returnurl);
> > $questionids = explode(',', $questionlist); > [$displayoptions, $message] = qbank_deletequestion\helper::get_delete_confirmation_message($questionids, > $deleteall); > > echo $OUTPUT->confirm($message, $continue, $returnurl, $displayoptions);
} echo $OUTPUT->footer();