4, // whitelist of IPs which don't need to be authenticated // use '*' to allow any IP 'ip_whitelist' => array('127.0.0.1', '::1'), // bootstrap file, if defined this file will be included before // the code entered by the user is evaluated. any variables and classes // defined here will be accessible by the eval'd code 'bootstrap' => null, ); if (file_exists(__DIR__.'/config.php')) { $options = include __DIR__.'/config.php'; $options = array_merge($defaults, $options); } else { $options = $defaults; } /** * PHP Console * * A web-based php debug console * * Copyright (C) 2010, Jordi Boggiano * http://seld.be/ - j.boggiano@seld.be * * Licensed under the new BSD License * See the LICENSE file for details * * Source on Github http://github.com/Seldaek/php-console */ if (!in_array('*', $options['ip_whitelist'], true) && !in_array($_SERVER['REMOTE_ADDR'], $options['ip_whitelist'], true) ) { header('HTTP/1.1 401 Access unauthorized'); die('ERR/401 Go Away'); } define('PHP_CONSOLE_VERSION', '1.4.0'); require 'lib/MelodyPlugin.php'; require 'vendor/autoload.php'; ini_set('log_errors', 0); ini_set('display_errors', 1); error_reporting(E_ALL | E_STRICT); $debugOutput = ''; function runCode($__source_code, $__bootstrap_file) { if ($__bootstrap_file) { require $__bootstrap_file; } eval($__source_code); } if (isset($_POST['code'])) { ini_set('html_errors', false); if (get_magic_quotes_gpc()) { $code = stripslashes($code); } $code = $_POST['code']; // // if there's only one line wrap it into a krumo() call // if (preg_match('#^(?!var_dump|echo|print|< )([^\r\n]+?);?\s*$#is', $code, $m) && trim($m[1])) { // $code = 'krumo('.$m[1].');'; // } // replace '< foo' by krumo(foo) // $code = preg_replace('#^<\s+(.+?);?[\r\n]?$#m', 'krumo($1);', $code); // replace newlines in the entire code block by the new specified one // i.e. put #\r\n on the first line to emulate a file with windows line // endings if you're on a unix box if (preg_match('{#((?:\\\\[rn]){1,2})}', $code, $m)) { $newLineBreak = str_replace(array('\\n', '\\r'), array("\n", "\r"), $m[1]); $code = preg_replace('#(\r?\n|\r\n?)#', $newLineBreak, $code); } ob_start(); $memBefore = memory_get_usage(true); $start = microtime(true); $melodyPlugin = new MelodyPlugin(); if ($melodyPlugin->isMelodyScript($code)) { if ($melodyPlugin->isScriptingSupported()) { $melodyPlugin->runScript($code, $options['bootstrap']); } else { throw new Exception('php-console misses required dependencies to run melody scripts.'); } } else { // Important: replace only line by line, so the generated source lines will map 1:1 to the initial user input! $code = preg_replace('{^\s*<\?(php)?\s*}i', '', $code); runCode($code, $options['bootstrap']); } // compare with peak, because regular memory could be free'd already $end = microtime(true); $memAfter = memory_get_peak_usage(true); $debugOutput .= ob_get_clean(); if (isset($_GET['js'])) { header('Content-Type: text/plain'); $memory = sprintf('%.3f', ($memAfter - $memBefore) / 1024.0 / 1024.0); // in MB $rendertime = sprintf('%.3f', (($end - $start) * 1000)); // in ms header('X-Memory-Usage: '. $memory); header('X-Rendertime: '. $rendertime); echo $debugOutput; die('#end-php-console-output#'); } } ?> PHP Sandbox
Line: 1, Column: 1