class ForumUninstallValidator in Drupal 8
Same name in this branch
- 8 core/modules/forum/src/ForumUninstallValidator.php \Drupal\forum\ForumUninstallValidator
- 8 core/modules/forum/src/ProxyClass/ForumUninstallValidator.php \Drupal\forum\ProxyClass\ForumUninstallValidator
Same name and namespace in other branches
- 9 core/modules/forum/src/ForumUninstallValidator.php \Drupal\forum\ForumUninstallValidator
- 10 core/modules/forum/src/ForumUninstallValidator.php \Drupal\forum\ForumUninstallValidator
Prevents forum module from being uninstalled whilst any forum nodes exist or there are any terms in the forum vocabulary.
Hierarchy
- class \Drupal\forum\ForumUninstallValidator implements ModuleUninstallValidatorInterface uses StringTranslationTrait
Expanded class hierarchy of ForumUninstallValidator
1 string reference to 'ForumUninstallValidator'
- forum.services.yml in core/
modules/ forum/ forum.services.yml - core/modules/forum/forum.services.yml
1 service uses ForumUninstallValidator
- forum.uninstall_validator in core/
modules/ forum/ forum.services.yml - Drupal\forum\ForumUninstallValidator
File
- core/
modules/ forum/ src/ ForumUninstallValidator.php, line 16
Namespace
Drupal\forumView source
class ForumUninstallValidator implements ModuleUninstallValidatorInterface {
use StringTranslationTrait;
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* The config factory.
*
* @var \Drupal\Core\Config\ConfigFactoryInterface
*/
protected $configFactory;
/**
* Constructs a new ForumUninstallValidator.
*
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
* @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
* The config factory.
* @param \Drupal\Core\StringTranslation\TranslationInterface $string_translation
* The string translation service.
*/
public function __construct(EntityTypeManagerInterface $entity_type_manager, ConfigFactoryInterface $config_factory, TranslationInterface $string_translation) {
$this->entityTypeManager = $entity_type_manager;
$this->configFactory = $config_factory;
$this->stringTranslation = $string_translation;
}
/**
* {@inheritdoc}
*/
public function validate($module) {
$reasons = [];
if ($module == 'forum') {
if ($this
->hasForumNodes()) {
$reasons[] = $this
->t('To uninstall Forum, first delete all <em>Forum</em> content');
}
$vocabulary = $this
->getForumVocabulary();
if ($this
->hasTermsForVocabulary($vocabulary)) {
if ($vocabulary
->access('view')) {
$reasons[] = $this
->t('To uninstall Forum, first delete all <a href=":url">%vocabulary</a> terms', [
'%vocabulary' => $vocabulary
->label(),
':url' => $vocabulary
->toUrl('overview-form')
->toString(),
]);
}
else {
$reasons[] = $this
->t('To uninstall Forum, first delete all %vocabulary terms', [
'%vocabulary' => $vocabulary
->label(),
]);
}
}
}
return $reasons;
}
/**
* Determines if there are any forum nodes or not.
*
* @return bool
* TRUE if there are forum nodes, FALSE otherwise.
*/
protected function hasForumNodes() {
$nodes = $this->entityTypeManager
->getStorage('node')
->getQuery()
->condition('type', 'forum')
->accessCheck(FALSE)
->range(0, 1)
->execute();
return !empty($nodes);
}
/**
* Determines if there are any taxonomy terms for a specified vocabulary.
*
* @param \Drupal\taxonomy\VocabularyInterface $vocabulary
* The vocabulary to check for terms.
*
* @return bool
* TRUE if there are terms for this vocabulary, FALSE otherwise.
*/
protected function hasTermsForVocabulary(VocabularyInterface $vocabulary) {
$terms = $this->entityTypeManager
->getStorage('taxonomy_term')
->getQuery()
->condition('vid', $vocabulary
->id())
->accessCheck(FALSE)
->range(0, 1)
->execute();
return !empty($terms);
}
/**
* Returns the vocabulary configured for forums.
*
* @return \Drupal\taxonomy\VocabularyInterface
* The vocabulary entity for forums.
*/
protected function getForumVocabulary() {
$vid = $this->configFactory
->get('forum.settings')
->get('vocabulary');
return $this->entityTypeManager
->getStorage('taxonomy_vocabulary')
->load($vid);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ForumUninstallValidator:: |
protected | property | The config factory. | |
ForumUninstallValidator:: |
protected | property | The entity type manager. | |
ForumUninstallValidator:: |
protected | function | Returns the vocabulary configured for forums. | |
ForumUninstallValidator:: |
protected | function | Determines if there are any forum nodes or not. | |
ForumUninstallValidator:: |
protected | function | Determines if there are any taxonomy terms for a specified vocabulary. | |
ForumUninstallValidator:: |
public | function |
Determines the reasons a module can not be uninstalled. Overrides ModuleUninstallValidatorInterface:: |
|
ForumUninstallValidator:: |
public | function | Constructs a new ForumUninstallValidator. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |