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\ConfigCode
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);
}