BookUninstallValidator::validate

public BookUninstallValidator::validate($module)

Determines the reasons a module can not be uninstalled.

Example implementation:

public function validate($module) {
  $entity_types = $this->entityManager->getDefinitions();
  $reasons = array();
  foreach ($entity_types as $entity_type) {
    if ($module == $entity_type->getProvider() && $entity_type instanceof ContentEntityTypeInterface && $this->entityManager->getStorage($entity_type->id())->hasData()) {
      $reasons[] = $this->t('There is content for the entity type: @entity_type', array('@entity_type' => $entity_type->getLabel()));
    }
  }
  return $reasons;
}

Parameters

string $module: A module name.

Return value

string[] An array of reasons the module can not be uninstalled, empty if it can. Each reason should not end with any punctuation since multiple reasons can be displayed together.

Overrides ModuleUninstallValidatorInterface::validate

See also

template_preprocess_system_modules_uninstall()

File

core/modules/book/src/BookUninstallValidator.php, line 51

Class

BookUninstallValidator
Prevents book module from being uninstalled whilst any book nodes exist or there are any book outline stored.

Namespace

Drupal\book

Code

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;
}
doc_Drupal
2016-10-29 08:48:35
Comments
Leave a Comment

Please login to continue.