Search moodle.org's
Developer Documentation

See Release Notes

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

< /** < * 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;
> defined('MOODLE_INTERNAL') || die(); > use mod_quiz\quiz_attempt; >
> 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); } }