Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 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.
13
//
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/>.
16
 
17
/**
18
 * Admin tool "Opcache management" - Main page
19
 *
20
 * @package    tool_opcache
21
 * @copyright  2017 Alexander Bias, Ulm University <alexander.bias@uni-ulm.de>
22
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23
 */
24
 
25
require(__DIR__ . '/../../../config.php');
26
require_once($CFG->libdir.'/adminlib.php');
27
 
28
// Set up the plugin's main page as external admin page.
29
admin_externalpage_setup('tool_opcache');
30
 
31
// Now: Distinguish the two possible request modes of opcache-gui.
32
// Request mode: Real-time update AJAX request.
33
// This request mode is identified in exactly the same way as opcache-gui does it itself.
34
if (!empty($_SERVER['HTTP_ACCEPT']) && stripos($_SERVER['HTTP_ACCEPT'], 'application/json') !== false) {
35
    // Include Opcache just for returning the AJAX request like it would work when Opcache GUI is called standalone.
36
    require_once(__DIR__ . '/lib/opcache-gui/index.php.inc');
37
 
38
    // Request mode: Display Opcache GUI.
39
} else {
40
    // Page setup.
41
    $title = get_string('pluginname', 'tool_opcache');
42
    $PAGE->set_url('/'.$CFG->admin.'/tool/opcache/index.php');
43
    $PAGE->set_title($title);
44
    $PAGE->set_heading($title);
45
 
46
    // Output has to be buffered because Opcache GUI might add headers which wouldn't be possible if output has already started.
47
    ob_start();
48
 
49
    // Page setup.
50
    echo $OUTPUT->header();
51
 
52
    // Include Opcache GUI.
53
    require_once(__DIR__ . '/lib/opcache-gui/index.php.inc');
54
 
55
    // Page setup.
56
    echo $OUTPUT->footer();
57
 
58
    // Output buffered content.
59
    ob_end_flush();
60
}