diff --git a/core/modules/taxonomy/src/Plugin/views/filter/TaxonomyIndexTid.php b/core/modules/taxonomy/src/Plugin/views/filter/TaxonomyIndexTid.php index 84c0533663bf99dbf5c971441e612c95539175d4..d83a028eddcf109699686b1a828d560975522bba 100644 --- a/core/modules/taxonomy/src/Plugin/views/filter/TaxonomyIndexTid.php +++ b/core/modules/taxonomy/src/Plugin/views/filter/TaxonomyIndexTid.php @@ -400,19 +400,6 @@ public function adminSummary() { return parent::adminSummary(); } - /** - * {@inheritdoc} - */ - public function getCacheContexts() { - $contexts = parent::getCacheContexts(); - // The result potentially depends on term access and so is just cacheable - // per user. - // @todo See https://www.drupal.org/node/2352175. - $contexts[] = 'user'; - - return $contexts; - } - /** * {@inheritdoc} */ diff --git a/core/modules/views/src/ViewsConfigUpdater.php b/core/modules/views/src/ViewsConfigUpdater.php index a3af80c199f8ac0fbf39655dd7f1f2f3db2601dc..81fb4af5fe5d7104dbda92031f5f4f58f44faccd 100644 --- a/core/modules/views/src/ViewsConfigUpdater.php +++ b/core/modules/views/src/ViewsConfigUpdater.php @@ -3,11 +3,13 @@ namespace Drupal\views; use Drupal\Component\Plugin\PluginManagerInterface; +use Drupal\Core\Cache\Cache; use Drupal\Core\Config\TypedConfigManagerInterface; use Drupal\Core\DependencyInjection\ContainerInjectionInterface; use Drupal\Core\Entity\EntityFieldManagerInterface; use Drupal\Core\Entity\EntityTypeManagerInterface; use Drupal\Core\Field\Plugin\Field\FieldFormatter\TimestampFormatter; +use Drupal\Core\Language\LanguageInterface; use Symfony\Component\DependencyInjection\ContainerInterface; /** @@ -450,4 +452,58 @@ public function processDefaultArgumentSkipUrlUpdate(array &$handler, string $han return FALSE; } + /** + * Removes user context from all views using term filter configurations. + * + * @param \Drupal\views\ViewEntityInterface $view + * The View to update. + * + * @return bool + * Whether the view was updated. + */ + public function needsTaxonomyTermFilterUpdate(ViewEntityInterface $view): bool { + return $this->processDisplayHandlers($view, TRUE, function (&$handler, $handler_type) use ($view) { + return $this->processTaxonomyTermFilterHandler($handler, $handler_type, $view); + }); + } + + /** + * Processes taxonomy_index_tid type filters. + * + * @param array $handler + * A display handler. + * @param string $handler_type + * The handler type. + * @param \Drupal\views\ViewEntityInterface $view + * The View being updated. + * + * @return bool + * Whether the handler was updated. + */ + protected function processTaxonomyTermFilterHandler(array &$handler, string $handler_type, ViewEntityInterface $view): bool { + $changed = FALSE; + + // Force view resave if using taxonomy id filter. + $plugin_id = $handler['plugin_id'] ?? ''; + if ($handler_type === 'filter' && $plugin_id === 'taxonomy_index_tid') { + + // This cannot be done in View::preSave() due to trusted data. + $executable = $view->getExecutable(); + $displays = $view->get('display'); + foreach ($displays as $display_id => &$display) { + $executable->setDisplay($display_id); + + $cache_metadata = $executable->getDisplay()->calculateCacheMetadata(); + $display['cache_metadata']['contexts'] = $cache_metadata->getCacheContexts(); + // Always include at least the 'languages:' context as there will most + // probably be translatable strings in the view output. + $display['cache_metadata']['contexts'] = Cache::mergeContexts($display['cache_metadata']['contexts'], ['languages:' . LanguageInterface::TYPE_INTERFACE]); + sort($display['cache_metadata']['contexts']); + } + $view->set('display', $displays); + $changed = TRUE; + } + return $changed; + } + } diff --git a/core/modules/views/views.post_update.php b/core/modules/views/views.post_update.php index 1d3c33e4d521bad4e4a0c487f48cdb7eaf114b6b..4869a14053b92b8f7ab7e3a65b38929c742a2c1f 100644 --- a/core/modules/views/views.post_update.php +++ b/core/modules/views/views.post_update.php @@ -115,3 +115,14 @@ function views_post_update_remove_default_argument_skip_url(array &$sandbox = NU return $view_config_updater->needsDefaultArgumentSkipUrlUpdate($view); }); } + +/** + * Removes User context from views with taxonomy filters. + */ +function views_post_update_taxonomy_filter_user_context(?array &$sandbox = NULL): void { + /** @var \Drupal\views\ViewsConfigUpdater $view_config_updater */ + $view_config_updater = \Drupal::classResolver(ViewsConfigUpdater::class); + \Drupal::classResolver(ConfigEntityUpdater::class)->update($sandbox, 'view', function (ViewEntityInterface $view) use ($view_config_updater): bool { + return $view_config_updater->needsTaxonomyTermFilterUpdate($view); + }); +}