-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.php
61 lines (53 loc) · 2.42 KB
/
index.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
<?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/>.
/**
* Custom SQL report.
*
* Users with the report/lsusql:definequeries capability can enter custom
* SQL SELECT statements. If they have report/lsusql:managecategories
* capability can create custom categories for the sql reports.
* Other users with the moodle/site:viewreports capability
* can see the list of available queries and run them. Reports are displayed as
* a table. Every data value is a string, and field names come from the database
* results set.
*
* This page shows the list of categorised queries, with edit icons, an add new button
* if you have the report/lsusql:definequeries capability, and a manage categories button
* ff you have report/lsusql:managecategories capability
*
* @package report_lsusql
* @copyright 2009 The Open University
* @copyright 2022 Louisiana State University
* @copyright 2022 Robert Russo
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once(dirname(__FILE__) . '/../../config.php');
require_once(dirname(__FILE__) . '/locallib.php');
require_once($CFG->libdir . '/adminlib.php');
// Start the page.
admin_externalpage_setup('report_lsusql');
$context = context_system::instance();
require_capability('report/lsusql:view', $context);
$categories = $DB->get_records('report_lsusql_categories', null, 'name, id');
$queries = $DB->get_records('report_lsusql_queries', null, 'displayname, id');
$showcat = optional_param('showcat', 0, PARAM_INT);
$hidecat = optional_param('hidecat', 0, PARAM_INT);
$returnurl = report_lsusql_url('index.php');
$widget = new \report_lsusql\output\index_page($categories, $queries, $context, $returnurl, $showcat, $hidecat);
$output = $PAGE->get_renderer('report_lsusql');
echo $OUTPUT->header();
echo $output->render($widget);
echo $OUTPUT->footer();