MDL-76614 quiz: move class quiz_attempt => mod_quiz\quiz_attempt
[moodle.git] / mod / quiz / classes / question / qubaids_for_users_attempts.php
blob2f4c7ba1abfe3b3beed117fcd3edf6631dcb2928
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
17 namespace mod_quiz\question;
19 use mod_quiz\quiz_attempt;
21 defined('MOODLE_INTERNAL') || die();
23 require_once($CFG->dirroot . '/question/engine/datalib.php');
24 require_once($CFG->dirroot.'/mod/quiz/attemptlib.php');
26 /**
27 * A {@see qubaid_condition} representing all the attempts by one user at a given quiz.
29 * @package mod_quiz
30 * @category question
31 * @copyright 2015 The Open University
32 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
34 class qubaids_for_users_attempts extends \qubaid_join {
35 /**
36 * Constructor.
38 * This takes the same arguments as {@link quiz_get_user_attempts()}.
40 * @param int $quizid the quiz id.
41 * @param int $userid the userid.
42 * @param string $status 'all', 'finished' or 'unfinished' to control
43 * @param bool $includepreviews defaults to false.
45 public function __construct($quizid, $userid, $status = 'finished', $includepreviews = false) {
46 $where = 'quiza.quiz = :quizaquiz AND quiza.userid = :userid';
47 $params = ['quizaquiz' => $quizid, 'userid' => $userid];
49 if (!$includepreviews) {
50 $where .= ' AND preview = 0';
53 switch ($status) {
54 case 'all':
55 break;
57 case 'finished':
58 $where .= ' AND state IN (:state1, :state2)';
59 $params['state1'] = quiz_attempt::FINISHED;
60 $params['state2'] = quiz_attempt::ABANDONED;
61 break;
63 case 'unfinished':
64 $where .= ' AND state IN (:state1, :state2)';
65 $params['state1'] = quiz_attempt::IN_PROGRESS;
66 $params['state2'] = quiz_attempt::OVERDUE;
67 break;
70 parent::__construct('{quiz_attempts} quiza', 'quiza.uniqueid', $where, $params);