-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathconfig_split.module
137 lines (121 loc) · 5.8 KB
/
config_split.module
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<?php
/**
* @file
* Configuration split module functions.
*/
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Link;
use Drupal\Core\Routing\RouteMatchInterface;
/**
* Implements hook_form_FORM_ID_alter().
*/
function config_split_form_config_admin_import_form_alter(&$form, FormStateInterface $form_state) {
$enabled = [];
$used_config_split_text = t('You are not using any config split configuration');
$config_split_entities = \Drupal::entityTypeManager()->getStorage('config_split')->loadMultiple();
$active_filters = \Drupal::service('plugin.manager.config_filter')->getDefinitions();
$active_filters = array_filter($active_filters, function ($filter) {
return $filter['status'];
});
/** @var \Drupal\config_split\Entity\ConfigSplitEntityInterface $config_split_entity */
foreach ($config_split_entities as $config_split_entity) {
if (in_array('config_split:' . $config_split_entity->id(), array_keys($active_filters))) {
$enabled[] = Link::fromTextAndUrl($config_split_entity->label(), $config_split_entity->toUrl())->toString();
// Read the configuration and check differences in important fields.
$config_name = $config_split_entity->getConfigDependencyName();
$active = \Drupal::getContainer()->get('config.storage')->read($config_name);
$staged = \Drupal::getContainer()->get('config.storage.sync')->read($config_name);
$fields = ['status', 'weight', 'folder'];
$warnings = array_sum(array_map(function ($filed) use ($active, $staged) {
return $active[$filed] != $staged[$filed];
}, $fields));
if ($warnings) {
\Drupal::messenger()
->addWarning(t('The configuration for @split has changed, consider a single import for it first.', ['@split' => $config_split_entity->label()]));
}
}
}
if (!empty($enabled)) {
$used_config_split_text = t('Used config split configuration:') . ' ' . implode(', ', $enabled);
}
$form['config_split']['#weight'] = -10;
$form['config_split']['#markup'] = '<p>' . $used_config_split_text . '</p>';
}
/**
* Implements hook_help().
*/
function config_split_help($route_name, RouteMatchInterface $route_match) {
switch ($route_name) {
case 'help.page.config_split':
$output = '';
$output .= '<h3>' . t('About') . '</h3>';
$output .= '<p>' . t('
The Drupal 8 configuration management works best when importing and exporting
the whole set of the sites configuration. However, sometimes developers like to
opt out of the robustness of CM and have a super-set of configuration active on
their development machine. The canonical example for this is to have the
<code>devel</code> module enabled or having a few block placements or views in
the development environment and then not export them into the set of
configuration to be deployed, yet still being able to share the development
configuration with colleagues.
This module allows to define sets of configuration that will get exported to
separate directories when exporting, and get merged together when importing.
It is possible to define in settings.php which of these sets should be active
and considered for the export and import.
For more information, see the <a href=":online-documentation">online documentation for the Config Split module</a>.',
[
':online-documentation' => 'https://www.drupal.org/docs/8/modules/configuration-split',
])
. '</p>';
$output .= '<h3>' . t('Uses') . '</h3>';
$output .= '<dl>';
$output .= '<dt>' . t('Setting up a split') . '</dt>';
$output .= '<dd>' . t('
Let us assume that you configured your sync directory as follows:
<code>
$config_directories[CONFIG_SYNC_DIRECTORY] = \'../config/sync\';
</code>
Create a split with the folder `../config/my-split-folder` and create that
directory. Now add a module that is currently active that you wish not to
export, say `devel`. Next export all the configuration (with `drush cex` for
drush >= 8.1.10 and `drush csex` for older versions of drush).
This should have removed devel from `core.extensions` and moved the devel
configuration to the split folder.') . '</dd>';
$output .= '<dt>' . t('Deploy splits') . '</dt>';
$output .= '<dd>' . t('
Now deploy the configuration and devel will be un-installed.
On another developers machine just import the configuration, add the override,
clear the cache, and import again to have devel enabled on that environment.
You should only edit active splits as inactive splits will not take effect when
exporting the configuration.') . '</dd>';
$output .= '</dl>';
return $output;
case 'entity.config_split.add_form':
case 'entity.config_split.edit_form':
$output = '';
$output .= '<p>' . t('Config Split Help') . '</p>';
$output .= '<p>' . t('The configuration listed as part of a split
are exported to the split directory rather than the usual sync directory
when exporting the whole configuration. When importing the whole
configuration, the configuration in the split directories is merged with
the default sync directory and overrides the configuration.
The configuration does not end up being overwritten in the sense of
configuration overrides such as the overrides from settings.php.') . '</p>';
return $output;
}
return NULL;
}
/**
* Implements hook_config_readonly_whitelist_patterns().
*
* Automatically add any enabled database config splits' graylist and blacklist
* entries as whitelisted patterns for config_readonly.
*/
function config_split_config_readonly_whitelist_patterns() {
$patterns = [];
$splits = \Drupal::entityTypeManager()->getStorage('config_split')->loadByProperties(['folder' => '', 'status' => TRUE]);
foreach ($splits as $split) {
$patterns = array_merge($patterns, $split->get('graylist'), $split->get('blacklist'));
}
return $patterns;
}