Overview.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  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. '#description' => t('NOT IMPLEMENTED YET. This will permanently remove the log messages from the Redis store.'),
  48. '#collapsible' => TRUE,
  49. '#collapsed' => TRUE,
  50. );
  51. $form['redis_logger_clear']['clear'] = array(
  52. '#type' => 'submit',
  53. '#value' => t('Clear log messages'),
  54. '#submit' => array('redis_logger_clear_log_submit'),
  55. );
  56. return $form;
  57. }
  58. /**
  59. * Build the filter form. Shares session status with DBLog.
  60. *
  61. * @param array $form
  62. * @param \Redis\Logger\Reader $reader
  63. *
  64. * @return array
  65. */
  66. protected function buildFilter(array $form) {
  67. $filters = $this->getFilters();
  68. $form['filters'] = array(
  69. '#type' => 'fieldset',
  70. '#title' => t('Filter log messages'),
  71. '#collapsible' => TRUE,
  72. '#collapsed' => empty($_SESSION['dblog_overview_filter']),
  73. );
  74. foreach ($filters as $key => $filter) {
  75. $form['filters']['status'][$key] = array(
  76. '#title' => $filter['title'],
  77. '#type' => 'select',
  78. '#multiple' => TRUE,
  79. '#size' => 8,
  80. '#options' => $filter['options'],
  81. );
  82. if (!empty($_SESSION['dblog_overview_filter'][$key])) {
  83. $form['filters']['status'][$key]['#default_value'] = $_SESSION['dblog_overview_filter'][$key];
  84. }
  85. }
  86. $form['filters']['actions'] = array(
  87. '#type' => 'actions',
  88. '#attributes' => array('class' => array('container-inline')),
  89. );
  90. $form['filters']['actions']['submit'] = array(
  91. '#type' => 'submit',
  92. '#value' => t('Filter'),
  93. '#submit' => array('redis_logger_filter_submit'),
  94. );
  95. if (!empty($_SESSION['dblog_overview_filter'])) {
  96. $form['filters']['actions']['reset'] = array(
  97. '#type' => 'submit',
  98. '#value' => t('Reset'),
  99. '#submit' => array('redis_logger_filter_reset_submit'),
  100. );
  101. }
  102. return $form;
  103. }
  104. public function build($form, &$form_state) {
  105. $reader = $this->reader;
  106. $severity_levels = $reader->getSettings()->getSeverityLevels();
  107. $base_form = $form;
  108. $form['redis_logger_filter_form'] = $this->buildFilter($base_form);
  109. $form['redis_logger_clear_log_form'] = $this->buildClear($base_form);
  110. $header = array(
  111. t('Level'),
  112. t('Count'),
  113. t('Type'),
  114. t('Source'), // file + line
  115. t('Message'),
  116. );
  117. // TODO pager
  118. $templates = $reader->getTemplates();
  119. $regex = $reader->getSettings()->getSplittingRegex();
  120. $rows = array();
  121. foreach ($templates as $template) {
  122. preg_match($regex, $template, $matches);
  123. list(, $channel, $severity, $template) = $matches;
  124. $rows[] = array(
  125. $severity_levels[$severity],
  126. rand(1, 100),
  127. $channel,
  128. 'somefile.module+' . rand(1, 500),
  129. l($template, 'admin/reports/redis/logger/' . $template),
  130. );
  131. }
  132. $form['redis_logger_table'] = array(
  133. '#theme' => 'table',
  134. '#header' => $header,
  135. '#rows' => $rows,
  136. '#attributes' => array('id' => 'admin-dblog'),
  137. '#empty' => t('No log messages available.'),
  138. );
  139. $form_state['reader'] = $reader;
  140. $form['#submit'][] = 'redis_logger_form_overview_submit';
  141. $form['#validate'][] = 'redis_logger_form_overview_validate';
  142. return $form;
  143. }
  144. public function validate($form, &$form_state) {
  145. dsm(__METHOD__);
  146. }
  147. public function submit($form, &$form_state) {
  148. dsm(__METHOD__);
  149. }
  150. public function submitClear($form, &$form_state) {
  151. dsm(__METHOD__);
  152. }
  153. public function submitFilter($form, &$form_state) {
  154. dsm($form_state, __METHOD__);
  155. $_SESSION['dblog_overview_filter']['type'] = $_SESSION['dblog_overview_filter']['severity'] = array();
  156. if (isset($form_state['values']['type'])) {
  157. foreach ($form_state['values']['type'] as $channel) {
  158. $_SESSION['dblog_overview_filter']['type'][$channel] = $channel;
  159. }
  160. }
  161. if (isset($form_state['values']['severity'])) {
  162. foreach ($form_state['values']['severity'] as $severity) {
  163. $_SESSION['dblog_overview_filter']['severity'][$severity] = $severity;
  164. }
  165. }
  166. }
  167. public function submitFilterReset($form, &$form_state) {
  168. $_SESSION['dblog_overview_filter'] = array();
  169. }
  170. }