You are here

public function ConfigUpdater::import in Commerce Core 8.2

Imports configuration from extension storage to active storage.

Parameters

string[] $config_names: The configuration names.

Return value

\Drupal\commerce\Config\ConfigUpdateResult The result.

Overrides ConfigUpdaterInterface::import

File

src/Config/ConfigUpdater.php, line 92

Class

ConfigUpdater
Default implementation of the ConfigUpdaterInterface.

Namespace

Drupal\commerce\Config

Code

public function import(array $config_names) {
  $succeeded = [];
  $failed = [];
  foreach ($config_names as $config_name) {
    $config_data = $this
      ->loadFromExtension($config_name);
    if (!$config_data) {
      $failed[$config_name] = $this
        ->t('@config does not exist in extension storage', [
        '@config' => $config_name,
      ]);
      continue;
    }
    if ($this
      ->loadFromActive($config_name)) {
      $failed[$config_name] = $this
        ->t('@config already exists, use revert to update', [
        '@config' => $config_name,
      ]);
      continue;
    }
    $config_type = $this
      ->getConfigType($config_name);
    if ($config_type == 'system.simple') {
      $this->configFactory
        ->getEditable($config_name)
        ->setData($config_data)
        ->save();
    }
    else {

      /** @var \Drupal\Core\Config\Entity\ConfigEntityStorageInterface $entity_storage */
      $entity_storage = $this->entityTypeManager
        ->getStorage($config_type);
      $entity = $entity_storage
        ->createFromStorageRecord($config_data);
      $entity
        ->save();
    }
    $succeeded[$config_name] = $this
      ->t('@config was successfully imported', [
      '@config' => $config_name,
    ]);
  }
  return new ConfigUpdateResult($succeeded, $failed);
}