class RestExport in Drupal 8
Same name and namespace in other branches
- 9 core/modules/rest/src/Plugin/views/display/RestExport.php \Drupal\rest\Plugin\views\display\RestExport
The plugin that handles Data response callbacks for REST resources.
Plugin annotation
@ViewsDisplay(
  id = "rest_export",
  title = @Translation("REST export"),
  help = @Translation("Create a REST export resource."),
  uses_route = TRUE,
  admin = @Translation("REST export"),
  returns_response = TRUE
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait- class \Drupal\views\Plugin\views\PluginBase implements DependentPluginInterface, ContainerFactoryPluginInterface, TrustedCallbackInterface, ViewsPluginInterface- class \Drupal\views\Plugin\views\display\DisplayPluginBase implements DependentPluginInterface, DisplayPluginInterface uses PluginDependencyTrait- class \Drupal\views\Plugin\views\display\PathPluginBase implements DisplayMenuInterface, DisplayRouterInterface uses UrlGeneratorTrait- class \Drupal\rest\Plugin\views\display\RestExport implements ResponseDisplayPluginInterface
 
 
- class \Drupal\views\Plugin\views\display\PathPluginBase implements DisplayMenuInterface, DisplayRouterInterface uses UrlGeneratorTrait
 
- class \Drupal\views\Plugin\views\display\DisplayPluginBase implements DependentPluginInterface, DisplayPluginInterface uses PluginDependencyTrait
 
- class \Drupal\views\Plugin\views\PluginBase implements DependentPluginInterface, ContainerFactoryPluginInterface, TrustedCallbackInterface, ViewsPluginInterface
 
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of RestExport
Related topics
3 files declare their use of RestExport
- CollectRoutesTest.php in core/modules/ rest/ tests/ src/ Unit/ CollectRoutesTest.php 
- RestExportTest.php in core/modules/ rest/ tests/ src/ Kernel/ Views/ RestExportTest.php 
- SerializerTest.php in core/modules/ rest/ tests/ src/ Unit/ Plugin/ views/ style/ SerializerTest.php 
File
- core/modules/ rest/ src/ Plugin/ views/ display/ RestExport.php, line 34 
Namespace
Drupal\rest\Plugin\views\displayView source
class RestExport extends PathPluginBase implements ResponseDisplayPluginInterface {
  /**
   * {@inheritdoc}
   */
  protected $usesAJAX = FALSE;
  /**
   * {@inheritdoc}
   */
  protected $usesPager = FALSE;
  /**
   * {@inheritdoc}
   */
  protected $usesMore = FALSE;
  /**
   * {@inheritdoc}
   */
  protected $usesAreas = FALSE;
  /**
   * {@inheritdoc}
   */
  protected $usesOptions = FALSE;
  /**
   * Overrides the content type of the data response, if needed.
   *
   * @var string
   */
  protected $contentType = 'json';
  /**
   * The mime type for the response.
   *
   * @var string
   */
  protected $mimeType = 'application/json';
  /**
   * The renderer.
   *
   * @var \Drupal\Core\Render\RendererInterface
   */
  protected $renderer;
  /**
   * The collector of authentication providers.
   *
   * @var \Drupal\Core\Authentication\AuthenticationCollectorInterface
   */
  protected $authenticationCollector;
  /**
   * The authentication providers, like 'cookie' and 'basic_auth'.
   *
   * @var string[]
   */
  protected $authenticationProviderIds;
  /**
   * The authentication providers' modules, keyed by provider ID.
   *
   * Authentication providers like 'cookie' and 'basic_auth' are the array
   * keys. The array values are the module names, e.g.:
   * @code
   *   ['cookie' => 'user', 'basic_auth' => 'basic_auth']
   * @endcode
   *
   * @deprecated in drupal:8.4.0 and is removed from drupal:9.0.0. see
   *   https://www.drupal.org/node/2825204.
   *
   * @var string[]
   */
  protected $authenticationProviders;
  /**
   * The serialization format providers, keyed by format.
   *
   * @var string[]
   */
  protected $formatProviders;
  /**
   * Constructs a RestExport 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\Routing\RouteProviderInterface $route_provider
   *   The route provider.
   * @param \Drupal\Core\State\StateInterface $state
   *   The state key value store.
   * @param \Drupal\Core\Render\RendererInterface $renderer
   *   The renderer.
   * @param string[] $authentication_providers
   *   The authentication providers, keyed by ID.
   * @param string[] $serializer_format_providers
   *   The serialization format providers, keyed by format.
   */
  public function __construct(array $configuration, $plugin_id, $plugin_definition, RouteProviderInterface $route_provider, StateInterface $state, RendererInterface $renderer, array $authentication_providers, array $serializer_format_providers) {
    parent::__construct($configuration, $plugin_id, $plugin_definition, $route_provider, $state);
    $this->renderer = $renderer;
    // $authentication_providers as defined in
    // \Drupal\Core\DependencyInjection\Compiler\AuthenticationProviderPass
    // and as such it is an array, with authentication providers (cookie,
    // basic_auth) as keys and modules providing those as values (user,
    // basic_auth).
    $this->authenticationProviderIds = array_keys($authentication_providers);
    // For BC reasons we keep around authenticationProviders as before.
    $this->authenticationProviders = $authentication_providers;
    $this->formatProviders = $serializer_format_providers;
  }
  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
    return new static($configuration, $plugin_id, $plugin_definition, $container
      ->get('router.route_provider'), $container
      ->get('state'), $container
      ->get('renderer'), $container
      ->getParameter('authentication_providers'), $container
      ->getParameter('serializer.format_providers'));
  }
  /**
   * {@inheritdoc}
   */
  public function initDisplay(ViewExecutable $view, array &$display, array &$options = NULL) {
    parent::initDisplay($view, $display, $options);
    // If the default 'json' format is not selected as a format option in the
    // view display, fallback to the first format available for the default.
    if (!empty($options['style']['options']['formats']) && !isset($options['style']['options']['formats'][$this
      ->getContentType()])) {
      $default_format = reset($options['style']['options']['formats']);
      $this
        ->setContentType($default_format);
    }
    // Only use the requested content type if it's not 'html'. This allows
    // still falling back to the default for things like views preview.
    $request_content_type = $this->view
      ->getRequest()
      ->getRequestFormat();
    if ($request_content_type !== 'html') {
      $this
        ->setContentType($request_content_type);
    }
    $this
      ->setMimeType($this->view
      ->getRequest()
      ->getMimeType($this
      ->getContentType()));
  }
  /**
   * {@inheritdoc}
   */
  public function getType() {
    return 'data';
  }
  /**
   * {@inheritdoc}
   */
  public function usesExposed() {
    return TRUE;
  }
  /**
   * {@inheritdoc}
   */
  public function displaysExposed() {
    return FALSE;
  }
  /**
   * Sets the request content type.
   *
   * @param string $mime_type
   *   The response mime type. E.g. 'application/json'.
   */
  public function setMimeType($mime_type) {
    $this->mimeType = $mime_type;
  }
  /**
   * Gets the mime type.
   *
   * This will return any overridden mime type, otherwise returns the mime type
   * from the request.
   *
   * @return string
   *   The response mime type. E.g. 'application/json'.
   */
  public function getMimeType() {
    return $this->mimeType;
  }
  /**
   * Sets the content type.
   *
   * @param string $content_type
   *   The content type machine name. E.g. 'json'.
   */
  public function setContentType($content_type) {
    $this->contentType = $content_type;
  }
  /**
   * Gets the content type.
   *
   * @return string
   *   The content type machine name. E.g. 'json'.
   */
  public function getContentType() {
    return $this->contentType;
  }
  /**
   * Gets the auth options available.
   *
   * @return string[]
   *   An array to use as value for "#options" in the form element.
   */
  public function getAuthOptions() {
    return array_combine($this->authenticationProviderIds, $this->authenticationProviderIds);
  }
  /**
   * {@inheritdoc}
   */
  protected function defineOptions() {
    $options = parent::defineOptions();
    // Options for REST authentication.
    $options['auth'] = [
      'default' => [],
    ];
    // Set the default style plugin to 'json'.
    $options['style']['contains']['type']['default'] = 'serializer';
    $options['row']['contains']['type']['default'] = 'data_entity';
    $options['defaults']['default']['style'] = FALSE;
    $options['defaults']['default']['row'] = FALSE;
    // Remove css/exposed form settings, as they are not used for the data display.
    unset($options['exposed_form']);
    unset($options['exposed_block']);
    unset($options['css_class']);
    return $options;
  }
  /**
   * {@inheritdoc}
   */
  public function optionsSummary(&$categories, &$options) {
    parent::optionsSummary($categories, $options);
    // Authentication.
    $auth = $this
      ->getOption('auth') ? implode(', ', $this
      ->getOption('auth')) : $this
      ->t('No authentication is set');
    unset($categories['page'], $categories['exposed']);
    // Hide some settings, as they aren't useful for pure data output.
    unset($options['show_admin_links'], $options['analyze-theme']);
    $categories['path'] = [
      'title' => $this
        ->t('Path settings'),
      'column' => 'second',
      'build' => [
        '#weight' => -10,
      ],
    ];
    $options['path']['category'] = 'path';
    $options['path']['title'] = $this
      ->t('Path');
    $options['auth'] = [
      'category' => 'path',
      'title' => $this
        ->t('Authentication'),
      'value' => views_ui_truncate($auth, 24),
    ];
    // Remove css/exposed form settings, as they are not used for the data
    // display.
    unset($options['exposed_form']);
    unset($options['exposed_block']);
    unset($options['css_class']);
  }
  /**
   * {@inheritdoc}
   */
  public function buildOptionsForm(&$form, FormStateInterface $form_state) {
    parent::buildOptionsForm($form, $form_state);
    if ($form_state
      ->get('section') === 'auth') {
      $form['#title'] .= $this
        ->t('The supported authentication methods for this view');
      $form['auth'] = [
        '#type' => 'checkboxes',
        '#title' => $this
          ->t('Authentication methods'),
        '#description' => $this
          ->t('These are the supported authentication providers for this view. When this view is requested, the client will be forced to authenticate with one of the selected providers. Make sure you set the appropriate requirements at the <em>Access</em> section since the Authentication System will fallback to the anonymous user if it fails to authenticate. For example: require Access: Role | Authenticated User.'),
        '#options' => $this
          ->getAuthOptions(),
        '#default_value' => $this
          ->getOption('auth'),
      ];
    }
  }
  /**
   * {@inheritdoc}
   */
  public function submitOptionsForm(&$form, FormStateInterface $form_state) {
    parent::submitOptionsForm($form, $form_state);
    if ($form_state
      ->get('section') == 'auth') {
      $this
        ->setOption('auth', array_keys(array_filter($form_state
        ->getValue('auth'))));
    }
  }
  /**
   * {@inheritdoc}
   */
  public function collectRoutes(RouteCollection $collection) {
    parent::collectRoutes($collection);
    $view_id = $this->view->storage
      ->id();
    $display_id = $this->display['id'];
    if ($route = $collection
      ->get("view.{$view_id}.{$display_id}")) {
      $style_plugin = $this
        ->getPlugin('style');
      // REST exports should only respond to GET methods.
      $route
        ->setMethods([
        'GET',
      ]);
      $formats = $style_plugin
        ->getFormats();
      // If there are no configured formats, add all formats that serialization
      // is known to support.
      if (!$formats) {
        $formats = $this
          ->getFormatOptions();
      }
      // Format as a string using pipes as a delimiter.
      $route
        ->setRequirement('_format', implode('|', $formats));
      // Add authentication to the route if it was set. If no authentication was
      // set, the default authentication will be used, which is cookie based by
      // default.
      $auth = $this
        ->getOption('auth');
      if (!empty($auth)) {
        $route
          ->setOption('_auth', $auth);
      }
    }
  }
  /**
   * Determines whether the view overrides the given route.
   *
   * @param string $view_path
   *   The path of the view.
   * @param \Symfony\Component\Routing\Route $view_route
   *   The route of the view.
   * @param \Symfony\Component\Routing\Route $route
   *   The route itself.
   *
   * @return bool
   *   TRUE, when the view should override the given route.
   */
  protected function overrideApplies($view_path, Route $view_route, Route $route) {
    $route_formats = explode('|', $route
      ->getRequirement('_format'));
    $view_route_formats = explode('|', $view_route
      ->getRequirement('_format'));
    return $this
      ->overrideAppliesPathAndMethod($view_path, $view_route, $route) && (!$route
      ->hasRequirement('_format') || array_intersect($route_formats, $view_route_formats) != []);
  }
  /**
   * {@inheritdoc}
   */
  public static function buildResponse($view_id, $display_id, array $args = []) {
    $build = static::buildBasicRenderable($view_id, $display_id, $args);
    // Setup an empty response so headers can be added as needed during views
    // rendering and processing.
    $response = new CacheableResponse('', 200);
    $build['#response'] = $response;
    /** @var \Drupal\Core\Render\RendererInterface $renderer */
    $renderer = \Drupal::service('renderer');
    $output = (string) $renderer
      ->renderRoot($build);
    $response
      ->setContent($output);
    $cache_metadata = CacheableMetadata::createFromRenderArray($build);
    $response
      ->addCacheableDependency($cache_metadata);
    $response->headers
      ->set('Content-type', $build['#content_type']);
    return $response;
  }
  /**
   * {@inheritdoc}
   */
  public function execute() {
    parent::execute();
    return $this->view
      ->render();
  }
  /**
   * {@inheritdoc}
   */
  public function render() {
    $build = [];
    $build['#markup'] = $this->renderer
      ->executeInRenderContext(new RenderContext(), function () {
      return $this->view->style_plugin
        ->render();
    });
    $this->view->element['#content_type'] = $this
      ->getMimeType();
    $this->view->element['#cache_properties'][] = '#content_type';
    // Encode and wrap the output in a pre tag if this is for a live preview.
    if (!empty($this->view->live_preview)) {
      $build['#prefix'] = '<pre>';
      $build['#plain_text'] = $build['#markup'];
      $build['#suffix'] = '</pre>';
      unset($build['#markup']);
    }
    else {
      // This display plugin is for returning non-HTML formats. However, we
      // still invoke the renderer to collect cacheability metadata. Because the
      // renderer is designed for HTML rendering, it filters #markup for XSS
      // unless it is already known to be safe, but that filter only works for
      // HTML. Therefore, we mark the contents as safe to bypass the filter. So
      // long as we are returning this in a non-HTML response,
      // this is safe, because an XSS attack only works when executed by an HTML
      // agent.
      // @todo Decide how to support non-HTML in the render API in
      //   https://www.drupal.org/node/2501313.
      $build['#markup'] = ViewsRenderPipelineMarkup::create($build['#markup']);
    }
    parent::applyDisplayCacheabilityMetadata($build);
    return $build;
  }
  /**
   * {@inheritdoc}
   *
   * The DisplayPluginBase preview method assumes we will be returning a render
   * array. The data plugin will already return the serialized string.
   */
  public function preview() {
    return $this->view
      ->render();
  }
  /**
   * {@inheritdoc}
   */
  public function calculateDependencies() {
    $dependencies = parent::calculateDependencies();
    $dependencies += [
      'module' => [],
    ];
    $dependencies['module'] = array_merge($dependencies['module'], array_filter(array_map(function ($provider) {
      // During the update path the provider options might be wrong. This can
      // happen when any update function, like block_update_8300() triggers a
      // view to be saved.
      return isset($this->authenticationProviderIds[$provider]) ? $this->authenticationProviderIds[$provider] : NULL;
    }, $this
      ->getOption('auth'))));
    return $dependencies;
  }
  /**
   * Returns an array of format options.
   *
   * @return string[]
   *   An array of format options. Both key and value are the same.
   */
  protected function getFormatOptions() {
    $formats = array_keys($this->formatProviders);
    return array_combine($formats, $formats);
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| 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 | |
| DependencyTrait:: | protected | property | The object's dependencies. | |
| DependencyTrait:: | protected | function | Adds multiple dependencies. | |
| DependencyTrait:: | protected | function | Adds a dependency. | |
| DisplayPluginBase:: | public | property | The display information coming directly from the view entity. | |
| DisplayPluginBase:: | protected | property | Stores all available display extenders. | |
| DisplayPluginBase:: | public | property | An array of instantiated handlers used in this display. | |
| DisplayPluginBase:: | public | property | Stores the rendered output of the display. | |
| DisplayPluginBase:: | protected | property | An array of instantiated plugins used in this display. | |
| DisplayPluginBase:: | protected static | property | Static cache for unpackOptions, but not if we are in the UI. | |
| DisplayPluginBase:: | protected | property | Whether the display allows attachments. | 6 | 
| DisplayPluginBase:: | public | property | The top object of a view. Overrides PluginBase:: | |
| DisplayPluginBase:: | public | function | Determines whether this display can use attachments. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Determines if the user has access to this display of the view. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Whether the display is actually using AJAX or not. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | protected | function | Applies the cacheability of the current display to the given render array. | |
| DisplayPluginBase:: | protected | function | Applies the cacheability of the current display to the given render array. | |
| DisplayPluginBase:: | public | function | Allows displays to attach to other views. Overrides DisplayPluginInterface:: | 2 | 
| DisplayPluginBase:: | public static | function | Builds a basic render array which can be properly render cached. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Builds a renderable array of the view. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | protected | function | Returns the available rendering strategies for language-aware entities. | |
| DisplayPluginBase:: | public | function | Calculates the display's cache metadata by inspecting each handler/plugin. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Lists the 'defaultable' sections and what items each section contains. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Clears a plugin. Overrides PluginBase:: | |
| DisplayPluginBase:: | public | function | #pre_render callback for view display rendering. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | protected | function | Gets all the handlers used by the display. | |
| DisplayPluginBase:: | protected | function | Gets all the plugins used by the display. | |
| DisplayPluginBase:: | public | function | Returns to tokens for arguments. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Provides help text for the arguments. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Find out all displays which are attached to this display. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Gets the cache metadata. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Gets the display extenders. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Retrieves a list of fields for the current display. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Get the handler object for a single handler. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Get a full array of handlers for $type. This caches them. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Returns the ID of the display to use when making links. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | protected | function | Get the more URL for this view. | |
| DisplayPluginBase:: | public | function | Gets an option, from this display or the default display. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Provides help text for pagers. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Get the instance of a plugin, for example style or row. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Points to the display which can be linked by this display. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Provides the block system with any exposed widget blocks for this display. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Returns a URL to $this display or its configured linked display. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | protected | function | Returns whether the base table is of a translatable entity type. | |
| DisplayPluginBase:: | public | function | Determines if this display is the 'default' display. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Determines if an option is set to use the default or current display. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Whether the display is enabled. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Checks if the provided identifier is unique. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Whether the display is using the 'more' link or not. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Whether the display is using a pager or not. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Merges default values for all plugin types. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | protected | function | Merges handlers default values. | |
| DisplayPluginBase:: | protected | function | Merges plugins default values. | |
| DisplayPluginBase:: | public | function | Reacts on adding a display. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Returns a link to a section of a form. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | If override/revert was clicked, perform the proper toggle. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Is the output of the view empty. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Set an option and force it to be an override. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Sets up any variables on the view prior to execution. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Add anything to the query that we might need to. Overrides PluginBase:: | 1 | 
| DisplayPluginBase:: | public | function | Renders one of the available areas. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Does nothing (obsolete function). Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Renders the 'more' link. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Checks to see if the display plugins support pager rendering. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Sets an option, on this display or the default display. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Flip the override setting for the given section. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public static | function | Lists the trusted callbacks provided by the implementing class. Overrides PluginBase:: | |
| DisplayPluginBase:: | public | function | Does the display have groupby enabled? Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Should the enabled display more link be shown when no more items? Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Does the display have custom link text? Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Whether the display allows the use of AJAX or not. Overrides DisplayPluginInterface:: | 2 | 
| DisplayPluginBase:: | public | function | Returns whether the display can use areas. Overrides DisplayPluginInterface:: | 2 | 
| DisplayPluginBase:: | public | function | Returns whether the display can use attachments. Overrides DisplayPluginInterface:: | 6 | 
| DisplayPluginBase:: | public | function | Checks to see if the display can put the exposed form in a block. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Determines if the display's style uses fields. Overrides DisplayPluginInterface:: | |
| DisplayPluginBase:: | public | function | Checks to see if the display has some need to link to another display. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Whether the display allows the use of a 'more' link or not. Overrides DisplayPluginInterface:: | 1 | 
| DisplayPluginBase:: | public | function | Whether the display allows the use of a pager or not. Overrides DisplayPluginInterface:: | 4 | 
| DisplayPluginBase:: | public | function | Renders the exposed form as block. Overrides DisplayPluginInterface:: | |
| MessengerTrait:: | protected | property | The messenger. | 29 | 
| MessengerTrait:: | public | function | Gets the messenger. | 29 | 
| MessengerTrait:: | public | function | Sets the messenger. | |
| PathPluginBase:: | protected | property | The route provider. | |
| PathPluginBase:: | protected | property | The state key value store. | |
| PathPluginBase:: | public | function | Alters a collection of routes and replaces definitions to the view. Overrides DisplayRouterInterface:: | |
| PathPluginBase:: | public | function | Returns the list of routes overridden by Views. Overrides DisplayRouterInterface:: | |
| PathPluginBase:: | public | function | Gets menu links, if this display provides some. Overrides DisplayMenuInterface:: | |
| PathPluginBase:: | public | function | Returns the base path to use for this display. Overrides DisplayPluginBase:: | |
| PathPluginBase:: | protected | function | Generates a route entry for a given view and display. | 1 | 
| PathPluginBase:: | public | function | Returns the route name for the display. Overrides DisplayRouterInterface:: | |
| PathPluginBase:: | public | function | Generates a URL to this display. Overrides DisplayRouterInterface:: | |
| PathPluginBase:: | public | function | Checks to see if the display has a 'path' field. Overrides DisplayPluginBase:: | |
| PathPluginBase:: | protected | function | Determines if this display's path is a default tab. | |
| PathPluginBase:: | protected | function | Determines whether a override for the path and method should happen. | |
| PathPluginBase:: | public | function | Reacts on deleting a display. Overrides DisplayPluginBase:: | |
| PathPluginBase:: | public | function | Validate that the plugin is correct and can be saved. Overrides DisplayPluginBase:: | 1 | 
| PathPluginBase:: | public | function | Validate the options form. Overrides DisplayPluginBase:: | 1 | 
| PathPluginBase:: | protected | function | Validates the path of the display. | |
| 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. | 1 | 
| PluginBase:: | protected | property | The plugin_id. | |
| PluginBase:: | constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
| PluginBase:: | protected | function | Do the work to filter out stored options depending on the defined options. | |
| PluginBase:: | public | function | Filter out stored options depending on the defined options. Overrides ViewsPluginInterface:: | |
| PluginBase:: | public | function | Returns an array of available token replacements. Overrides ViewsPluginInterface:: | |
| PluginBase:: | public | function | Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: | 3 | 
| PluginBase:: | public | function | Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: | |
| PluginBase:: | public | function | Returns the plugin provider. Overrides ViewsPluginInterface:: | |
| PluginBase:: | protected | function | Returns the render API renderer. | 1 | 
| PluginBase:: | public | function | Adds elements for available core tokens to a form. Overrides ViewsPluginInterface:: | |
| PluginBase:: | public | function | Returns a string with any core tokens replaced. Overrides ViewsPluginInterface:: | |
| PluginBase:: | constant | Include entity row languages when listing languages. | ||
| PluginBase:: | constant | Include negotiated languages when listing languages. | ||
| PluginBase:: | public | function | Initialize the plugin. Overrides ViewsPluginInterface:: | 8 | 
| PluginBase:: | public | function | Determines if the plugin is configurable. | |
| PluginBase:: | protected | function | Makes an array of languages, optionally including special languages. | |
| PluginBase:: | public | function | Return the human readable name of the display. Overrides ViewsPluginInterface:: | |
| PluginBase:: | public static | function | Moves form elements into fieldsets for presentation purposes. Overrides ViewsPluginInterface:: | |
| PluginBase:: | public static | function | Flattens the structure of form elements. Overrides ViewsPluginInterface:: | |
| PluginBase:: | public static | function | Returns substitutions for Views queries for languages. | |
| PluginBase:: | protected | function | Fills up the options of the plugin with defaults. | |
| PluginBase:: | public | function | Returns the summary of the settings in the display. Overrides ViewsPluginInterface:: | 6 | 
| PluginBase:: | public | function | Provide a full list of possible theme templates used by this style. Overrides ViewsPluginInterface:: | 1 | 
| PluginBase:: | public | function | Unpack options over our existing defaults, drilling down into arrays
so that defaults don't get totally blown away. Overrides ViewsPluginInterface:: | |
| PluginBase:: | public | function | Returns the usesOptions property. Overrides ViewsPluginInterface:: | 8 | 
| PluginBase:: | protected | function | Replaces Views' tokens in a given string. The resulting string will be sanitized with Xss::filterAdmin. | 1 | 
| PluginBase:: | constant | Query string to indicate the site default language. | ||
| PluginDependencyTrait:: | protected | function | Calculates and adds dependencies of a specific plugin instance. | 1 | 
| PluginDependencyTrait:: | protected | function | Calculates and returns dependencies of a specific plugin instance. | |
| PluginDependencyTrait:: | protected | function | Wraps the module handler. | 1 | 
| PluginDependencyTrait:: | protected | function | Wraps the theme handler. | 1 | 
| RestExport:: | protected | property | The collector of authentication providers. | |
| RestExport:: | protected | property | The authentication providers, like 'cookie' and 'basic_auth'. | |
| RestExport:: | protected | property | The authentication providers' modules, keyed by provider ID. | |
| RestExport:: | protected | property | Overrides the content type of the data response, if needed. | |
| RestExport:: | protected | property | The serialization format providers, keyed by format. | |
| RestExport:: | protected | property | The mime type for the response. | |
| RestExport:: | protected | property | The renderer. Overrides PluginBase:: | |
| RestExport:: | protected | property | Whether the display allows the use of AJAX or not. Overrides DisplayPluginBase:: | |
| RestExport:: | protected | property | Whether the display allows area plugins. Overrides DisplayPluginBase:: | |
| RestExport:: | protected | property | Whether the display allows the use of a 'more' link or not. Overrides DisplayPluginBase:: | |
| RestExport:: | protected | property | Denotes whether the plugin has an additional options form. Overrides DisplayPluginBase:: | |
| RestExport:: | protected | property | Whether the display allows the use of a pager or not. Overrides DisplayPluginBase:: | |
| RestExport:: | public | function | Provide a form to edit options for this plugin. Overrides PathPluginBase:: | |
| RestExport:: | public static | function | Builds up a response with the rendered view as content. Overrides ResponseDisplayPluginInterface:: | |
| RestExport:: | public | function | Calculates dependencies for the configured plugin. Overrides DisplayPluginBase:: | |
| RestExport:: | public | function | Adds the route entry of a view to the collection. Overrides PathPluginBase:: | |
| RestExport:: | public static | function | Creates an instance of the plugin. Overrides PathPluginBase:: | |
| RestExport:: | protected | function | Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase:defineOptions(). Overrides PathPluginBase:: | |
| RestExport:: | public | function | Determines if this display should display the exposed filters widgets. Overrides DisplayPluginBase:: | |
| RestExport:: | public | function | Executes the view and returns data in the format required. Overrides PathPluginBase:: | |
| RestExport:: | public | function | Gets the auth options available. | |
| RestExport:: | public | function | Gets the content type. | |
| RestExport:: | protected | function | Returns an array of format options. | |
| RestExport:: | public | function | Gets the mime type. | |
| RestExport:: | public | function | Returns the display type that this display requires. Overrides DisplayPluginBase:: | |
| RestExport:: | public | function | Initializes the display plugin. Overrides DisplayPluginBase:: | |
| RestExport:: | public | function | Provides the default summary for options in the views UI. Overrides PathPluginBase:: | |
| RestExport:: | protected | function | Determines whether the view overrides the given route. Overrides PathPluginBase:: | |
| RestExport:: | public | function | The DisplayPluginBase preview method assumes we will be returning a render
array. The data plugin will already return the serialized string. Overrides DisplayPluginBase:: | |
| RestExport:: | public | function | Renders this display. Overrides DisplayPluginBase:: | |
| RestExport:: | public | function | Sets the content type. | |
| RestExport:: | public | function | Sets the request content type. | |
| RestExport:: | public | function | Handle any special handling on the validate form. Overrides PathPluginBase:: | |
| RestExport:: | public | function | Determines if this display uses exposed filters. Overrides DisplayPluginBase:: | |
| RestExport:: | public | function | Constructs a RestExport object. Overrides PathPluginBase:: | |
| 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. | |
| TrustedCallbackInterface:: | constant | Untrusted callbacks throw exceptions. | ||
| TrustedCallbackInterface:: | constant | Untrusted callbacks trigger silenced E_USER_DEPRECATION errors. | ||
| TrustedCallbackInterface:: | constant | Untrusted callbacks trigger E_USER_WARNING errors. | ||
| UrlGeneratorTrait:: | protected | property | The url generator. | |
| UrlGeneratorTrait:: | protected | function | Returns the URL generator service. | |
| UrlGeneratorTrait:: | protected | function | Returns a redirect response object for the specified route. | 3 | 
| UrlGeneratorTrait:: | public | function | Sets the URL generator service. | |
| UrlGeneratorTrait:: | protected | function | Generates a URL or path for a specific route based on the given parameters. | 
