You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

124 lines
2.9 KiB

<?php
/**
* @link http://www.yiiframework.com/
* @copyright Copyright (c) 2008 Yii Software LLC
* @license http://www.yiiframework.com/license/
*/
namespace yii\debug\controllers;
use Yii;
use yii\web\Controller;
use yii\web\NotFoundHttpException;
/**
* @author Qiang Xue <qiang.xue@gmail.com>
* @since 2.0
*/
class DefaultController extends Controller
{
12 years ago
public $layout = 'main';
12 years ago
/**
* @var \yii\debug\Module
*/
public $module;
/**
* @var array the summary data (e.g. URL, time)
*/
public $summary;
12 years ago
public function actions()
{
$actions = [];
foreach($this->module->panels as $panel) {
$actions = array_merge($actions, $panel->actions);
}
return $actions;
}
public function actionIndex()
{
return $this->render('index', ['manifest' => $this->getManifest()]);
}
public function actionView($tag = null, $panel = null)
{
12 years ago
if ($tag === null) {
$tags = array_keys($this->getManifest());
$tag = reset($tags);
12 years ago
}
12 years ago
$this->loadData($tag);
12 years ago
if (isset($this->module->panels[$panel])) {
$activePanel = $this->module->panels[$panel];
} else {
12 years ago
$activePanel = $this->module->panels['request'];
12 years ago
}
return $this->render('view', [
12 years ago
'tag' => $tag,
12 years ago
'summary' => $this->summary,
12 years ago
'manifest' => $this->getManifest(),
12 years ago
'panels' => $this->module->panels,
'activePanel' => $activePanel,
]);
}
public function actionToolbar($tag)
{
$this->loadData($tag, 3);
return $this->renderPartial('toolbar', [
'tag' => $tag,
12 years ago
'panels' => $this->module->panels,
]);
12 years ago
}
12 years ago
public function actionPhpinfo()
{
phpinfo();
}
12 years ago
private $_manifest;
protected function getManifest($forceReload = false)
12 years ago
{
if ($this->_manifest === null || $forceReload) {
if ($forceReload) {
clearstatcache();
}
11 years ago
$indexFile = $this->module->dataPath . '/index.data';
12 years ago
if (is_file($indexFile)) {
$this->_manifest = array_reverse(unserialize(file_get_contents($indexFile)), true);
12 years ago
} else {
$this->_manifest = [];
12 years ago
}
}
return $this->_manifest;
}
public function loadData($tag, $maxRetry = 0)
12 years ago
{
// retry loading debug data because the debug data is logged in shutdown function
// which may be delayed in some environment if xdebug is enabled.
// See: https://github.com/yiisoft/yii2/issues/1504
for ($retry = 0; $retry <= $maxRetry; ++$retry) {
$manifest = $this->getManifest($retry > 0);
if (isset($manifest[$tag])) {
$dataFile = $this->module->dataPath . "/$tag.data";
$data = unserialize(file_get_contents($dataFile));
foreach ($this->module->panels as $id => $panel) {
if (isset($data[$id])) {
$panel->tag = $tag;
$panel->load($data[$id]);
} else {
// remove the panel since it has not received any data
unset($this->module->panels[$id]);
}
12 years ago
}
$this->summary = $data['summary'];
return;
12 years ago
}
}
throw new NotFoundHttpException("Unable to find debug data tagged with '$tag'.");
}
12 years ago
}