3 namespace Drupal\pathauto\EventSubscriber;
5 use Drupal\Core\Config\ConfigCrudEvent;
6 use Drupal\Core\Config\ConfigEvents;
7 use Symfony\Component\EventDispatcher\EventSubscriberInterface;
8 use Drupal\Core\Entity\EntityFieldManagerInterface;
9 use Drupal\pathauto\AliasTypeManager;
12 * A subscriber to clear fielddefinition cache when saving pathauto settings.
14 class PathautoSettingsCacheTag implements EventSubscriberInterface {
17 * @var \Drupal\Core\Entity\EntityFieldManagerInterface
19 protected $entityFieldManager;
22 * The alias type manager.
24 * @var \Drupal\pathauto\AliasTypeManager
26 protected $aliasTypeManager;
29 * Constructs a PathautoSettingsCacheTag object.
31 * @param \Drupal\Core\Entity\EntityFieldManagerInterface $entity_field_manager
32 * The entity field manager.
33 * @param \Drupal\pathauto\AliasTypeManager $alias_type_manager
34 * The alias type manager.
36 public function __construct(EntityFieldManagerInterface $entity_field_manager, AliasTypeManager $alias_type_manager) {
37 $this->entityFieldManager = $entity_field_manager;
38 $this->aliasTypeManager = $alias_type_manager;
42 * Invalidate the 'rendered' cache tag whenever the settings are modified.
44 * @param \Drupal\Core\Config\ConfigCrudEvent $event
45 * The Event to process.
47 public function onSave(ConfigCrudEvent $event) {
48 if ($event->getConfig()->getName() === 'pathauto.settings') {
49 $config = $event->getConfig();
50 $original_entity_types = $config->getOriginal('enabled_entity_types');
52 // Clear cached field definitions if the values are changed.
53 if ($original_entity_types != $config->get('enabled_entity_types')) {
54 $this->entityFieldManager->clearCachedFieldDefinitions();
55 $this->aliasTypeManager->clearCachedDefinitions();
63 public static function getSubscribedEvents() {
64 $events[ConfigEvents::SAVE][] = ['onSave'];