forked from maths/moodle-qtype_stack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcascacheview.php
76 lines (65 loc) · 2.53 KB
/
cascacheview.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
<?php
// This file is part of Stack - http://stack.maths.ed.ac.uk/
//
// Stack 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.
//
// Stack 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 Stack. If not, see <http://www.gnu.org/licenses/>.
/**
* This script lets the user see the latest commands stored to CAS
* cache as pretty printted presentations. This exists for debugging.
*
* @copyright 2019 Aalto University
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once(__DIR__.'/../../../../config.php');
require_once($CFG->libdir . '/questionlib.php');
require_once(__DIR__ . '/../locallib.php');
require_once(__DIR__ . '/../stack/utils.class.php');
require_once(__DIR__ . '/../stack/options.class.php');
require_once(__DIR__ . '/../stack/maximaparser/utils.php');
require_login();
$context = context_system::instance();
require_capability('qtype/stack:usediagnostictools', $context);
$urlparams = [];
$context = context_system::instance();
$PAGE->set_context($context);
$PAGE->set_url('/question/type/stack/adminui/cascacheview.php', $urlparams);
$title = 'Cache debug';
$PAGE->set_title($title);
// Get the ten latest cached things.
$data = $DB->get_recordset_sql('SELECT * FROM {qtype_stack_cas_cache} ORDER BY id DESC LIMIT 10;');
echo $OUTPUT->header();
echo $OUTPUT->heading($title);
$i = 0;
foreach ($data as $item) {
$i++;
echo '<h2>item ' . $i . '</h2>';
echo '<pre>';
// Ends with $ which is bad.
// Now can contain $ signs elsewhere as well...
$ast = maxima_parser_utils::parse(str_replace('$', ';', $item->command));
$str = $ast->toString(['pretty' => true]);
$str = str_replace('&', '&', $str);
$str = str_replace('<', '<', $str);
$str = str_replace('>', '>', $str);
echo $str;
echo '</pre>';
echo '<pre>';
$json = json_decode($item->result);
$str = json_encode($json, JSON_UNESCAPED_SLASHES | JSON_PRETTY_PRINT);
$str = str_replace('&', '&', $str);
$str = str_replace('<', '<', $str);
$str = str_replace('>', '>', $str);
echo $str;
echo '</pre>';
}
echo $OUTPUT->footer();