Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.3.x will end 7 October 2024 (12 months).
  • Bug fixes for security issues in 4.3.x will end 21 April 2025 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.2.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/>.

/**
 * Quiz external functions and service definitions.
 *
 * @package    mod_quiz
 * @category   external
 * @copyright  2016 Juan Leyva <juan@moodle.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @since      Moodle 3.1
 */

defined('MOODLE_INTERNAL') || die;

< $functions = array(
> $functions = [
< 'mod_quiz_get_quizzes_by_courses' => array(
> 'mod_quiz_get_quizzes_by_courses' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_quizzes_by_courses', 'description' => 'Returns a list of quizzes in a provided list of courses, if no list is provided all quizzes that the user can view will be returned.', 'type' => 'read', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_view_quiz' => array(
> 'mod_quiz_view_quiz' => [
'classname' => 'mod_quiz_external', 'methodname' => 'view_quiz', 'description' => 'Trigger the course module viewed event and update the module completion status.', 'type' => 'write', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_user_attempts' => array(
> 'mod_quiz_get_user_attempts' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_user_attempts', 'description' => 'Return a list of attempts for the given quiz and user.', 'type' => 'read', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_user_best_grade' => array(
> 'mod_quiz_get_user_best_grade' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_user_best_grade', 'description' => 'Get the best current grade for the given user on a quiz.', 'type' => 'read', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_combined_review_options' => array(
> 'mod_quiz_get_combined_review_options' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_combined_review_options', 'description' => 'Combines the review options from a number of different quiz attempts.', 'type' => 'read', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_start_attempt' => array(
> 'mod_quiz_start_attempt' => [
'classname' => 'mod_quiz_external', 'methodname' => 'start_attempt', 'description' => 'Starts a new attempt at a quiz.', 'type' => 'write', 'capabilities' => 'mod/quiz:attempt',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_attempt_data' => array(
> 'mod_quiz_get_attempt_data' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_attempt_data', 'description' => 'Returns information for the given attempt page for a quiz attempt in progress.', 'type' => 'read', 'capabilities' => 'mod/quiz:attempt',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_attempt_summary' => array(
> 'mod_quiz_get_attempt_summary' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_attempt_summary', 'description' => 'Returns a summary of a quiz attempt before it is submitted.', 'type' => 'read', 'capabilities' => 'mod/quiz:attempt',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_save_attempt' => array(
> 'mod_quiz_save_attempt' => [
'classname' => 'mod_quiz_external', 'methodname' => 'save_attempt', 'description' => 'Processes save requests during the quiz. This function is intended for the quiz auto-save feature.', 'type' => 'write', 'capabilities' => 'mod/quiz:attempt',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_process_attempt' => array(
> 'mod_quiz_process_attempt' => [
'classname' => 'mod_quiz_external', 'methodname' => 'process_attempt', 'description' => 'Process responses during an attempt at a quiz and also deals with attempts finishing.', 'type' => 'write', 'capabilities' => 'mod/quiz:attempt',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_attempt_review' => array(
> 'mod_quiz_get_attempt_review' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_attempt_review', 'description' => 'Returns review information for the given finished attempt, can be used by users or teachers.', 'type' => 'read', 'capabilities' => 'mod/quiz:reviewmyattempts',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_view_attempt' => array(
> 'mod_quiz_view_attempt' => [
'classname' => 'mod_quiz_external', 'methodname' => 'view_attempt', 'description' => 'Trigger the attempt viewed event.', 'type' => 'write', 'capabilities' => 'mod/quiz:attempt',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_view_attempt_summary' => array(
> 'mod_quiz_view_attempt_summary' => [
'classname' => 'mod_quiz_external', 'methodname' => 'view_attempt_summary', 'description' => 'Trigger the attempt summary viewed event.', 'type' => 'write', 'capabilities' => 'mod/quiz:attempt',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_view_attempt_review' => array(
> 'mod_quiz_view_attempt_review' => [
'classname' => 'mod_quiz_external', 'methodname' => 'view_attempt_review', 'description' => 'Trigger the attempt reviewed event.', 'type' => 'write', 'capabilities' => 'mod/quiz:reviewmyattempts',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_quiz_feedback_for_grade' => array(
> 'mod_quiz_get_quiz_feedback_for_grade' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_quiz_feedback_for_grade', 'description' => 'Get the feedback text that should be show to a student who got the given grade in the given quiz.', 'type' => 'read', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_quiz_access_information' => array(
> 'mod_quiz_get_quiz_access_information' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_quiz_access_information', 'description' => 'Return access information for a given quiz.', 'type' => 'read', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_attempt_access_information' => array(
> 'mod_quiz_get_attempt_access_information' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_attempt_access_information', 'description' => 'Return access information for a given attempt in a quiz.', 'type' => 'read', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ),
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ],
< 'mod_quiz_get_quiz_required_qtypes' => array(
> 'mod_quiz_get_quiz_required_qtypes' => [
'classname' => 'mod_quiz_external', 'methodname' => 'get_quiz_required_qtypes', 'description' => 'Return the potential question types that would be required for a given quiz.', 'type' => 'read', 'capabilities' => 'mod/quiz:view',
< 'services' => array(MOODLE_OFFICIAL_MOBILE_SERVICE) < ), < );
> 'services' => [MOODLE_OFFICIAL_MOBILE_SERVICE] > ], > > 'mod_quiz_set_question_version' => [ > 'classname' => 'mod_quiz\external\submit_question_version', > 'description' => 'Set the version of question that would be required for a given quiz.', > 'type' => 'write', > 'capabilities' => 'mod/quiz:view', > 'ajax' => true, > ], > > 'mod_quiz_reopen_attempt' => [ > 'classname' => 'mod_quiz\external\reopen_attempt', > 'description' => 'Re-open an attempt that is currently in the never submitted state.', > 'type' => 'write', > 'capabilities' => 'mod/quiz:reopenattempts', > 'ajax' => true, > ], > > 'mod_quiz_get_reopen_attempt_confirmation' => [ > 'classname' => 'mod_quiz\external\get_reopen_attempt_confirmation', > 'description' => 'Verify it is OK to re-open a given quiz attempt, and if so, return a suitable confirmation message.', > 'type' => 'read', > 'capabilities' => 'mod/quiz:reopenattempts', > 'ajax' => true, > ], > > 'mod_quiz_add_random_questions' => [ > 'classname' => 'mod_quiz\external\add_random_questions', > 'description' => 'Add a number of random questions to a quiz.', > 'type' => 'write', > 'capabilities' => 'mod/quiz:manage', > 'ajax' => true, > ], > > 'mod_quiz_update_filter_condition' => [ > 'classname' => 'mod_quiz\external\update_filter_condition', > 'description' => 'Update filter condition for a random question slot.', > 'type' => 'write', > 'capabilities' => 'mod/quiz:manage', > 'ajax' => true, > ], > ];