3 namespace Drupal\filter;
5 use Drupal\Component\Plugin\PluginManagerInterface;
6 use Drupal\Core\Entity\EntityManagerInterface;
7 use Drupal\Core\Extension\ModuleUninstallValidatorInterface;
8 use Drupal\Core\StringTranslation\StringTranslationTrait;
9 use Drupal\Core\StringTranslation\TranslationInterface;
12 * Prevents uninstallation of modules providing used filter plugins.
14 class FilterUninstallValidator implements ModuleUninstallValidatorInterface {
16 use StringTranslationTrait;
19 * The filter plugin manager.
21 * @var \Drupal\Component\Plugin\PluginManagerInterface
23 protected $filterManager;
26 * The filter entity storage.
28 * @var \Drupal\Core\Config\Entity\ConfigEntityStorageInterface
30 protected $filterStorage;
33 * Constructs a new FilterUninstallValidator.
35 * @param \Drupal\Component\Plugin\PluginManagerInterface $filter_manager
36 * The filter plugin manager.
37 * @param \Drupal\Core\Entity\EntityManagerInterface $entity_manager
39 * @param \Drupal\Core\StringTranslation\TranslationInterface $string_translation
40 * The string translation service.
42 public function __construct(PluginManagerInterface $filter_manager, EntityManagerInterface $entity_manager, TranslationInterface $string_translation) {
43 $this->filterManager = $filter_manager;
44 $this->filterStorage = $entity_manager->getStorage('filter_format');
45 $this->stringTranslation = $string_translation;
51 public function validate($module) {
53 // Get filter plugins supplied by this module.
54 if ($filter_plugins = $this->getFilterDefinitionsByProvider($module)) {
56 // Find out if any filter formats have the plugin enabled.
57 foreach ($this->getEnabledFilterFormats() as $filter_format) {
58 $filters = $filter_format->filters();
59 foreach ($filter_plugins as $filter_plugin) {
60 if ($filters->has($filter_plugin['id']) && $filters->get($filter_plugin['id'])->status) {
61 $used_in[] = $filter_format->label();
66 if (!empty($used_in)) {
67 $reasons[] = $this->t('Provides a filter plugin that is in use in the following filter formats: %formats', ['%formats' => implode(', ', $used_in)]);
74 * Returns all filter definitions that are provided by the specified provider.
76 * @param string $provider
77 * The provider of the filters.
80 * The filter definitions for the specified provider.
82 protected function getFilterDefinitionsByProvider($provider) {
83 return array_filter($this->filterManager->getDefinitions(), function ($definition) use ($provider) {
84 return $definition['provider'] == $provider;
89 * Returns all enabled filter formats.
91 * @return \Drupal\filter\FilterFormatInterface[]
93 protected function getEnabledFilterFormats() {
94 return $this->filterStorage->loadByProperties(['status' => TRUE]);