class BookUninstallValidator in Zircon Profile 8.0
Same name in this branch
- 8.0 core/modules/book/src/BookUninstallValidator.php \Drupal\book\BookUninstallValidator
- 8.0 core/modules/book/src/ProxyClass/BookUninstallValidator.php \Drupal\book\ProxyClass\BookUninstallValidator
Same name and namespace in other branches
- 8 core/modules/book/src/BookUninstallValidator.php \Drupal\book\BookUninstallValidator
Prevents book module from being uninstalled whilst any book nodes exist or there are any book outline stored.
Hierarchy
- class \Drupal\book\BookUninstallValidator implements ModuleUninstallValidatorInterface uses StringTranslationTrait
Expanded class hierarchy of BookUninstallValidator
1 string reference to 'BookUninstallValidator'
- book.services.yml in core/
modules/ book/ book.services.yml - core/modules/book/book.services.yml
1 service uses BookUninstallValidator
- book.uninstall_validator in core/
modules/ book/ book.services.yml - Drupal\book\BookUninstallValidator
File
- core/
modules/ book/ src/ BookUninstallValidator.php, line 19 - Contains \Drupal\book\BookUninstallValidator.
Namespace
Drupal\bookView source
class BookUninstallValidator implements ModuleUninstallValidatorInterface {
use StringTranslationTrait;
/**
* The book outline storage.
*
* @var \Drupal\book\BookOutlineStorageInterface
*/
protected $bookOutlineStorage;
/**
* The entity query for node.
*
* @var \Drupal\Core\Entity\Query\QueryInterface
*/
protected $entityQuery;
/**
* Constructs a new BookUninstallValidator.
*
* @param \Drupal\book\BookOutlineStorageInterface $book_outline_storage
* The book outline storage.
* @param \Drupal\Core\Entity\Query\QueryFactory $query_factory
* The entity query factory.
* @param \Drupal\Core\StringTranslation\TranslationInterface $string_translation
* The string translation service.
*/
public function __construct(BookOutlineStorageInterface $book_outline_storage, QueryFactory $query_factory, TranslationInterface $string_translation) {
$this->bookOutlineStorage = $book_outline_storage;
$this->entityQuery = $query_factory
->get('node');
$this->stringTranslation = $string_translation;
}
/**
* {@inheritdoc}
*/
public function validate($module) {
$reasons = [];
if ($module == 'book') {
if ($this
->hasBookOutlines()) {
$reasons[] = $this
->t('To uninstall Book, delete all content that is part of a book');
}
else {
// The book node type is provided by the Book module. Prevent uninstall
// if there are any nodes of that type.
if ($this
->hasBookNodes()) {
$reasons[] = $this
->t('To uninstall Book, delete all content that has the Book content type');
}
}
}
return $reasons;
}
/**
* Checks if there are any books in an outline.
*
* @return bool
* TRUE if there are books, FALSE if not.
*/
protected function hasBookOutlines() {
return $this->bookOutlineStorage
->hasBooks();
}
/**
* Determines if there is any book nodes or not.
*
* @return bool
* TRUE if there are book nodes, FALSE otherwise.
*/
protected function hasBookNodes() {
$nodes = $this->entityQuery
->condition('type', 'book')
->accessCheck(FALSE)
->range(0, 1)
->execute();
return !empty($nodes);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
BookUninstallValidator:: |
protected | property | The book outline storage. | |
BookUninstallValidator:: |
protected | property | The entity query for node. | |
BookUninstallValidator:: |
protected | function | Determines if there is any book nodes or not. | |
BookUninstallValidator:: |
protected | function | Checks if there are any books in an outline. | |
BookUninstallValidator:: |
public | function |
Determines the reasons a module can not be uninstalled. Overrides ModuleUninstallValidatorInterface:: |
|
BookUninstallValidator:: |
public | function | Constructs a new BookUninstallValidator. | |
StringTranslationTrait:: |
protected | property | The string translation service. | |
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. |