statistics.install

Same filename and directory in other branches
  1. 7.x modules/statistics/statistics.install
  2. 9 core/modules/statistics/statistics.install
  3. 10 core/modules/statistics/statistics.install
  4. 11.x core/modules/statistics/statistics.install

Install and update functions for the Statistics module.

File

core/modules/statistics/statistics.install

View source
<?php


/**
 * @file
 * Install and update functions for the Statistics module.
 */


/**
 * Implements hook_uninstall().
 */
function statistics_uninstall() {
  // Remove states.
  \Drupal::state()->delete('statistics.node_counter_scale');
  \Drupal::state()->delete('statistics.day_timestamp');
}

/**
 * Implements hook_schema().
 */
function statistics_schema() {
  $schema['node_counter'] = [
    'description' => 'Access statistics for {node}s.',
    'fields' => [
      'nid' => [
        'description' => 'The {node}.nid for these statistics.',
        'type' => 'int',
        'unsigned' => TRUE,
        'not null' => TRUE,
        'default' => 0,
      ],
      'totalcount' => [
        'description' => 'The total number of times the {node} has been viewed.',
        'type' => 'int',
        'unsigned' => TRUE,
        'not null' => TRUE,
        'default' => 0,
        'size' => 'big',
      ],
      'daycount' => [
        'description' => 'The total number of times the {node} has been viewed today.',
        'type' => 'int',
        'unsigned' => TRUE,
        'not null' => TRUE,
        'default' => 0,
        'size' => 'medium',
      ],
      'timestamp' => [
        'description' => 'The most recent time the {node} has been viewed.',
        'type' => 'int',
        'unsigned' => TRUE,
        'not null' => TRUE,
        'default' => 0,
      ],
    ],
    'primary key' => [
      'nid',
    ],
  ];
  return $schema;
}

/**
 * Disable the Statistics module if the node module is not enabled.
 */
function statistics_update_8001() {
  if (!\Drupal::moduleHandler()->moduleExists('node')) {
    if (\Drupal::service('module_installer')->uninstall([
      'statistics',
    ], TRUE)) {
      return 'The statistics module depends on the node module and has therefore been uninstalled.';
    }
    else {
      return 'There was an error uninstalling the statistcs module.';
    }
  }
}

/**
 * Disable the Statistics module if the node module is not enabled.
 */
function statistics_update_8002() {
  // Set the new configuration setting for max age to the initial value.
  \Drupal::configFactory()->getEditable('statistics.settings')
    ->set('display_max_age', 3600)
    ->save();
}

/**
 * Remove access_log settings.
 */
function statistics_update_8300() {
  \Drupal::configFactory()->getEditable('statistics.settings')
    ->clear('access_log')
    ->save();
}

Functions

Title Deprecated Summary
statistics_schema Implements hook_schema().
statistics_uninstall Implements hook_uninstall().
statistics_update_8001 Disable the Statistics module if the node module is not enabled.
statistics_update_8002 Disable the Statistics module if the node module is not enabled.
statistics_update_8300 Remove access_log settings.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.