RevisionLink.php 2.16 KB
Newer Older
1 2 3 4
<?php

/**
 * @file
5
 * Definition of Drupal\node\Plugin\views\field\RevisionLink.
6 7
 */

8
namespace Drupal\node\Plugin\views\field;
9

10
use Drupal\node\Plugin\views\field\Link;
11
use Drupal\views\Plugin\views\display\DisplayPluginBase;
12
use Drupal\views\ViewExecutable;
13
use Drupal\Component\Annotation\PluginID;
14

15 16 17 18
/**
 * Field handler to present a link to a node revision.
 *
 * @ingroup views_field_handlers
19
 *
20
 * @PluginID("node_revision_link")
21 22
 */
class RevisionLink extends Link {
23

24
  /**
25
   * Overrides Drupal\views\Plugin\views\field\FieldPluginBase::init().
26
   */
27 28
  public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) {
    parent::init($view, $display, $options);
29

30
    $this->additional_fields['node_vid'] = array('table' => 'node_field_revision', 'field' => 'vid');
31 32
  }

33
  public function access() {
34 35 36 37 38 39 40 41 42 43 44
    return user_access('view revisions') || user_access('administer nodes');
  }

  function render_link($data, $values) {
    list($node, $vid) = $this->get_revision_entity($values, 'view');
    if (!isset($vid)) {
      return;
    }

    // Current revision uses the node view path.
    $path = 'node/' . $node->nid;
45
    if (!$node->isDefaultRevision()) {
46 47 48 49 50 51 52
      $path .= "/revisions/$vid/view";
    }

    $this->options['alter']['make_link'] = TRUE;
    $this->options['alter']['path'] = $path;
    $this->options['alter']['query'] = drupal_get_destination();

53
    return !empty($this->options['text']) ? $this->options['text'] : t('View');
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
  }

  /**
   * Returns the revision values of a node.
   *
   * @param object $values
   *   An object containing all retrieved values.
   * @param string $op
   *   The operation being performed.
   *
   * @return array
   *   A numerically indexed array containing the current node object and the
   *   revision ID for this row.
   */
  function get_revision_entity($values, $op) {
69
    $vid = $this->getValue($values, 'node_vid');
70
    $node = $this->getEntity($values);
71 72 73 74 75 76 77 78
    // Unpublished nodes ignore access control.
    $node->status = 1;
    // Ensure user has access to perform the operation on this node.
    if (!node_access($op, $node)) {
      return array($node, NULL);
    }
    return array($node, $vid);
  }
79

80
}