public function ConfigFactory::onConfigSave in Drupal 9
Same name and namespace in other branches
- 8 core/lib/Drupal/Core/Config/ConfigFactory.php \Drupal\Core\Config\ConfigFactory::onConfigSave()
Updates stale static cache entries when configuration is saved.
Parameters
ConfigCrudEvent $event: The configuration event.
File
- core/lib/ Drupal/ Core/ Config/ ConfigFactory.php, line 337 
Class
- ConfigFactory
- Defines the configuration object factory.
Namespace
Drupal\Core\ConfigCode
public function onConfigSave(ConfigCrudEvent $event) {
  $saved_config = $event
    ->getConfig();
  // We are only concerned with config objects that belong to the collection
  // that matches the storage we depend on. Skip if the event was fired for a
  // config object belonging to a different collection.
  if ($saved_config
    ->getStorage()
    ->getCollectionName() !== $this->storage
    ->getCollectionName()) {
    return;
  }
  // Ensure that the static cache contains up to date configuration objects by
  // replacing the data on any entries for the configuration object apart
  // from the one that references the actual config object being saved.
  foreach ($this
    ->getConfigCacheKeys($saved_config
    ->getName()) as $cache_key) {
    $cached_config = $this->cache[$cache_key];
    if ($cached_config !== $saved_config) {
      // We can not just update the data since other things about the object
      // might have changed. For example, whether or not it is new.
      $this->cache[$cache_key]
        ->initWithData($saved_config
        ->getRawData());
    }
  }
}