AssetGroupSetHashTrait.php

Same filename and directory in other branches
  1. 11.x core/lib/Drupal/Core/Asset/AssetGroupSetHashTrait.php
  2. 10 core/lib/Drupal/Core/Asset/AssetGroupSetHashTrait.php

Namespace

Drupal\Core\Asset

File

core/lib/Drupal/Core/Asset/AssetGroupSetHashTrait.php

View source
<?php

namespace Drupal\Core\Asset;

use Drupal\Component\Utility\Crypt;
use Drupal\Core\Site\Settings;

/**
 * Provides a method to generate a normalized hash of a given asset group set.
 */
trait AssetGroupSetHashTrait {
  
  /**
   * Generates a hash for an array of asset groups.
   *
   * @param array $group
   *   An asset group.
   *
   * @return string
   *   A hash to uniquely identify the groups.
   */
  protected function generateHash(array $group) : string {
    $normalized = [];
    $group_keys = [
      'type' => NULL,
      'group' => NULL,
      'media' => NULL,
      'browsers' => NULL,
    ];
    $normalized['asset_group'] = array_intersect_key($group, $group_keys);
    $normalized['asset_group']['items'] = [];
    // Remove some keys to make the hash more stable.
    $omit_keys = [
      'weight' => NULL,
    ];
    foreach ($group['items'] as $key => $asset) {
      $normalized['asset_group']['items'][$key] = array_diff_key($asset, $group_keys, $omit_keys);
      // Drupal core adds a version to libraries even when they don't change.
      // Conversely some themes or modules may fail to update the version when
      // files do change. Therefore always replace the version with a hash of
      // the file contents so that it always, but only, updates when the file
      // itself changes. Check for file existence here because missing files
      // should be dealt with elsewhere than when generating the hash.
      $normalized['asset_group']['items'][$key]['version'] = file_exists($asset['data']) ? hash_file('xxh64', $asset['data']) : $asset['version'];
    }
    // The asset array ensures that a valid hash can only be generated via the
    // same code base. Additionally use the hash salt to ensure that hashes are
    // not re-usable between different installations.
    return Crypt::hmacBase64(serialize($normalized), Settings::getHashSalt());
  }

}

Traits

Title Deprecated Summary
AssetGroupSetHashTrait Provides a method to generate a normalized hash of a given asset group set.

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