123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- <?php
- /**
- * @file
- * Install, update and uninstall functions for the dblog module.
- */
- /**
- * Implements hook_schema().
- */
- function dblog_schema() {
- $schema['watchdog'] = [
- 'description' => 'Table that contains logs of all system events.',
- 'fields' => [
- 'wid' => [
- 'type' => 'serial',
- 'not null' => TRUE,
- 'description' => 'Primary Key: Unique watchdog event ID.',
- ],
- 'uid' => [
- 'type' => 'int',
- 'unsigned' => TRUE,
- 'not null' => TRUE,
- 'default' => 0,
- 'description' => 'The {users}.uid of the user who triggered the event.',
- ],
- 'type' => [
- 'type' => 'varchar_ascii',
- 'length' => 64,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'Type of log message, for example "user" or "page not found."',
- ],
- 'message' => [
- 'type' => 'text',
- 'not null' => TRUE,
- 'size' => 'big',
- 'description' => 'Text of log message to be passed into the t() function.',
- ],
- 'variables' => [
- 'type' => 'blob',
- 'not null' => TRUE,
- 'size' => 'big',
- 'description' => 'Serialized array of variables that match the message string and that is passed into the t() function.',
- ],
- 'severity' => [
- 'type' => 'int',
- 'unsigned' => TRUE,
- 'not null' => TRUE,
- 'default' => 0,
- 'size' => 'tiny',
- 'description' => 'The severity level of the event; ranges from 0 (Emergency) to 7 (Debug)',
- ],
- 'link' => [
- 'type' => 'text',
- 'not null' => FALSE,
- 'description' => 'Link to view the result of the event.',
- ],
- 'location' => [
- 'type' => 'text',
- 'not null' => TRUE,
- 'description' => 'URL of the origin of the event.',
- ],
- 'referer' => [
- 'type' => 'text',
- 'not null' => FALSE,
- 'description' => 'URL of referring page.',
- ],
- 'hostname' => [
- 'type' => 'varchar_ascii',
- 'length' => 128,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'Hostname of the user who triggered the event.',
- ],
- 'timestamp' => [
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- 'description' => 'Unix timestamp of when event occurred.',
- ],
- ],
- 'primary key' => ['wid'],
- 'indexes' => [
- 'type' => ['type'],
- 'uid' => ['uid'],
- 'severity' => ['severity'],
- ],
- ];
- return $schema;
- }
- /**
- * Use standard plugin for wid and uid fields. Use dblog_types for type filter.
- */
- function dblog_update_8400() {
- $config_factory = \Drupal::configFactory();
- foreach ($config_factory->listAll('views.view.') as $view_config_name) {
- $view = $config_factory->getEditable($view_config_name);
- if ($view->get('base_table') != 'watchdog') {
- continue;
- }
- $save = FALSE;
- foreach ($view->get('display') as $display_name => $display) {
- // Iterate through all the fields of watchdog views based tables.
- if (isset($display['display_options']['fields'])) {
- foreach ($display['display_options']['fields'] as $field_name => $field) {
- // We are only interested in wid and uid fields from the watchdog
- // table that still use the numeric id.
- if (isset($field['table']) &&
- $field['table'] === 'watchdog' &&
- $field['plugin_id'] == 'numeric' &&
- in_array($field['field'], ['wid', 'uid'])) {
- $save = TRUE;
- $new_value = $field;
- $new_value['plugin_id'] = 'standard';
- // Delete all the attributes related to numeric fields.
- unset(
- $new_value['set_precision'],
- $new_value['precision'],
- $new_value['decimal'],
- $new_value['separator'],
- $new_value['format_plural'],
- $new_value['format_plural_string'],
- $new_value['prefix'],
- $new_value['suffix']
- );
- $view->set("display.$display_name.display_options.fields.$field_name", $new_value);
- }
- }
- }
- // Iterate all filters looking for type filters to update.
- if (isset($display['display_options']['filters'])) {
- foreach ($display['display_options']['filters'] as $filter_name => $filter) {
- if (isset($filter['table']) &&
- $filter['table'] === 'watchdog' &&
- $filter['plugin_id'] == 'in_operator' &&
- $filter['field'] == 'type') {
- $save = TRUE;
- $filter['plugin_id'] = 'dblog_types';
- $view->set("display.$display_name.display_options.filters.$filter_name", $filter);
- }
- }
- }
- }
- if ($save) {
- $view->save();
- }
- }
- }
|