ILIAS  trunk Revision v11.0_alpha-1689-g66c127b4ae8
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilTestResultsToXML.php
Go to the documentation of this file.
1 <?php
2 
19 declare(strict_types=1);
20 
22 {
23  private $active_ids;
24 
26 
27  public function __construct(
28  private int $test_id,
29  private ilDBInterface $db,
30  private bool $anonymized = false
31  ) {
33  }
34 
35  public function isIncludeRandomTestQuestionsEnabled(): bool
36  {
38  }
39 
40  public function setIncludeRandomTestQuestionsEnabled(bool $include_random_test_questions_enabled): void
41  {
42  $this->include_random_test_questions_enabled = $include_random_test_questions_enabled;
43  }
44 
45  protected function exportActiveIDs(): void
46  {
47  $assessment_setting = new ilSetting('assessment');
48  $user_criteria = $assessment_setting->get('user_criteria');
49  if ($user_criteria === null || $user_criteria === '') {
50  $user_criteria = 'usr_id';
51  }
52 
53  if ($this->anonymized) {
54  $result = $this->db->queryF(
55  'SELECT * FROM tst_active WHERE test_fi = %s',
56  ['integer'],
57  [$this->test_id]
58  );
59  } else {
60  $result = $this->db->queryF(
61  'SELECT tst_active.*, usr_data.' . $user_criteria . ' FROM tst_active, usr_data WHERE tst_active.test_fi = %s AND tst_active.user_fi = usr_data.usr_id',
62  ['integer'],
63  [$this->test_id]
64  );
65  }
66  $this->xmlStartTag('tst_active', null);
67  while ($row = $this->db->fetchAssoc($result)) {
68  $attrs = [
69  'active_id' => $row['active_id'],
70  'user_fi' => $row['user_fi'] ?? '',
71  'anonymous_id' => $row['anonymous_id'] ?? '',
72  'test_fi' => $row['test_fi'],
73  'lastindex' => $row['lastindex'] ?? '',
74  'tries' => $row['tries'] ?? '',
75  'last_started_pass' => $row['last_started_pass'] ?? '',
76  'last_finished_pass' => $row['last_finished_pass'] ?? '',
77  'submitted' => $row['submitted'] ?? '',
78  'submittimestamp' => $row['submittimestamp'] ?? '',
79  'tstamp' => $row['tstamp'] ?? ''
80  ];
81  $attrs['fullname'] = ilObjTestAccess::_getParticipantData($row['active_id']);
82  if (!$this->anonymized) {
83  $attrs['user_criteria'] = $user_criteria;
84  $attrs[$user_criteria] = $row[$user_criteria];
85  }
86  array_push($this->active_ids, $row['active_id']);
87  $this->xmlElement('row', $attrs);
88  }
89  $this->xmlEndTag('tst_active');
90  }
91 
92  protected function exportPassResult(): void
93  {
94  $query = 'SELECT * FROM tst_pass_result WHERE ' . $this->db->in('active_fi', $this->active_ids, false, 'integer') . ' ORDER BY active_fi, pass';
95  $result = $this->db->query($query);
96  $this->xmlStartTag('tst_pass_result', null);
97  while ($row = $this->db->fetchAssoc($result)) {
98  $attrs = [
99  'active_fi' => $row['active_fi'],
100  'pass' => $row['pass'] ?? '',
101  'points' => $row['points'] ?? '',
102  'maxpoints' => $row['maxpoints'] ?? '',
103  'questioncount' => $row['questioncount'] ?? '',
104  'answeredquestions' => $row['answeredquestions'] ?? '',
105  'workingtime' => $row['workingtime'] ?? '',
106  'tstamp' => $row['tstamp'] ?? ''
107  ];
108  $this->xmlElement('row', $attrs);
109  }
110  $this->xmlEndTag('tst_pass_result');
111  }
112 
113  protected function exportResultCache(): void
114  {
115  $query = 'SELECT * FROM tst_result_cache WHERE ' . $this->db->in('active_fi', $this->active_ids, false, 'integer') . ' ORDER BY active_fi';
116  $result = $this->db->query($query);
117  $this->xmlStartTag('tst_result_cache', null);
118  while ($row = $this->db->fetchAssoc($result)) {
119  $attrs = [
120  'active_fi' => $row['active_fi'],
121  'pass' => $row['pass'],
122  'max_points' => $row['max_points'],
123  'reached_points' => $row['reached_points'],
124  'mark_short' => $row['mark_short'],
125  'mark_official' => $row['mark_official'],
126  'passed' => $row['passed'],
127  'failed' => $row['failed'],
128  'tstamp' => $row['tstamp']
129  ];
130  $this->xmlElement('row', $attrs);
131  }
132  $this->xmlEndTag('tst_result_cache');
133  }
134 
135  protected function exportTestSequence(): void
136  {
137  $query = 'SELECT * FROM tst_sequence WHERE ' . $this->db->in('active_fi', $this->active_ids, false, 'integer') . ' ORDER BY active_fi, pass';
138  $result = $this->db->query($query);
139  $this->xmlStartTag('tst_sequence', null);
140  while ($row = $this->db->fetchAssoc($result)) {
141  $attrs = [
142  'active_fi' => $row['active_fi'],
143  'pass' => $row['pass'] ?? '',
144  'sequence' => $row['sequence'] ?? '',
145  'postponed' => $row['postponed'] ?? '',
146  'hidden' => $row['hidden'] ?? '',
147  'tstamp' => $row['tstamp'] ?? ''
148  ];
149  $this->xmlElement('row', $attrs);
150  }
151  $this->xmlEndTag('tst_sequence');
152  }
153 
154  protected function exportTestSolutions(): void
155  {
156  $query = 'SELECT * FROM tst_solutions WHERE ' . $this->db->in('active_fi', $this->active_ids, false, 'integer') . ' ORDER BY solution_id';
157  $result = $this->db->query($query);
158  $this->xmlStartTag('tst_solutions', null);
159  while ($row = $this->db->fetchAssoc($result)) {
160  $attrs = [
161  'solution_id' => $row['solution_id'],
162  'active_fi' => $row['active_fi'],
163  'question_fi' => $row['question_fi'],
164  'points' => $row['points'] ?? '',
165  'pass' => $row['pass'] ?? '',
166  'value1' => $row['value1'] ?? '',
167  'value2' => $row['value2'] ?? '',
168  'tstamp' => $row['tstamp'] ?? ''
169  ];
170  $this->xmlElement('row', $attrs);
171  }
172  $this->xmlEndTag('tst_solutions');
173  }
174 
175  protected function exportRandomTestQuestions(): void
176  {
177  $result = $this->db->query("
178  SELECT * FROM tst_test_rnd_qst
179  WHERE {$this->db->in('active_fi', $this->active_ids, false, 'integer')}
180  ORDER BY test_random_question_id
181  ");
182 
183  $this->xmlStartTag('tst_test_rnd_qst', null);
184  while ($row = $this->db->fetchAssoc($result)) {
185  $attrs = [];
186 
187  foreach ($row as $field => $value) {
188  $attrs[$field] = $value;
189  }
190 
191  $this->xmlElement('row', $attrs);
192  }
193  $this->xmlEndTag('tst_test_rnd_qst');
194  }
195 
196 
197  protected function exportTestResults(): void
198  {
199  $query = 'SELECT * FROM tst_test_result WHERE ' . $this->db->in('active_fi', $this->active_ids, false, 'integer') . ' ORDER BY active_fi';
200  $result = $this->db->query($query);
201  $this->xmlStartTag('tst_test_result', null);
202  while ($row = $this->db->fetchAssoc($result)) {
203  $attrs = [
204  'test_result_id' => $row['test_result_id'],
205  'active_fi' => $row['active_fi'],
206  'question_fi' => $row['question_fi'],
207  'points' => $row['points'] ?? '',
208  'pass' => $row['pass'] ?? '',
209  'manual' => $row['manual'] ?? '',
210  'tstamp' => $row['tstamp'] ?? ''
211  ];
212  $this->xmlElement('row', $attrs);
213  }
214  $this->xmlEndTag('tst_test_result');
215  }
216 
217  protected function exportTestTimes(): void
218  {
219  $query = 'SELECT * FROM tst_times WHERE ' . $this->db->in('active_fi', $this->active_ids, false, 'integer') . ' ORDER BY active_fi';
220  $result = $this->db->query($query);
221  $this->xmlStartTag('tst_times', null);
222  while ($row = $this->db->fetchAssoc($result)) {
223  $attrs = [
224  'times_id' => $row['times_id'],
225  'active_fi' => $row['active_fi'],
226  'started' => $row['started'],
227  'finished' => $row['finished'],
228  'pass' => $row['pass'],
229  'tstamp' => $row['tstamp']
230  ];
231  $this->xmlElement('row', $attrs);
232  }
233  $this->xmlEndTag('tst_times');
234  }
235 
236  public function getXML(): void
237  {
238  $this->active_ids = [];
239  $this->xmlHeader();
240  $attrs = ['version' => '4.1.0'];
241  $this->xmlStartTag('results', $attrs);
242  $this->exportActiveIDs();
243 
245  $this->exportRandomTestQuestions();
246  }
247 
248  $this->exportPassResult();
249  $this->exportResultCache();
250  $this->exportTestSequence();
251  $this->exportTestSolutions();
252  $this->exportTestResults();
253  $this->exportTestTimes();
254  $this->xmlEndTag('results');
255  }
256 
257  public function xmlDumpMem(bool $format = true): string
258  {
259  $this->getXML();
260  return parent::xmlDumpMem($format);
261  }
262 
263  public function xmlDumpFile(string $file, bool $format = true): void
264  {
265  $this->getXML();
266  parent::xmlDumpFile($file, $format);
267  }
268 }
__construct(private int $test_id, private ilDBInterface $db, private bool $anonymized=false)
static _getParticipantData($active_id)
Retrieves a participant name from active id.
xmlDumpFile(string $file, bool $format=true)
xmlDumpMem(bool $format=true)
xmlEndTag(string $tag)
Writes an endtag.
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
setIncludeRandomTestQuestionsEnabled(bool $include_random_test_questions_enabled)
xmlHeader()
Writes xml header.
__construct(Container $dic, ilPlugin $plugin)
xmlStartTag(string $tag, ?array $attrs=null, bool $empty=false, bool $encode=true, bool $escape=true)
Writes a starttag.
xmlElement(string $tag, $attrs=null, $data=null, $encode=true, $escape=true)
Writes a basic element (no children, just textual content)