Issue #1972990 by pwolanin, Dean Reilly, dawehner, Jberges, dokumori, AjitS, tim.plunkett: Convert tracker_page() to a Controller.

8.0.x
webchick 2013-10-06 21:33:22 -07:00
parent 1f6bbe94fd
commit 4020361ecb
11 changed files with 230 additions and 77 deletions

View File

@ -7,16 +7,13 @@
namespace Drupal\Core\Menu;
use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
use Drupal\Core\Plugin\PluginBase;
use Drupal\Core\Routing\RouteProviderInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\HttpFoundation\Request;
/**
* Default object used for LocalTaskPlugins.
*/
class LocalTaskDefault extends PluginBase implements LocalTaskInterface, ContainerFactoryPluginInterface {
class LocalTaskDefault extends PluginBase implements LocalTaskInterface {
/**
* The route provider to load routes by name.
@ -32,35 +29,6 @@ class LocalTaskDefault extends PluginBase implements LocalTaskInterface, Contain
*/
protected $active = FALSE;
/**
* Constructs a \Drupal\system\Plugin\LocalTaskDefault 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 array $plugin_definition
* The plugin implementation definition.
* @param \Drupal\Core\Routing\RouteProviderInterface $route_provider
* The route provider.
*/
public function __construct(array $configuration, $plugin_id, array $plugin_definition, RouteProviderInterface $route_provider) {
$this->routeProvider = $route_provider;
parent::__construct($configuration, $plugin_id, $plugin_definition);
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, array $plugin_definition) {
return new static(
$configuration,
$plugin_id,
$plugin_definition,
$container->get('router.route_provider')
);
}
/**
* {@inheritdoc}
*/
@ -73,7 +41,7 @@ class LocalTaskDefault extends PluginBase implements LocalTaskInterface, Contain
*/
public function getRouteParameters(Request $request) {
$parameters = isset($this->pluginDefinition['route_parameters']) ? $this->pluginDefinition['route_parameters'] : array();
$route = $this->routeProvider->getRouteByName($this->getRouteName());
$route = $this->routeProvider()->getRouteByName($this->getRouteName());
$variables = $route->compile()->getVariables();
// Normally the \Drupal\Core\ParamConverter\ParamConverterManager has
@ -158,4 +126,17 @@ class LocalTaskDefault extends PluginBase implements LocalTaskInterface, Contain
return $this->active;
}
/**
* Returns the route provider.
*
* @return \Drupal\Core\Routing\RouteProviderInterface
* The route provider.
*/
protected function routeProvider() {
if (!$this->routeProvider) {
$this->routeProvider = \Drupal::service('router.route_provider');
}
return $this->routeProvider;
}
}

View File

@ -0,0 +1,38 @@
<?php
/**
* @file
* Contains Drupal\tracker\Access\ViewOwnTrackerAccessCheck.
*/
namespace Drupal\tracker\Access;
use Drupal\Core\Access\StaticAccessCheckInterface;
use Symfony\Component\Routing\Route;
use Symfony\Component\HttpFoundation\Request;
/**
* Access check for user tracker routes.
*/
class ViewOwnTrackerAccessCheck implements StaticAccessCheckInterface {
/**
* {@inheritdoc}
*/
public function appliesTo() {
return array('_access_tracker_own_information');
}
/**
* {@inheritdoc}
*/
public function access(Route $route, Request $request) {
// The user object from the User ID in the path.
$user = $request->attributes->get('user');
// @todo - $account should be passed in.
// The \Drupal\Core\Session\AccountInterface $account trying to access this.
$account = \Drupal::currentUser();
return $user && $account->isAuthenticated() && ($user->id() == $account->id());
}
}

View File

@ -0,0 +1,24 @@
<?php
/**
* @file
* Contains \Drupal\tracker\Controller\TrackerPage.
*/
namespace Drupal\tracker\Controller;
use Drupal\Core\Controller\ControllerBase;
/**
* Controller for tracker.page route.
*/
class TrackerPage extends ControllerBase {
/**
* Content callback for the tracker.page route.
*/
public function getContent() {
module_load_include('inc', 'tracker', 'tracker.pages');
return tracker_page();
}
}

View File

@ -0,0 +1,25 @@
<?php
/**
* @file
* Contains \Drupal\tracker\Controller\TrackerUserRecent.
*/
namespace Drupal\tracker\Controller;
use Drupal\Core\Controller\ControllerBase;
use Drupal\user\UserInterface;
/**
* Controller for tracker.users_recent_content route.
*/
class TrackerUserRecent extends ControllerBase {
/**
* Content callback for the tracker.users_recent_content route.
*/
public function getContent(UserInterface $user) {
module_load_include('inc', 'tracker', 'tracker.pages');
return tracker_page($user);
}
}

View File

@ -0,0 +1,33 @@
<?php
/**
* @file
* Contains \Drupal\tracker\Controller\TrackerUserTab.
*/
namespace Drupal\tracker\Controller;
use Drupal\Core\Controller\ControllerBase;
use Drupal\user\UserInterface;
use Drupal\Component\Utility\String;
/**
* Controller for tracker.user_tab route.
*/
class TrackerUserTab extends ControllerBase {
/**
* Content callback for the tracker.user_tab route.
*/
public function getContent(UserInterface $user) {
module_load_include('inc', 'tracker', 'tracker.pages');
return tracker_page($user);
}
/**
* Title callback for the tracker.user_tab route.
*/
public function getTitle(UserInterface $user) {
return String::checkPlain(user_format_name($user));
}
}

View File

@ -0,0 +1,48 @@
<?php
/**
* @file
* Contains \Drupal\tracker\Plugin\Menu\UserTrackerTab.
*/
namespace Drupal\tracker\Plugin\Menu;
use Drupal\Core\Menu\LocalTaskDefault;
use Symfony\Component\HttpFoundation\Request;
/**
* Provides route parameters needed to link to the current user tracker tab.
*/
class UserTrackerTab extends LocalTaskDefault {
/**
* Current user object.
*
* @var \Drupal\Core\Session\AccountInterface
*/
protected $currentUser;
/**
* Gets the current active user.
*
* @todo: https://drupal.org/node/2105123 put this method in
* \Drupal\Core\Plugin\PluginBase instead.
*
* @return \Drupal\Core\Session\AccountInterface
*/
protected function currentUser() {
if (!$this->currentUser) {
$this->currentUser = \Drupal::currentUser();
}
return $this->currentUser;
}
/**
* {@inheritdoc}
*/
public function getRouteParameters(Request $request) {
return array('user' => $this->currentUser()->Id());
}
}

View File

@ -0,0 +1,10 @@
tracker.page_tab:
route_name: tracker.page
title: 'Recent content'
tab_root_id: tracker.page_tab
tracker.users_recent_tab:
route_name: tracker.users_recent_content
title: 'My recent content'
tab_root_id: tracker.page_tab
class: '\Drupal\tracker\Plugin\Menu\UserTrackerTab'

View File

@ -30,48 +30,6 @@ function tracker_help($path, $arg) {
}
}
/**
* Implements hook_menu().
*/
function tracker_menu() {
$items['tracker'] = array(
'title' => 'Recent content',
'page callback' => 'tracker_page',
'access arguments' => array('access content'),
'weight' => 1,
'file' => 'tracker.pages.inc',
);
$items['tracker/all'] = array(
'title' => 'All recent content',
'type' => MENU_DEFAULT_LOCAL_TASK,
);
$items['tracker/%user_uid_optional'] = array(
'title' => 'My recent content',
'page callback' => 'tracker_page',
'access callback' => '_tracker_myrecent_access',
'access arguments' => array(1),
'page arguments' => array(1),
'type' => MENU_LOCAL_TASK,
'file' => 'tracker.pages.inc',
);
$items['user/%user/track'] = array(
'title' => 'Track',
'page callback' => 'tracker_page',
'page arguments' => array(1, TRUE),
'access callback' => '_tracker_user_access',
'access arguments' => array(1),
'type' => MENU_LOCAL_TASK,
'file' => 'tracker.pages.inc',
);
$items['user/%user/track/content'] = array(
'title' => 'Track content',
'type' => MENU_DEFAULT_LOCAL_TASK,
);
return $items;
}
/**
* Implements hook_cron().
*

View File

@ -0,0 +1,30 @@
tracker.page:
path: '/tracker'
defaults:
_content: '\Drupal\tracker\Controller\TrackerPage::getContent'
_title: 'Recent content'
requirements:
_permission: 'access content'
tracker.users_recent_content:
path: '/tracker/{user}'
defaults:
_content: '\Drupal\tracker\Controller\TrackerUserRecent::getContent'
_title: 'My recent content'
options:
_access_mode: 'ALL'
requirements:
_permission: 'access content'
_access_tracker_own_information: 'TRUE'
tracker.user_tab:
path: '/user/{user}/track'
defaults:
_content: '\Drupal\tracker\Controller\TrackerUserTab::getContent'
_title_callback: '\Drupal\tracker\Controller\TrackerUserTab::getTitle'
options:
_access_mode: 'ALL'
requirements:
_permission: 'access content'
_entity_access: 'user.view'

View File

@ -0,0 +1,5 @@
services:
access_check.tracker.view_own:
class: Drupal\tracker\Access\ViewOwnTrackerAccessCheck
tags:
- { name: access_check }

View File

@ -86,8 +86,9 @@ class LocalTaskDefaultTest extends UnitTestCase {
protected function setupLocalTaskDefault() {
$container = new ContainerBuilder();
$container->set('string_translation', $this->stringTranslation);
$container->set('router.route_provider', $this->routeProvider);
\Drupal::setContainer($container);
$this->localTaskBase = new LocalTaskDefault($this->config, $this->pluginId, $this->pluginDefinition, $this->routeProvider);
$this->localTaskBase = new LocalTaskDefault($this->config, $this->pluginId, $this->pluginDefinition);
}
/**