Drupal is a registered trademark of Dries Buytaert
drupal 11.3.7 Update released for Drupal core (11.3.7)! drupal 11.2.11 Update released for Drupal core (11.2.11)! drupal 10.6.7 Update released for Drupal core (10.6.7)! drupal 10.5.9 Update released for Drupal core (10.5.9)! cms 2.1.1 Update released for Drupal core (2.1.1)! drupal 11.3.6 Update released for Drupal core (11.3.6)! drupal 10.6.6 Update released for Drupal core (10.6.6)! cms 2.1.0 Update released for Drupal core (2.1.0)! bootstrap 8.x-3.40 Minor update available for theme bootstrap (8.x-3.40). menu_link_attributes 8.x-1.7 Minor update available for module menu_link_attributes (8.x-1.7). eca 3.1.1 Minor update available for module eca (3.1.1). layout_paragraphs 2.1.3 Minor update available for module layout_paragraphs (2.1.3). ai 1.3.3 Minor update available for module ai (1.3.3). ai 1.2.14 Minor update available for module ai (1.2.14). node_revision_delete 2.0.3 Minor update available for module node_revision_delete (2.0.3). moderated_content_bulk_publish 2.0.52 Minor update available for module moderated_content_bulk_publish (2.0.52). klaro 3.0.10 Minor update available for module klaro (3.0.10). klaro 3.0.9 Minor update available for module klaro (3.0.9). layout_paragraphs 2.1.2 Minor update available for module layout_paragraphs (2.1.2). geofield_map 11.1.8 Minor update available for module geofield_map (11.1.8).

page_cache_vary

6 sites No security coverage
View on drupal.org

Provide the ability to specify by which Request header the cache should vary. Implement the vary feature in the Internal Page Cache by extanding it.
Works on cached pages visited by the anonymous user.

Features

Provide a new interface for Cache Context allowing to specify a list of headers to vary the response by (using https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Vary).

The Vary header is populated accordingly.

Usage example

Simply implement \Drupal\page_cache_vary\VaryCacheContextInterface with your CacheContext class.

namespace Drupal\page_cache_vary_test\Cache\Context;

use Drupal\Core\Cache\CacheableMetadata;
use Drupal\Core\Cache\Context\CalculatedCacheContextInterface;
use Drupal\Core\Cache\Context\RequestStackCacheContextBase;
use Drupal\page_cache_vary\VaryCacheContextInterface;

/**
 * Varies the context depending on the x-country-code header.
 *
 * Cache context ID: 'country'.
 */
final class CountryCacheContext extends RequestStackCacheContextBase implements CalculatedCacheContextInterface, VaryCacheContextInterface {

  const COUNTRY_CODE_HEADER = 'x-country-code';

  /**
   * {@inheritdoc}
   */
  public static function getLabel(): string {
    return (string) t('Country');
  }

  /**
   * {@inheritdoc}
   */
  public function getContext($parameter = NULL): string {
    return $this->requestStack->getMainRequest()->headers->get(self::COUNTRY_CODE_HEADER, '');
  }

  /**
   * {@inheritdoc}
   */
  public function getCacheableMetadata($parameter = NULL): CacheableMetadata {
    return new CacheableMetadata();
  }

  /**
   * Return the list of headers the response vary by.
   */
  public function getVaryHeaders(): array {
    return [self::COUNTRY_CODE_HEADER];
  }

}

Additional Requirements

This module as a requirement on the Internal Page Cache.

Activity

Total releases
2
First release
Jan 2025
Latest release
2 months ago
Release cadence
362 days
Stability
100% stable

Releases

Version Type Release date
1.0.4 Stable Jan 26, 2026
1.0.3 Stable Jan 29, 2025