Merge pull request #20845 from herbdool/issue-899
[civicrm-core.git] / mixin / setting-php@1 / mixin.php
1 <?php
2
3 /**
4 * Auto-register "settings/*.setting.php" files.
5 *
6 * @mixinName setting-php
7 * @mixinVersion 1.0.0
8 *
9 * @param CRM_Extension_MixInfo $mixInfo
10 * On newer deployments, this will be an instance of MixInfo. On older deployments, Civix may polyfill with a work-a-like.
11 * @param \CRM_Extension_BootCache $bootCache
12 * On newer deployments, this will be an instance of MixInfo. On older deployments, Civix may polyfill with a work-a-like.
13 */
14 return function ($mixInfo, $bootCache) {
15
16 /**
17 * @param \Civi\Core\Event\GenericHookEvent $e
18 * @see CRM_Utils_Hook::alterSettingsFolders()
19 */
20 Civi::dispatcher()->addListener('hook_civicrm_alterSettingsFolders', function ($e) use ($mixInfo) {
21 // When deactivating on a polyfill/pre-mixin system, listeners may not cleanup automatically.
22 if (!$mixInfo->isActive()) {
23 return;
24 }
25
26 $settingsDir = $mixInfo->getPath('settings');
27 if (!in_array($settingsDir, $e->settingsFolders) && is_dir($settingsDir)) {
28 $e->settingsFolders[] = $settingsDir;
29 }
30 });
31
32 };