Overview.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. <?php
  2. /**
  3. * @file
  4. * Logger Overview form
  5. */
  6. namespace Drupal\redis_logger\Form;
  7. use Redis\Logger\Reader;
  8. class Overview {
  9. /**
  10. * @var \Redis\Logger\Reader
  11. */
  12. protected $reader;
  13. public function __construct(Reader $reader) {
  14. $this->reader = $reader;
  15. }
  16. /**
  17. * Helper for the Redis logger filter form builder.
  18. *
  19. * @param \Redis\Logger\Reader $reader
  20. *
  21. * @return array
  22. */
  23. protected function getFilters() {
  24. $filters = array();
  25. $filters['type'] = array(
  26. 'title' => t('Type'),
  27. 'options' => $this->reader->getChannels(),
  28. );
  29. $filters['severity'] = array(
  30. 'title' => t('Severity'),
  31. 'options' => $this->reader->getSettings()->getSeverityLevels(),
  32. );
  33. return $filters;
  34. }
  35. /**
  36. * Form constructor for the form that clears out the log.
  37. *
  38. * TODO implement.
  39. *
  40. * @see dblog_clear_log_submit()
  41. * @ingroup forms
  42. */
  43. protected function buildClear(array $form) {
  44. $form['redis_logger_clear'] = array(
  45. '#type' => 'fieldset',
  46. '#title' => t('Clear log messages'),
  47. '#collapsible' => TRUE,
  48. '#collapsed' => TRUE,
  49. );
  50. $form['redis_logger_clear']['clear'] = array(
  51. '#type' => 'submit',
  52. '#value' => t('Clear log messages'),
  53. '#submit' => array('redis_logger_clear_log_submit'),
  54. );
  55. return $form;
  56. }
  57. /**
  58. * Build the filter form. Shares session status with DBLog.
  59. *
  60. * @param array $form
  61. * @param \Redis\Logger\Reader $reader
  62. *
  63. * @return array
  64. */
  65. protected function buildFilter(array $form) {
  66. $filters = $this->getFilters();
  67. $form['filters'] = array(
  68. '#type' => 'fieldset',
  69. '#title' => t('Filter log messages'),
  70. '#collapsible' => TRUE,
  71. '#collapsed' => empty($_SESSION['dblog_overview_filter']),
  72. );
  73. foreach ($filters as $key => $filter) {
  74. $form['filters']['status'][$key] = array(
  75. '#title' => $filter['title'],
  76. '#type' => 'select',
  77. '#multiple' => TRUE,
  78. '#size' => 8,
  79. '#options' => $filter['options'],
  80. );
  81. if (!empty($_SESSION['dblog_overview_filter'][$key])) {
  82. $form['filters']['status'][$key]['#default_value'] = $_SESSION['dblog_overview_filter'][$key];
  83. }
  84. }
  85. $form['filters']['actions'] = array(
  86. '#type' => 'actions',
  87. '#attributes' => array('class' => array('container-inline')),
  88. );
  89. $form['filters']['actions']['submit'] = array(
  90. '#type' => 'submit',
  91. '#value' => t('Filter'),
  92. '#submit' => array('redis_logger_filter_submit'),
  93. );
  94. if (!empty($_SESSION['dblog_overview_filter'])) {
  95. $form['filters']['actions']['reset'] = array(
  96. '#type' => 'submit',
  97. '#value' => t('Reset'),
  98. '#submit' => array('redis_logger_filter_reset_submit'),
  99. );
  100. }
  101. return $form;
  102. }
  103. /**
  104. * Form builder.
  105. */
  106. public function build($form, &$form_state) {
  107. $reader = $this->reader;
  108. $severity_levels = $reader->getSettings()->getSeverityLevels();
  109. $base_form = $form;
  110. $form['redis_logger_filter_form'] = $this->buildFilter($base_form);
  111. $form['redis_logger_clear_log_form'] = $this->buildClear($base_form);
  112. $header = array(
  113. t('Level'),
  114. t('Count'),
  115. t('Type'),
  116. t('Source'), // file + line
  117. t('Message'),
  118. );
  119. $severity_classes = array(
  120. WATCHDOG_DEBUG => 'debug',
  121. WATCHDOG_INFO => 'info',
  122. WATCHDOG_NOTICE => 'notice',
  123. WATCHDOG_WARNING => 'warning',
  124. WATCHDOG_ERROR => 'error',
  125. WATCHDOG_CRITICAL => 'critical',
  126. WATCHDOG_ALERT => 'alert',
  127. WATCHDOG_EMERGENCY => 'emerg',
  128. );
  129. // TODO pager
  130. $templates = $reader->getTemplates();
  131. $regex = $reader->getSettings()->getSplittingRegex();
  132. $rows = array();
  133. foreach ($templates as $template) {
  134. preg_match($regex, $template, $matches);
  135. list(, $channel, $severity, $template) = $matches;
  136. $class = 'dblog-' . $severity_classes[$severity];
  137. $rows[] = array(
  138. 'class' => array($class),
  139. 'data' => array(
  140. array(
  141. 'class' => 'icon',
  142. 'data' => NULL,
  143. 'title' => $severity . " = " . $severity_levels[$severity],
  144. ),
  145. rand(1, 100),
  146. $channel,
  147. 'somefile.module+' . rand(1, 500),
  148. l($template, 'admin/reports/redis/logger/' . $template),
  149. ),
  150. );
  151. }
  152. $form['redis_logger_table'] = array(
  153. '#theme' => 'table',
  154. '#header' => $header,
  155. '#rows' => $rows,
  156. '#attributes' => array('id' => 'admin-dblog'),
  157. '#empty' => t('No log messages available.'),
  158. );
  159. $form_state['reader'] = $reader;
  160. return $form;
  161. }
  162. /**
  163. * Submit handler for Clear op.
  164. */
  165. public function submitClear($form, &$form_state) {
  166. $this->reader->clear();
  167. }
  168. /**
  169. * Submit handler for Apply Filter op.
  170. */
  171. public function submitFilter($form, &$form_state) {
  172. $_SESSION['dblog_overview_filter']['type'] = $_SESSION['dblog_overview_filter']['severity'] = array();
  173. if (isset($form_state['values']['type'])) {
  174. foreach ($form_state['values']['type'] as $channel) {
  175. $_SESSION['dblog_overview_filter']['type'][$channel] = $channel;
  176. }
  177. }
  178. if (isset($form_state['values']['severity'])) {
  179. foreach ($form_state['values']['severity'] as $severity) {
  180. $_SESSION['dblog_overview_filter']['severity'][$severity] = $severity;
  181. }
  182. }
  183. }
  184. /**
  185. * Submit handler for Filter reset op.
  186. */
  187. public function submitFilterReset($form, &$form_state) {
  188. $_SESSION['dblog_overview_filter'] = array();
  189. }
  190. }