2017-04-20 12:55:30 +02:00
|
|
|
<?php
|
|
|
|
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
2016-10-22 16:57:10 +02:00
|
|
|
/**
|
|
|
|
* Output buffering wrapper
|
|
|
|
*
|
|
|
|
* @package PhpMyAdmin
|
|
|
|
*/
|
2017-04-20 12:55:30 +02:00
|
|
|
if (! defined('PHPMYADMIN')) {
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
require_once './libraries/Util.class.php';
|
2016-10-22 16:57:10 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Output buffering wrapper class
|
|
|
|
*
|
|
|
|
* @package PhpMyAdmin
|
|
|
|
*/
|
2017-04-20 12:55:30 +02:00
|
|
|
class PMA_OutputBuffering
|
2016-10-22 16:57:10 +02:00
|
|
|
{
|
|
|
|
private static $_instance;
|
|
|
|
private $_mode;
|
|
|
|
private $_content;
|
|
|
|
private $_on;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializes class
|
2017-04-20 12:55:30 +02:00
|
|
|
*
|
|
|
|
* @return void
|
2016-10-22 16:57:10 +02:00
|
|
|
*/
|
|
|
|
private function __construct()
|
|
|
|
{
|
|
|
|
$this->_mode = $this->_getMode();
|
|
|
|
$this->_on = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function could be used eventually to support more modes.
|
|
|
|
*
|
|
|
|
* @return integer the output buffer mode
|
|
|
|
*/
|
|
|
|
private function _getMode()
|
|
|
|
{
|
|
|
|
$mode = 0;
|
|
|
|
if ($GLOBALS['cfg']['OBGzip'] && function_exists('ob_start')) {
|
|
|
|
if (ini_get('output_handler') == 'ob_gzhandler') {
|
|
|
|
// If a user sets the output_handler in php.ini to ob_gzhandler, then
|
|
|
|
// any right frame file in phpMyAdmin will not be handled properly by
|
|
|
|
// the browser. My fix was to check the ini file within the
|
|
|
|
// PMA_outBufferModeGet() function.
|
|
|
|
$mode = 0;
|
|
|
|
} elseif (function_exists('ob_get_level') && ob_get_level() > 0) {
|
2017-04-20 12:55:30 +02:00
|
|
|
// If output buffering is enabled in php.ini it's not possible to
|
|
|
|
// add the ob_gzhandler without a warning message from php 4.3.0.
|
|
|
|
// Being better safe than sorry, check for any existing output handler
|
|
|
|
// instead of just checking the 'output_buffering' setting.
|
|
|
|
$mode = 0;
|
2016-10-22 16:57:10 +02:00
|
|
|
} else {
|
|
|
|
$mode = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Zero (0) is no mode or in other words output buffering is OFF.
|
|
|
|
// Follow 2^0, 2^1, 2^2, 2^3 type values for the modes.
|
2017-04-20 12:55:30 +02:00
|
|
|
// Usefull if we ever decide to combine modes. Then a bitmask field of
|
2016-10-22 16:57:10 +02:00
|
|
|
// the sum of all modes will be the natural choice.
|
|
|
|
return $mode;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-04-20 12:55:30 +02:00
|
|
|
* Returns the singleton PMA_OutputBuffering object
|
2016-10-22 16:57:10 +02:00
|
|
|
*
|
2017-04-20 12:55:30 +02:00
|
|
|
* @return PMA_OutputBuffering object
|
2016-10-22 16:57:10 +02:00
|
|
|
*/
|
|
|
|
public static function getInstance()
|
|
|
|
{
|
|
|
|
if (empty(self::$_instance)) {
|
2017-04-20 12:55:30 +02:00
|
|
|
self::$_instance = new PMA_OutputBuffering();
|
2016-10-22 16:57:10 +02:00
|
|
|
}
|
|
|
|
return self::$_instance;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will need to run at the top of all pages if output
|
|
|
|
* output buffering is turned on. It also needs to be passed $mode from
|
|
|
|
* the PMA_outBufferModeGet() function or it will be useless.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function start()
|
|
|
|
{
|
|
|
|
if (! $this->_on) {
|
2017-04-20 12:55:30 +02:00
|
|
|
if ($this->_mode) {
|
2016-10-22 16:57:10 +02:00
|
|
|
ob_start('ob_gzhandler');
|
|
|
|
}
|
|
|
|
ob_start();
|
|
|
|
if (! defined('TESTSUITE')) {
|
|
|
|
header('X-ob_mode: ' . $this->_mode);
|
|
|
|
}
|
2017-04-20 12:55:30 +02:00
|
|
|
register_shutdown_function(array('PMA_OutputBuffering', 'stop'));
|
2016-10-22 16:57:10 +02:00
|
|
|
$this->_on = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will need to run at the bottom of all pages if output
|
|
|
|
* buffering is turned on. It also needs to be passed $mode from the
|
|
|
|
* PMA_outBufferModeGet() function or it will be useless.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public static function stop()
|
|
|
|
{
|
2017-04-20 12:55:30 +02:00
|
|
|
$buffer = PMA_OutputBuffering::getInstance();
|
2016-10-22 16:57:10 +02:00
|
|
|
if ($buffer->_on) {
|
|
|
|
$buffer->_on = false;
|
|
|
|
$buffer->_content = ob_get_contents();
|
|
|
|
ob_end_clean();
|
|
|
|
}
|
2017-04-20 12:55:30 +02:00
|
|
|
PMA_Response::response();
|
2016-10-22 16:57:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets buffer content
|
|
|
|
*
|
2017-04-20 12:55:30 +02:00
|
|
|
* @return buffer content
|
2016-10-22 16:57:10 +02:00
|
|
|
*/
|
|
|
|
public function getContents()
|
|
|
|
{
|
|
|
|
return $this->_content;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Flushes output buffer
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function flush()
|
|
|
|
{
|
|
|
|
if (ob_get_status() && $this->_mode) {
|
|
|
|
ob_flush();
|
|
|
|
}
|
2017-04-20 12:55:30 +02:00
|
|
|
/**
|
|
|
|
* previously we had here an "else flush()" but some PHP versions
|
|
|
|
* (at least PHP 5.2.11) have a bug (49816) that produces garbled
|
|
|
|
* data
|
|
|
|
*/
|
2016-10-22 16:57:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-20 12:55:30 +02:00
|
|
|
?>
|