. /** * This page is used to regenerate and preview a maintenance mode static page. * * @package auth_outage * @author Daniel Thee Roperto * @copyright 2016 Catalyst IT * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ use auth_outage\dml\outagedb; use auth_outage\local\controllers\maintenance_static_page; if (isset($_GET['file'])) { define('NO_DEBUG_DISPLAY', true); define('ABORT_AFTER_CONFIG', true); require_once(__DIR__.'/../../config.php'); // We are not using any external libraries or references in this file (cli maintenance is active). // If you change the path below maybe you need to change maintenance_static_page::get_resources_folder() as well. $resourcedir = $CFG->dataroot.'/auth_outage/climaintenance'; // Protect against path traversal attacks. $file = $resourcedir.'/'.basename($_GET['file']); if (realpath($file) !== $file) { error_log('Invalid file: '.$_GET['file']); http_response_code(404); die('Not found.'); } // Detect type, we only support css or PNG images. $type = substr($file, -3); if ($type == 'css') { header('Content-type: text/css'); } else { header('Content-type: image/png'); } readfile($file); return; }