Access plugin that provides permission-based access control.
@Plugin(
  id = "perm",
  title = @Translation("Permission"),
  help = @Translation("Access will be granted to users with the specified permission string.")
)
Expanded class hierarchy of Permission
class Permission extends AccessPluginBase {
  /**
   * Overrides Drupal\views\Plugin\Plugin::$usesOptions.
   */
  protected $usesOptions = TRUE;
  /**
   * {@inheritdoc}
   */
  public function access(AccountInterface $account) {
    return user_access($this->options['perm'], $account) || user_access('access all views', $account);
  }
  /**
   * {@inheritdoc}
   */
  public function alterRouteDefinition(Route $route) {
    $route
      ->setRequirement('_permission', $this->options['perm']);
  }
  public function summaryTitle() {
    $permissions = module_invoke_all('permission');
    if (isset($permissions[$this->options['perm']])) {
      return $permissions[$this->options['perm']]['title'];
    }
    return t($this->options['perm']);
  }
  protected function defineOptions() {
    $options = parent::defineOptions();
    $options['perm'] = array(
      'default' => 'access content',
    );
    return $options;
  }
  public function buildOptionsForm(&$form, &$form_state) {
    parent::buildOptionsForm($form, $form_state);
    $perms = array();
    $module_info = system_get_info('module');
    // Get list of permissions
    foreach (module_implements('permission') as $module) {
      $permissions = module_invoke($module, 'permission');
      foreach ($permissions as $name => $perm) {
        $perms[$module_info[$module]['name']][$name] = strip_tags($perm['title']);
      }
    }
    ksort($perms);
    $form['perm'] = array(
      '#type' => 'select',
      '#options' => $perms,
      '#title' => t('Permission'),
      '#default_value' => $this->options['perm'],
      '#description' => t('Only users with the selected permission flag will be able to access this display. Note that users with "access all views" can see any view, regardless of other permissions.'),
    );
  }
}| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| AccessPluginBase:: | public | function | Provide the default form form for submitting options Overrides PluginBase:: | 1 | 
| AccessPluginBase:: | public | function | Provide the default form form for validating options Overrides PluginBase:: | 1 | 
| ContainerFactoryPluginBase:: | public static | function | Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: | 11 | 
| Permission:: | protected | property | Overrides Drupal\views\Plugin\Plugin::$usesOptions. Overrides PluginBase:: | |
| Permission:: | public | function | Determine if the current user has access or not. Overrides AccessPluginBase:: | |
| Permission:: | public | function | Allows access plugins to alter the route definition of a view. Overrides AccessPluginBase:: | |
| Permission:: | public | function | Provide the default form for setting options. Overrides AccessPluginBase:: | |
| Permission:: | protected | function | Retrieve the options when this is a new access
control plugin Overrides AccessPluginBase:: | |
| Permission:: | public | function | Return a string to display as the clickable title for the
access control. Overrides AccessPluginBase:: | |
| PluginBase:: | protected | property | Configuration information passed into the plugin. | 1 | 
| PluginBase:: | public | property | Plugins's definition | |
| PluginBase:: | public | property | The display object this plugin is for. | |
| PluginBase:: | public | property | Options for this plugin will be held here. | |
| PluginBase:: | protected | property | The plugin implementation definition. | |
| PluginBase:: | protected | property | The plugin_id. | |
| PluginBase:: | public | property | The top object of a view. | 1 | 
| PluginBase:: | public | function | Clears a plugin. | 2 | 
| PluginBase:: | public | function | Returns an array of available token replacements. | |
| PluginBase:: | public | function | Returns the definition of the plugin implementation. Overrides PluginInspectionInterface:: | |
| PluginBase:: | public | function | Returns the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: | |
| PluginBase:: | public | function | Adds elements for available core tokens to a form. | |
| PluginBase:: | public | function | Returns a string with any core tokens replaced. | |
| PluginBase:: | public | function | Initialize the plugin. | 8 | 
| PluginBase:: | public | function | Return the human readable name of the display. | |
| PluginBase:: | public | function | Add anything to the query that we might need to. | 13 | 
| PluginBase:: | protected | function | Fills up the options of the plugin with defaults. | |
| PluginBase:: | public | function | Provide a full list of possible theme templates used by this style. | 1 | 
| PluginBase:: | public | function | Unpack options over our existing defaults, drilling down into arrays so that defaults don't get totally blown away. | |
| PluginBase:: | public | function | Returns the usesOptions property. | 8 | 
| PluginBase:: | public | function | Validate that the plugin is correct and can be saved. | 4 | 
| PluginBase:: | public | function | Constructs a Plugin object. Overrides PluginBase:: |