class AliasGet in Services 8.4
Same name in this branch
- 8.4 src/Plugin/Deriver/AliasGet.php \Drupal\services\Plugin\Deriver\AliasGet
- 8.4 src/Plugin/ServiceDefinition/AliasGet.php \Drupal\services\Plugin\ServiceDefinition\AliasGet
Same name and namespace in other branches
- 9.0.x src/Plugin/ServiceDefinition/AliasGet.php \Drupal\services\Plugin\ServiceDefinition\AliasGet
Plugin annotation
@ServiceDefinition(
id = "alias_get",
methods = {
"GET"
},
translatable = true,
deriver = "\Drupal\services\Plugin\Deriver\AliasGet"
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Component\Plugin\ContextAwarePluginBase implements ContextAwarePluginInterface
- class \Drupal\Core\Plugin\ContextAwarePluginBase implements CacheableDependencyInterface, ContextAwarePluginInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\services\ServiceDefinitionBase implements ServiceDefinitionInterface
- class \Drupal\services\Plugin\ServiceDefinition\AliasGet implements ContainerFactoryPluginInterface
- class \Drupal\services\ServiceDefinitionBase implements ServiceDefinitionInterface
- class \Drupal\Core\Plugin\ContextAwarePluginBase implements CacheableDependencyInterface, ContextAwarePluginInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Component\Plugin\ContextAwarePluginBase implements ContextAwarePluginInterface
Expanded class hierarchy of AliasGet
File
- src/
Plugin/ ServiceDefinition/ AliasGet.php, line 27
Namespace
Drupal\services\Plugin\ServiceDefinitionView source
class AliasGet extends ServiceDefinitionBase implements ContainerFactoryPluginInterface {
/**
* @var Drupal\path_alias\AliasManagerInterface
*/
protected $aliasManager;
protected $entity;
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container
->get('path.alias_manager'));
}
/**
* @param array $configuration
* @param string $plugin_id
* @param mixed $plugin_definition
* @param Drupal\path_alias\AliasManagerInterface $alias_manager
*/
public function __construct(array $configuration, $plugin_id, $plugin_definition, AliasManagerInterface $alias_manager) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->aliasManager = $alias_manager;
}
/**
* {@inheritdoc}
*/
public function processRequest(Request $request, RouteMatchInterface $route_match, SerializerInterface $serializer) {
// The query string parameter 'path' must exist in order to load the
// node that correlates to path value provided.
if (!$request->query
->has('path')) {
throw new HttpException(404);
}
$this
->buildResponseObject($request);
return $this->entity
->toArray();
}
/**
* Builds the response object to be returned. This will be a node.
*
* @param $request
*
* @return \Symfony\Component\HttpFoundation\Response
*/
public function buildResponseObject($request) {
$alias = $request->query
->get('path');
$path = $this->aliasManager
->getPathByAlias($alias);
// If $path does not contain /node/ it's a result of no alias existing
// for any nodes in Drupal.
if (!strstr('/node/', $path)) {
throw new HttpException(404);
}
$parts = explode('/', $path);
$this->entity = Node::load($parts[2]);
return TRUE;
}
/**
* {@inheritdoc}
*/
public function getCacheContexts() {
// @todo Change the autogenerated stub.
return parent::getCacheContexts();
}
/**
*
*/
public function getCacheTags() {
$tags = [];
// Applied contexts can affect the cache tags when this plugin is
// involved in caching, collect and return them.
if ($this->entity instanceof CacheableDependencyInterface) {
$tags = Cache::mergeTags($tags, $this->entity
->getCacheTags());
}
/** @var \Drupal\Core\Cache\CacheableDependencyInterface $context */
return $tags;
}
/**
* {@inheritdoc}
*/
public function getCacheMaxAge() {
// @todo Change the autogenerated stub.
return parent::getCacheMaxAge();
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
AliasGet:: |
protected | property | ||
AliasGet:: |
protected | property | ||
AliasGet:: |
public | function | Builds the response object to be returned. This will be a node. | |
AliasGet:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
AliasGet:: |
public | function |
The cache contexts associated with this object. Overrides ContextAwarePluginBase:: |
|
AliasGet:: |
public | function |
The maximum age for which this object may be cached. Overrides ContextAwarePluginBase:: |
|
AliasGet:: |
public | function |
The cache tags associated with this object. Overrides ContextAwarePluginBase:: |
|
AliasGet:: |
public | function |
Processes the request and returns an array of data as appropriate. Overrides ServiceDefinitionInterface:: |
|
AliasGet:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
protected | property | The data objects representing the context of this plugin. | |
ContextAwarePluginBase:: |
private | property | Data objects representing the contexts passed in the plugin configuration. | |
ContextAwarePluginBase:: |
protected | function | Wraps the context handler. | |
ContextAwarePluginBase:: |
protected | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
This code is identical to the Component in order to pick up a different
Context class. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Gets a mapping of the expected assignment names to their context names. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the value for a defined context. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the values for all defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Set a context on this plugin. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Sets a mapping of the expected assignment names to their context names. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Sets the value for a defined context. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Validates the set values for the defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function | Implements magic __get() method. | |
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 | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
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:: |
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 | Determines if the plugin is configurable. | |
ServiceDefinitionBase:: |
public | function |
Returns an array of service request arguments. Overrides ServiceDefinitionInterface:: |
|
ServiceDefinitionBase:: |
public | function |
Returns a translated string for the category. Overrides ServiceDefinitionInterface:: |
|
ServiceDefinitionBase:: |
public | function |
Returns a translated description for the constraint description. Overrides ServiceDefinitionInterface:: |
|
ServiceDefinitionBase:: |
public | function |
Return an array of allowed methods. Overrides ServiceDefinitionInterface:: |
|
ServiceDefinitionBase:: |
public | function |
Returns the appended path for the service. Overrides ServiceDefinitionInterface:: |
|
ServiceDefinitionBase:: |
public | function |
Returns a translated string for the service title. Overrides ServiceDefinitionInterface:: |
|
ServiceDefinitionBase:: |
public | function |
Allow plugins to alter the response object before it is returned. Overrides ServiceDefinitionInterface:: |
|
ServiceDefinitionBase:: |
public | function |
Checks access for the ServiceDefintion. Overrides ServiceDefinitionInterface:: |
7 |
ServiceDefinitionBase:: |
public | function |
Returns a boolean if this service definition supports translations. Overrides ServiceDefinitionInterface:: |
|
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. | |
TypedDataTrait:: |
protected | property | The typed data manager used for creating the data types. | |
TypedDataTrait:: |
public | function | Gets the typed data manager. | 2 |
TypedDataTrait:: |
public | function | Sets the typed data manager. | 2 |