public function EntityReplicate::access in Replicate UI 8
Checks object access.
Parameters
mixed $object: The object to execute the action on.
\Drupal\Core\Session\AccountInterface $account: (optional) The user for which to check access, or NULL to check access for the current user. Defaults to NULL.
bool $return_as_object: (optional) Defaults to FALSE.
Return value
bool|\Drupal\Core\Access\AccessResultInterface The access result. Returns a boolean if $return_as_object is FALSE (this is the default) and otherwise an AccessResultInterface object. When a boolean is returned, the result of AccessInterface::isAllowed() is returned, i.e. TRUE means access is explicitly allowed, FALSE means access is either explicitly forbidden or "no opinion".
Overrides ActionInterface::access
File
- src/
Plugin/ Action/ EntityReplicate.php, line 36
Class
- EntityReplicate
- Redirects to a node deletion form.
Namespace
Drupal\replicate_ui\Plugin\ActionCode
public function access($object, AccountInterface $account = NULL, $return_as_object = FALSE) {
/** @var \Drupal\replicate_ui\ReplicateAccessChecker $access_check */
$access_check = \Drupal::service('replicate_ui.access_check');
$entity_type_id = $this
->getPluginDefinition()['type'];
$route = new Route($entity_type_id, [
'_entity_form' => "{$entity_type_id}.replicate",
'entity_type_id' => $entity_type_id,
], [
'_replicate_access' => 'TRUE',
], [
'parameters' => [
$entity_type_id => [
'type' => 'entity:' . $entity_type_id,
],
],
]);
$route_match = new RouteMatch("entity.{$entity_type_id}.replicate", $route, [
$entity_type_id => $object,
], [
$entity_type_id => $object
->id(),
]);
/** @var \Drupal\Core\Access\AccessResultInterface $result */
$result = $access_check
->access($route, $route_match, $account);
return $return_as_object ? $result : $result
->isAllowed();
}