class EncryptionProfileListBuilder in Encrypt 8.3
Provides a listing of encryption profile entities.
Hierarchy
- class \Drupal\Core\Entity\EntityHandlerBase uses DependencySerializationTrait, StringTranslationTrait
- class \Drupal\Core\Entity\EntityListBuilder implements EntityHandlerInterface, EntityListBuilderInterface uses MessengerTrait, RedirectDestinationTrait
- class \Drupal\Core\Config\Entity\ConfigEntityListBuilder
- class \Drupal\encrypt\Controller\EncryptionProfileListBuilder
- class \Drupal\Core\Config\Entity\ConfigEntityListBuilder
- class \Drupal\Core\Entity\EntityListBuilder implements EntityHandlerInterface, EntityListBuilderInterface uses MessengerTrait, RedirectDestinationTrait
Expanded class hierarchy of EncryptionProfileListBuilder
File
- src/
Controller/ EncryptionProfileListBuilder.php, line 16
Namespace
Drupal\encrypt\ControllerView source
class EncryptionProfileListBuilder extends ConfigEntityListBuilder {
/**
* A configuration object.
*
* @var \Drupal\Core\Config\ImmutableConfig
*/
protected $config;
/**
* Constructs a new EncryptionProfileListBuilder object.
*
* @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
* The entity type definition.
* @param \Drupal\Core\Entity\EntityStorageInterface $storage
* The entity storage class.
* @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
* The configuration factory.
*/
public function __construct(EntityTypeInterface $entity_type, EntityStorageInterface $storage, ConfigFactoryInterface $config_factory) {
parent::__construct($entity_type, $storage);
$this->config = $config_factory
->get('encrypt.settings');
}
/**
* {@inheritdoc}
*/
public static function createInstance(ContainerInterface $container, EntityTypeInterface $entity_type) {
return new static($entity_type, $container
->get('entity_type.manager')
->getStorage($entity_type
->id()), $container
->get('config.factory'));
}
/**
* {@inheritdoc}
*/
public function buildHeader() {
$header['label'] = $this
->t('Label');
$header['encryption_method'] = $this
->t('Encryption method');
$header['key'] = $this
->t('Key');
if ($this->config
->get('check_profile_status')) {
$header['status'] = $this
->t('Status');
}
return $header + parent::buildHeader();
}
/**
* {@inheritdoc}
*/
public function buildRow(EntityInterface $entity) {
$row['label'] = $entity
->label();
// Render encryption method row.
if ($encryption_method = $entity
->getEncryptionMethod()) {
$row['encryption_method'] = $encryption_method
->getLabel();
}
else {
$row['encryption_method'] = $this
->t('Error loading encryption method');
}
// Render encryption key row.
if ($key = $entity
->getEncryptionKey()) {
$row['key'] = $key
->label();
}
else {
$row['key'] = $this
->t('Error loading key');
}
// Render status report row.
if ($this->config
->get('check_profile_status')) {
$errors = $entity
->validate();
$warnings = [];
// Check if the encryption plugin is deprecated.
if ($encryption_method
->isDeprecated()) {
$warnings[] = $this
->t('The encryption plugin used in this encryption profile is deprecated.');
}
if (!empty($errors)) {
$row['status']['data'] = [
'#theme' => 'item_list',
'#items' => $errors,
'#attributes' => [
"class" => [
"color-error",
],
],
];
}
elseif (!empty($warnings)) {
$row['status']['data'] = [
'#theme' => 'item_list',
'#items' => $warnings,
'#attributes' => [
"class" => [
"color-warning",
],
],
];
}
else {
$row['status'] = $this
->t('OK');
}
}
return $row + parent::buildRow($entity);
}
/**
* {@inheritdoc}
*/
public function getDefaultOperations(EntityInterface $entity) {
/* @var \Drupal\Core\Config\Entity\ConfigEntityInterface $entity */
$operations = parent::getDefaultOperations($entity);
if ($entity
->hasLinkTemplate('test-form')) {
$operations['test'] = [
'title' => $this
->t('Test'),
'weight' => 30,
'url' => $entity
->toUrl('test-form'),
];
}
return $operations;
}
/**
* {@inheritdoc}
*/
public function render() {
$build = parent::render();
$build['table']['#empty'] = $this
->t('No encryption profiles are available. <a href=":link">Add a profile</a>.', [
':link' => Url::fromRoute('entity.encryption_profile.add_form')
->toString(),
]);
return $build;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigEntityListBuilder:: |
public | function |
Loads entities of this type from storage for listing. Overrides EntityListBuilder:: |
7 |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
EncryptionProfileListBuilder:: |
protected | property | A configuration object. | |
EncryptionProfileListBuilder:: |
public | function |
Builds the header row for the entity listing. Overrides EntityListBuilder:: |
|
EncryptionProfileListBuilder:: |
public | function |
Builds a row for an entity in the entity listing. Overrides EntityListBuilder:: |
|
EncryptionProfileListBuilder:: |
public static | function |
Instantiates a new instance of this entity handler. Overrides EntityListBuilder:: |
|
EncryptionProfileListBuilder:: |
public | function |
Gets this list's default operations. Overrides ConfigEntityListBuilder:: |
|
EncryptionProfileListBuilder:: |
public | function |
Builds the entity listing as renderable array for table.html.twig. Overrides EntityListBuilder:: |
|
EncryptionProfileListBuilder:: |
public | function |
Constructs a new EncryptionProfileListBuilder object. Overrides EntityListBuilder:: |
|
EntityHandlerBase:: |
protected | property | The module handler to invoke hooks on. | 2 |
EntityHandlerBase:: |
protected | function | Gets the module handler. | 2 |
EntityHandlerBase:: |
public | function | Sets the module handler for this handler. | |
EntityListBuilder:: |
protected | property | Information about the entity type. | |
EntityListBuilder:: |
protected | property | The entity type ID. | |
EntityListBuilder:: |
protected | property | The number of entities to list per page, or FALSE to list all entities. | 3 |
EntityListBuilder:: |
protected | property | The entity storage class. | 1 |
EntityListBuilder:: |
public | function | Builds a renderable list of operation links for the entity. | 2 |
EntityListBuilder:: |
protected | function | Ensures that a destination is present on the given URL. | |
EntityListBuilder:: |
protected | function | Loads entity IDs using a pager sorted by the entity id. | 4 |
EntityListBuilder:: |
protected | function | Gets the label of an entity. | |
EntityListBuilder:: |
public | function |
Provides an array of information to build a list of operation links. Overrides EntityListBuilderInterface:: |
2 |
EntityListBuilder:: |
public | function |
Gets the entity storage. Overrides EntityListBuilderInterface:: |
|
EntityListBuilder:: |
protected | function | Gets the title of the page. | 1 |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
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. |