Module Description
πΊπ¦ This module is maintained by Ukrainian developers. Please consider supporting Ukraine in a fight for their freedom and safety of Europe. This module aims to cover development needs with managing configurations during project development.
Importing all configs during development is not convenient and can lead to a bad behaviour with overwriting or deleting configs or content from a site.
So there is a need for importing only of specific configs via hook_update_N().
Usage All the work happening with the config_import.importer service. Let's instantiate it:
/* @var \Drupal\config_import\ConfigImporterServiceInterface $config_importer */ $config_importer = \Drupal::service('config_import.importer'); By default, import and export operations will use the sync directory. But, if needed, it could be changed to a path of existing directory or type of already configured configuration directories. For instance:
// $config_importer->setDirectory(CONFIG_STAGING_DIRECTORY); $config_importer->setDirectory('/var/config'); You may do so to import existing configs:
$config_importer->importConfigs(['core.extension']); And export can be achieved with a similar construction:
$config_importer->exportConfigs(['core.extension']); Features integration To revert/import features you have to enable the features module first:
drush en features -y Get instance of service:
/* @var \Drupal\config_import\ConfigFeaturesImporterServiceInterface $features_importer */ $features_importer = \Drupal::service('config_import.features_importer'); And do the import:
$features_importer->importFeatures(['feature1', 'feature2']); Drush integration Execute the next command to see the list of available commands from a group:
drush help --filter=config_import Then use the following syntax to find out more information about concrete command:
drush help COMMAND_NAME Example use cases /** * Revert custom block feature. */ function ygh_master_update_8024() { \Drupal::service('config_import.features_importer')->importFeatures(['openy_block_custom_simple']); } /** * Update HTML format config. */ function ygh_master_update_8025() { /* @var \Drupal\config_import\ConfigImporterServiceInterface $config_importer */ $config_importer = \Drupal::service('config_import.importer'); $config_importer->setDirectory(YGH_CONFDIR); $config_importer->importConfigs(['filter.format.html']); } To do
* Create UI for making manual config changes convenient
Video about this module: https://www.youtube.com/watch?v=vFsgNjhGr4Y
For updating specific property in config: 1) go to related to this config module
2) create new hook_update_N in openy_*.install file
3) in update add next code (this is example):
$config = drupal_get_path('module', 'openy_media_image') . '/config/install/views.view.images_library.yml'; $config_importer = \Drupal::service('config_import.param_updater'); $config_importer->update($config, 'views.view.images_library', 'display.default.display_options.pager'); Where:
* $config variable contains path to config with config name
* "views.view.images_library" - config name
* "display.default.display_options.pager" - config specific property (you can set value from a nested array with variable depth)
Importing all configs during development is not convenient and can lead to a bad behaviour with overwriting or deleting configs or content from a site.
So there is a need for importing only of specific configs via hook_update_N().
Usage All the work happening with the config_import.importer service. Let's instantiate it:
/* @var \Drupal\config_import\ConfigImporterServiceInterface $config_importer */ $config_importer = \Drupal::service('config_import.importer'); By default, import and export operations will use the sync directory. But, if needed, it could be changed to a path of existing directory or type of already configured configuration directories. For instance:
// $config_importer->setDirectory(CONFIG_STAGING_DIRECTORY); $config_importer->setDirectory('/var/config'); You may do so to import existing configs:
$config_importer->importConfigs(['core.extension']); And export can be achieved with a similar construction:
$config_importer->exportConfigs(['core.extension']); Features integration To revert/import features you have to enable the features module first:
drush en features -y Get instance of service:
/* @var \Drupal\config_import\ConfigFeaturesImporterServiceInterface $features_importer */ $features_importer = \Drupal::service('config_import.features_importer'); And do the import:
$features_importer->importFeatures(['feature1', 'feature2']); Drush integration Execute the next command to see the list of available commands from a group:
drush help --filter=config_import Then use the following syntax to find out more information about concrete command:
drush help COMMAND_NAME Example use cases /** * Revert custom block feature. */ function ygh_master_update_8024() { \Drupal::service('config_import.features_importer')->importFeatures(['openy_block_custom_simple']); } /** * Update HTML format config. */ function ygh_master_update_8025() { /* @var \Drupal\config_import\ConfigImporterServiceInterface $config_importer */ $config_importer = \Drupal::service('config_import.importer'); $config_importer->setDirectory(YGH_CONFDIR); $config_importer->importConfigs(['filter.format.html']); } To do
* Create UI for making manual config changes convenient
Video about this module: https://www.youtube.com/watch?v=vFsgNjhGr4Y
For updating specific property in config: 1) go to related to this config module
2) create new hook_update_N in openy_*.install file
3) in update add next code (this is example):
$config = drupal_get_path('module', 'openy_media_image') . '/config/install/views.view.images_library.yml'; $config_importer = \Drupal::service('config_import.param_updater'); $config_importer->update($config, 'views.view.images_library', 'display.default.display_options.pager'); Where:
* $config variable contains path to config with config name
* "views.view.images_library" - config name
* "display.default.display_options.pager" - config specific property (you can set value from a nested array with variable depth)
Module Link
Project Usage
586
Security Covered
Covered By Security Advisory
Version Available
Production
Module Summary
This module aims to solve the need for importing only specific configurations during project development, avoiding the inconvenience of importing all configs and the risk of overwriting or deleting content from a site.
Data Name
confi