log_filter.install 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <?php
  2. /**
  3. * @file
  4. * Drupal Log Filter module (un)installation
  5. */
  6. /**
  7. * Implements hook_install().
  8. *
  9. * @return void
  10. */
  11. function log_filter_install() {
  12. // Invoke our hook_menu() later than dblog's ditto.
  13. db_update('system')
  14. ->fields(array('weight' => 10))
  15. ->condition('type', 'module')
  16. ->condition('name', 'log_filter')
  17. ->execute();
  18. // Insert some default filters.
  19. $uid = $GLOBALS['user']->uid;
  20. $filters = array(
  21. array('name' => 'errors_day', 'creator' => $uid, 'description' => '', 'require_admin' => 1, 'severity' => '0,1,2,3', 'type' => '', 'time_range' => 30, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1),
  22. array('name' => 'errors_month', 'creator' => $uid, 'description' => '', 'require_admin' => 1, 'severity' => '0,1,2,3', 'type' => '', 'time_range' => 750, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1),
  23. array('name' => 'errors_week', 'creator' => $uid, 'description' => '', 'require_admin' => 1, 'severity' => '0,1,2,3', 'type' => '', 'time_range' => 175, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1),
  24. array('name' => 'latest_day', 'creator' => $uid, 'description' => '', 'require_admin' => 0, 'severity' => '', 'type' => '', 'time_range' => 30, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1),
  25. array('name' => 'latest_month', 'creator' => $uid, 'description' => '', 'require_admin' => 0, 'severity' => '', 'type' => '', 'time_range' => 750, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1),
  26. array('name' => 'latest_week', 'creator' => $uid, 'description' => '', 'require_admin' => 0, 'severity' => '', 'type' => '', 'time_range' => 175, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1),
  27. array('name' => 'severity_debug', 'creator' => $uid, 'description' => 'Debug severity', 'require_admin' => 1, 'severity' => 7, 'type' => '', 'time_range' => 0, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1),
  28. array('name' => 'severity_error', 'creator' => $uid, 'description' => 'All error severities', 'require_admin' => 1, 'severity' => '0,1,2,3', 'type' => '', 'time_range' => 0, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1),
  29. array('name' => 'severity_warning_notice_info', 'creator' => $uid, 'description' => 'All non-error severities but debug', 'require_admin' => 1, 'severity' => '4,5,6', 'type' => '', 'time_range' => 0, 'time_from' => 0, 'time_to' => 0, 'role' => -1, 'uid' => -1, 'hostname' => '', 'location' => '', 'referer' => '', 'order_by' => '', 'editor' => $uid, 'created' => 1, 'changed' => 1)
  30. );
  31. try {
  32. $le = count($filters);
  33. for ($i = 0; $i < $le; ++$i) {
  34. db_insert('log_filter')
  35. ->fields($filters[$i])
  36. ->execute();
  37. }
  38. }
  39. catch (Exception $xc) {
  40. watchdog(
  41. 'log_filter',
  42. 'Failed to insert default filters during installation of module Log Filter.',
  43. NULL,
  44. WATCHDOG_ERROR
  45. );
  46. }
  47. }
  48. /**
  49. * Implements hook_schema().
  50. *
  51. * @return array
  52. */
  53. function log_filter_schema() {
  54. return array(
  55. 'log_filter' => array(
  56. 'description' => 'Log filters.',
  57. 'fields' => array(
  58. 'id' => array(
  59. 'type' => 'serial',
  60. 'not null' => TRUE,
  61. ),
  62. 'name' => array(
  63. 'type' => 'varchar',
  64. 'length' => 32,
  65. 'not null' => TRUE,
  66. ),
  67. 'creator' => array(
  68. 'type' => 'int',
  69. 'not null' => TRUE,
  70. 'description' => 'The user.uid that created the filter.',
  71. ),
  72. 'description' => array(
  73. 'type' => 'varchar',
  74. 'length' => 255,
  75. 'not null' => TRUE,
  76. 'default' => '',
  77. ),
  78. 'require_admin' => array(
  79. 'type' => 'int',
  80. 'size' => 'tiny',
  81. 'not null' => TRUE,
  82. 'default' => 0,
  83. 'description' => 'Require the \'Administer log filtering\' role.',
  84. ),
  85. 'severity' => array(
  86. 'type' => 'varchar',
  87. 'length' => 255,
  88. 'not null' => TRUE,
  89. 'default' => '',
  90. 'description' => 'Comma-separated list.',
  91. ),
  92. 'type' => array(
  93. 'type' => 'text',
  94. 'not null' => TRUE,
  95. // Text fields don't support default value; at least not MySQL.
  96. 'description' => 'Comma-separated list. Empty default because it\'s a text field (not char/varchar).',
  97. ),
  98. 'time_range' => array(
  99. 'type' => 'int',
  100. 'not null' => TRUE,
  101. 'default' => 0,
  102. ),
  103. 'time_from' => array(
  104. 'type' => 'int',
  105. 'not null' => TRUE,
  106. 'default' => 0,
  107. ),
  108. 'time_to' => array(
  109. 'type' => 'int',
  110. 'not null' => TRUE,
  111. 'default' => 0,
  112. ),
  113. 'role' => array(
  114. 'type' => 'int',
  115. 'not null' => TRUE,
  116. 'default' => -1,
  117. ),
  118. 'uid' => array(
  119. 'type' => 'int',
  120. 'not null' => TRUE,
  121. 'default' => -1,
  122. ),
  123. 'hostname' => array(
  124. 'type' => 'varchar',
  125. 'length' => 255,
  126. 'not null' => TRUE,
  127. 'default' => '',
  128. ),
  129. 'location' => array(
  130. 'type' => 'varchar',
  131. 'length' => 255,
  132. 'not null' => TRUE,
  133. 'default' => '',
  134. ),
  135. 'referer' => array(
  136. 'type' => 'varchar',
  137. 'length' => 255,
  138. 'not null' => TRUE,
  139. 'default' => '',
  140. 'description' => 'Url, \'none\' or empty.',
  141. ),
  142. 'order_by' => array(
  143. 'type' => 'varchar',
  144. 'length' => 255,
  145. 'not null' => TRUE,
  146. 'default' => 'time:DESC',
  147. 'description' => 'Comma-separated list, like: \'time:DESC,severity:ASC\'.',
  148. ),
  149. 'editor' => array(
  150. 'type' => 'int',
  151. 'not null' => TRUE,
  152. 'description' => 'The user.uid that most recently changed (or created) the filter.',
  153. ),
  154. 'created' => array(
  155. 'type' => 'int',
  156. 'not null' => TRUE,
  157. 'description' => 'The Unix timestamp when the filter was created.',
  158. ),
  159. 'changed' => array(
  160. 'type' => 'int',
  161. 'not null' => TRUE,
  162. 'description' => 'The Unix timestamp when the filter was most recently saved.',
  163. ),
  164. ),
  165. 'primary key' => array('id'),
  166. 'unique keys' => array(
  167. 'name' => array('name'),
  168. ),
  169. ),
  170. );
  171. }
  172. /**
  173. * Deletes configuration variables.
  174. *
  175. * Implements hook_uninstall().
  176. */
  177. function log_filter_uninstall() {
  178. variable_del('log_filter_admintheme');
  179. variable_del('log_filter_cssdefault');
  180. variable_del('log_filter_trnslt');
  181. variable_del('log_filter_pgrng');
  182. variable_del('log_filter_showdeletions');
  183. }
  184. /**
  185. * Increase log_filter's module weight to 10; the module's hook_menu() must be invoked _after_ dblog's ditto.
  186. */
  187. function log_filter_update_7001() {
  188. // Invoke our hook_menu() later than dblog's ditto.
  189. db_update('system')
  190. ->fields(array('weight' => 10))
  191. ->condition('type', 'module')
  192. ->condition('name', 'log_filter')
  193. ->execute();
  194. }