LogPanel.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?php
  2. /**
  3. * @link http://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license http://www.yiiframework.com/license/
  6. */
  7. namespace yii\debug\panels;
  8. use Yii;
  9. use yii\debug\Panel;
  10. use yii\helpers\VarDumper;
  11. use yii\log\Logger;
  12. use yii\debug\models\search\Log;
  13. /**
  14. * Debugger panel that collects and displays logs.
  15. *
  16. * @author Qiang Xue <qiang.xue@gmail.com>
  17. * @since 2.0
  18. */
  19. class LogPanel extends Panel
  20. {
  21. /**
  22. * @var array log messages extracted to array as models, to use with data provider.
  23. */
  24. private $_models;
  25. /**
  26. * @inheritdoc
  27. */
  28. public function getName()
  29. {
  30. return 'Logs';
  31. }
  32. /**
  33. * @inheritdoc
  34. */
  35. public function getSummary()
  36. {
  37. return Yii::$app->view->render('panels/log/summary', ['data' => $this->data, 'panel' => $this]);
  38. }
  39. /**
  40. * @inheritdoc
  41. */
  42. public function getDetail()
  43. {
  44. $searchModel = new Log();
  45. $dataProvider = $searchModel->search(Yii::$app->request->getQueryParams(), $this->getModels());
  46. return Yii::$app->view->render('panels/log/detail', [
  47. 'dataProvider' => $dataProvider,
  48. 'panel' => $this,
  49. 'searchModel' => $searchModel,
  50. ]);
  51. }
  52. /**
  53. * @inheritdoc
  54. */
  55. public function save()
  56. {
  57. $target = $this->module->logTarget;
  58. $except = [];
  59. if (isset($this->module->panels['router'])) {
  60. $except = $this->module->panels['router']->getCategories();
  61. }
  62. $messages = $target->filterMessages($target->messages, Logger::LEVEL_ERROR | Logger::LEVEL_INFO | Logger::LEVEL_WARNING | Logger::LEVEL_TRACE, [], $except);
  63. foreach ($messages as &$message) {
  64. if (!is_string($message[0])) {
  65. // exceptions may not be serializable if in the call stack somewhere is a Closure
  66. if ($message[0] instanceof \Throwable || $message[0] instanceof \Exception) {
  67. $message[0] = (string) $message[0];
  68. } else {
  69. $message[0] = VarDumper::export($message[0]);
  70. }
  71. }
  72. }
  73. return ['messages' => $messages];
  74. }
  75. /**
  76. * Returns an array of models that represents logs of the current request.
  77. * Can be used with data providers, such as \yii\data\ArrayDataProvider.
  78. *
  79. * @param bool $refresh if need to build models from log messages and refresh them.
  80. * @return array models
  81. */
  82. protected function getModels($refresh = false)
  83. {
  84. if ($this->_models === null || $refresh) {
  85. $this->_models = [];
  86. foreach ($this->data['messages'] as $message) {
  87. $this->_models[] = [
  88. 'message' => $message[0],
  89. 'level' => $message[1],
  90. 'category' => $message[2],
  91. 'time' => $message[3] * 1000, // time in milliseconds
  92. 'trace' => $message[4]
  93. ];
  94. }
  95. }
  96. return $this->_models;
  97. }
  98. }