See Release Notes
Long Term Support Release
<?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/>.< /** < * A {@link qubaid_condition} representing all the attempts by one user at a given quiz. < * < * @package mod_quiz < * @category question < * @copyright 2015 The Open University < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */ <namespace mod_quiz\question;> use mod_quiz\quiz_attempt; defined('MOODLE_INTERNAL') || die(); >< require_once($CFG->dirroot.'/mod/quiz/attemptlib.php');> require_once($CFG->dirroot . '/question/engine/datalib.php');/**< * A {@link qubaid_condition} representing all the attempts by one user at a given quiz.> * A {@see qubaid_condition} representing all the attempts by one user at a given quiz.*> * @package mod_quiz * @copyright 2015 The Open University > * @category question* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class qubaids_for_users_attempts extends \qubaid_join { /** * Constructor. * * This takes the same arguments as {@link quiz_get_user_attempts()}. * * @param int $quizid the quiz id. * @param int $userid the userid. * @param string $status 'all', 'finished' or 'unfinished' to control * @param bool $includepreviews defaults to false. */ public function __construct($quizid, $userid, $status = 'finished', $includepreviews = false) { $where = 'quiza.quiz = :quizaquiz AND quiza.userid = :userid';< $params = array('quizaquiz' => $quizid, 'userid' => $userid);> $params = ['quizaquiz' => $quizid, 'userid' => $userid];if (!$includepreviews) { $where .= ' AND preview = 0'; } switch ($status) { case 'all': break; case 'finished': $where .= ' AND state IN (:state1, :state2)';< $params['state1'] = \quiz_attempt::FINISHED; < $params['state2'] = \quiz_attempt::ABANDONED;> $params['state1'] = quiz_attempt::FINISHED; > $params['state2'] = quiz_attempt::ABANDONED;break; case 'unfinished': $where .= ' AND state IN (:state1, :state2)';< $params['state1'] = \quiz_attempt::IN_PROGRESS; < $params['state2'] = \quiz_attempt::OVERDUE;> $params['state1'] = quiz_attempt::IN_PROGRESS; > $params['state2'] = quiz_attempt::OVERDUE;break; } parent::__construct('{quiz_attempts} quiza', 'quiza.uniqueid', $where, $params); } }