class Permissions in Drupal 10
Same name in this branch
- 10 core/modules/content_moderation/src/Permissions.php \Drupal\content_moderation\Permissions
- 10 core/modules/user/src/Plugin/views/filter/Permissions.php \Drupal\user\Plugin\views\filter\Permissions
- 10 core/modules/user/src/Plugin/views/field/Permissions.php \Drupal\user\Plugin\views\field\Permissions
Same name and namespace in other branches
- 8 core/modules/user/src/Plugin/views/field/Permissions.php \Drupal\user\Plugin\views\field\Permissions
- 9 core/modules/user/src/Plugin/views/field/Permissions.php \Drupal\user\Plugin\views\field\Permissions
Field handler to provide a list of permissions.
Plugin annotation
@ViewsField("user_permissions");Hierarchy
- class \Drupal\views\Plugin\views\field\PrerenderList extends \Drupal\views\Plugin\views\field\FieldPluginBase implements MultiItemsFieldHandlerInterface- class \Drupal\user\Plugin\views\field\Permissions
 
Expanded class hierarchy of Permissions
7 string references to 'Permissions'
- drupal6.php in core/modules/ migrate_drupal/ tests/ fixtures/ drupal6.php 
- A database agnostic dump for testing purposes.
- drupal7.php in core/modules/ tracker/ tests/ fixtures/ drupal7.php 
- A database agnostic dump for testing purposes.
- drupal7.php in core/modules/ rdf/ tests/ fixtures/ drupal7.php 
- A database agnostic dump for testing purposes.
- drupal7.php in core/modules/ migrate_drupal/ tests/ fixtures/ drupal7.php 
- A database agnostic dump for testing purposes.
- user.links.task.yml in core/modules/ user/ user.links.task.yml 
- core/modules/user/user.links.task.yml
File
- core/modules/ user/ src/ Plugin/ views/ field/ Permissions.php, line 19 
Namespace
Drupal\user\Plugin\views\fieldView source
class Permissions extends PrerenderList {
  /**
   * The role storage.
   *
   * @var \Drupal\user\RoleStorageInterface
   */
  protected $roleStorage;
  /**
   * The module handler.
   *
   * @var \Drupal\Core\Extension\ModuleHandlerInterface
   */
  protected $moduleHandler;
  /**
   * Constructs a \Drupal\user\Plugin\views\field\Permissions object.
   *
   * @param array $configuration
   *   A configuration array containing information about the plugin instance.
   * @param string $plugin_id
   *   The plugin_id for the plugin instance.
   * @param mixed $plugin_definition
   *   The plugin implementation definition.
   * @param \Drupal\Core\Extension\ModuleHandlerInterface $module_handler
   *   The module handler.
   * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
   *   The entity type manager.
   */
  public function __construct(array $configuration, $plugin_id, $plugin_definition, ModuleHandlerInterface $module_handler, EntityTypeManagerInterface $entity_type_manager) {
    parent::__construct($configuration, $plugin_id, $plugin_definition);
    $this->roleStorage = $entity_type_manager
      ->getStorage('user_role');
    $this->moduleHandler = $module_handler;
  }
  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
    return new static($configuration, $plugin_id, $plugin_definition, $container
      ->get('module_handler'), $container
      ->get('entity_type.manager'));
  }
  /**
   * {@inheritdoc}
   */
  public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) {
    parent::init($view, $display, $options);
    $this->additional_fields['uid'] = [
      'table' => 'users_field_data',
      'field' => 'uid',
    ];
  }
  public function query() {
    $this
      ->addAdditionalFields();
    $this->field_alias = $this->aliases['uid'];
  }
  public function preRender(&$values) {
    $this->items = [];
    $permission_names = \Drupal::service('user.permissions')
      ->getPermissions();
    $rids = [];
    foreach ($values as $result) {
      $user_rids = $this
        ->getEntity($result)
        ->getRoles();
      $uid = $this
        ->getValue($result);
      foreach ($user_rids as $rid) {
        $rids[$rid][] = $uid;
      }
    }
    if ($rids) {
      $roles = $this->roleStorage
        ->loadMultiple(array_keys($rids));
      foreach ($rids as $rid => $role_uids) {
        foreach ($roles[$rid]
          ->getPermissions() as $permission) {
          foreach ($role_uids as $uid) {
            $this->items[$uid][$permission]['permission'] = $permission_names[$permission]['title'];
          }
        }
      }
      foreach ($this->items as &$permission) {
        ksort($permission);
      }
    }
  }
  public function render_item($count, $item) {
    return $item['permission'];
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| DerivativeInspectionInterface:: | public | function | Gets the base_plugin_id of the plugin instance. | |
| DerivativeInspectionInterface:: | public | function | Gets the derivative_id of the plugin instance. | |
| FieldHandlerInterface:: | public | function | Renders a field using advanced settings. | |
| FieldHandlerInterface:: | public | function | Adds an ORDER BY clause to the query for click sort columns. | |
| FieldHandlerInterface:: | public | function | Determines if this field is click sortable. | |
| FieldHandlerInterface:: | public | function | Returns the class of the field. | |
| FieldHandlerInterface:: | public | function | Returns the class of the field's label. | |
| FieldHandlerInterface:: | public | function | Returns an HTML element for the label based upon the field's element type. | |
| FieldHandlerInterface:: | public | function | Returns an HTML element based upon the field's element type. | |
| FieldHandlerInterface:: | public | function | Returns the class of the field's wrapper. | |
| FieldHandlerInterface:: | public | function | Returns an HTML element for the wrapper based upon the field's element type. | |
| FieldHandlerInterface:: | public | function | Provides a list of elements valid for field HTML. | |
| FieldHandlerInterface:: | public | function | Gets the entity matching the current row and relationship. | |
| FieldHandlerInterface:: | public | function | Gets the 'render' tokens to use for advanced rendering. | |
| FieldHandlerInterface:: | public | function | Gets the value that's supposed to be rendered. | |
| FieldHandlerInterface:: | public | function | Checks if a field value is empty. | |
| FieldHandlerInterface:: | public | function | Gets this field's label. | |
| FieldHandlerInterface:: | public | function | Runs after every field has been rendered. | |
| FieldHandlerInterface:: | public | function | Renders the field. | |
| FieldHandlerInterface:: | public | function | Performs an advanced text render for the item. | |
| FieldHandlerInterface:: | public | function | Renders row values using $this->themeFunctions() as #theme. | |
| FieldHandlerInterface:: | public | function | Replaces a value with tokens from the last field. | |
| FieldHandlerInterface:: | public | function | Determines if this field will be available as an option to group the result by in the style settings. | |
| Permissions:: | protected | property | The module handler. | |
| Permissions:: | protected | property | The role storage. | |
| Permissions:: | public static | function | Overrides ViewsPluginInterface:: | |
| Permissions:: | public | function | Initialize the plugin. Overrides ViewsPluginInterface:: | |
| Permissions:: | public | function | Runs before any fields are rendered. Overrides FieldHandlerInterface:: | |
| Permissions:: | public | function | Add anything to the query that we might need to. Overrides ViewsPluginInterface:: | |
| Permissions:: | public | function | Renders a single item of a row. Overrides MultiItemsFieldHandlerInterface:: | |
| Permissions:: | public | function | Constructs a \Drupal\user\Plugin\views\field\Permissions object. | |
| PluginInspectionInterface:: | public | function | Gets the definition of the plugin implementation. | 1 | 
| PluginInspectionInterface:: | public | function | Gets the plugin_id of the plugin instance. | 1 | 
| PrerenderList:: | public | property | Stores all items which are used to render the items. | |
| PrerenderList:: | public | function | Provide a form to edit options for this plugin. Overrides ViewsPluginInterface:: | 1 | 
| PrerenderList:: | protected | function | 1 | |
| PrerenderList:: | public | function | Items should be stored in the result array, if possible, as an array
with 'value' as the actual displayable value of the item, plus
any items that might be found in the 'alter' options array for
creating links, such as… Overrides MultiItemsFieldHandlerInterface:: | |
| PrerenderList:: | public | function | Render all items in this field together. Overrides MultiItemsFieldHandlerInterface:: | |
| ViewsHandlerInterface:: | public | function | Check whether given user has access to this handler. | |
| ViewsHandlerInterface:: | public | function | Return a string representing this handler's name in the UI. | |
| ViewsHandlerInterface:: | public | function | Provide text for the administrative summary. | |
| ViewsHandlerInterface:: | public static | function | Breaks x,y,z and x+y+z into an array. | |
| ViewsHandlerInterface:: | public | function | Determines if the handler is considered 'broken', meaning it's a placeholder used when a handler can't be found. | |
| ViewsHandlerInterface:: | public | function | Ensure the main table for this handler is in the query. This is used a lot. | |
| ViewsHandlerInterface:: | public | function | Determines the entity type used by this handler. | |
| ViewsHandlerInterface:: | public | function | Shortcut to get a handler's raw field value. | |
| ViewsHandlerInterface:: | public | function | Get the join object that should be used for this handler. | |
| ViewsHandlerInterface:: | public static | function | Fetches a handler to join one table to a primary table from the data cache. | |
| ViewsHandlerInterface:: | public | function | Run after the view is executed, before the result is cached. | |
| ViewsHandlerInterface:: | public | function | Run before the view is built. | |
| ViewsHandlerInterface:: | public | function | Sanitize the value for output. | |
| ViewsHandlerInterface:: | public | function | Called just prior to query(), this lets a handler set up any relationship it needs. | |
| ViewsHandlerInterface:: | public | function | Shortcut to display the exposed options form. | |
| ViewsPluginInterface:: | public | function | Clears a plugin. | |
| ViewsPluginInterface:: | public | function | Filter out stored options depending on the defined options. | |
| ViewsPluginInterface:: | public | function | Returns an array of available token replacements. | |
| ViewsPluginInterface:: | public | function | Returns the plugin provider. | |
| ViewsPluginInterface:: | public | function | Adds elements for available core tokens to a form. | |
| ViewsPluginInterface:: | public | function | Returns a string with any core tokens replaced. | |
| ViewsPluginInterface:: | public | function | Return the human readable name of the display. | |
| ViewsPluginInterface:: | public static | function | Moves form elements into fieldsets for presentation purposes. | |
| ViewsPluginInterface:: | public static | function | Flattens the structure of form elements. | |
| ViewsPluginInterface:: | public | function | Handle any special handling on the validate form. | |
| ViewsPluginInterface:: | public | function | Returns the summary of the settings in the display. | |
| ViewsPluginInterface:: | public | function | Provide a full list of possible theme templates used by this style. | |
| ViewsPluginInterface:: | public | function | Unpack options over our existing defaults, drilling down into arrays so that defaults don't get totally blown away. | |
| ViewsPluginInterface:: | public | function | Returns the usesOptions property. | |
| ViewsPluginInterface:: | public | function | Validate that the plugin is correct and can be saved. | |
| ViewsPluginInterface:: | public | function | Validate the options form. | 
