public ContentTranslationManageAccessCheck::access(Route $route, RouteMatchInterface $route_match, AccountInterface $account, $source = NULL, $target = NULL, $language = NULL, $entity_type_id = NULL)
Checks translation access for the entity and operation on the given route.
Parameters
\Symfony\Component\Routing\Route $route: The route to check against.
\Drupal\Core\Routing\RouteMatchInterface $route_match: The parametrized route.
\Drupal\Core\Session\AccountInterface $account: The currently logged in account.
string $source: (optional) For a create operation, the language code of the source.
string $target: (optional) For a create operation, the language code of the translation.
string $language: (optional) For an update or delete operation, the language code of the translation being updated or deleted.
string $entity_type_id: (optional) The entity type ID.
Return value
\Drupal\Core\Access\AccessResultInterface The access result.
File
- core/modules/content_translation/src/Access/ContentTranslationManageAccessCheck.php, line 68
Class
- ContentTranslationManageAccessCheck
- Access check for entity translation CRUD operation.
Namespace
Drupal\content_translation\Access
Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | public function access(Route $route , RouteMatchInterface $route_match , AccountInterface $account , $source = NULL, $target = NULL, $language = NULL, $entity_type_id = NULL) { /* @var \Drupal\Core\Entity\ContentEntityInterface $entity */ if ( $entity = $route_match ->getParameter( $entity_type_id )) { $operation = $route ->getRequirement( '_access_content_translation_manage' ); $language = $this ->languageManager->getLanguage( $language ) ? : $this ->languageManager->getCurrentLanguage(LanguageInterface::TYPE_CONTENT); $entity_type = $this ->entityManager->getDefinition( $entity_type_id ); if (in_array( $operation , [ 'update' , 'delete' ])) { // Translation operations cannot be performed on the default // translation. if ( $language ->getId() == $entity ->getUntranslated()->language()->getId()) { return AccessResult::forbidden()->addCacheableDependency( $entity ); } // Editors have no access to the translation operations, as entity // access already grants them an equal or greater access level. $templates = [ 'update' => 'edit-form' , 'delete' => 'delete-form' ]; if ( $entity ->access( $operation ) && $entity_type ->hasLinkTemplate( $templates [ $operation ])) { return AccessResult::forbidden()->cachePerPermissions(); } } if ( $account ->hasPermission( 'translate any entity' )) { return AccessResult::allowed()->cachePerPermissions(); } /* @var \Drupal\content_translation\ContentTranslationHandlerInterface $handler */ $handler = $this ->entityManager->getHandler( $entity ->getEntityTypeId(), 'translation' ); // Load translation. $translations = $entity ->getTranslationLanguages(); $languages = $this ->languageManager->getLanguages(); switch ( $operation ) { case 'create' : $source_language = $this ->languageManager->getLanguage( $source ) ? : $entity ->language(); $target_language = $this ->languageManager->getLanguage( $target ) ? : $this ->languageManager->getCurrentLanguage(LanguageInterface::TYPE_CONTENT); $is_new_translation = ( $source_language ->getId() != $target_language ->getId() && isset( $languages [ $source_language ->getId()]) && isset( $languages [ $target_language ->getId()]) && !isset( $translations [ $target_language ->getId()])); return AccessResult::allowedIf( $is_new_translation )->cachePerPermissions()->addCacheableDependency( $entity ) ->andIf( $handler ->getTranslationAccess( $entity , $operation )); case 'delete' : case 'update' : $has_translation = isset( $languages [ $language ->getId()]) && $language ->getId() != $entity ->getUntranslated()->language()->getId() && isset( $translations [ $language ->getId()]); return AccessResult::allowedIf( $has_translation )->cachePerPermissions()->addCacheableDependency( $entity ) ->andIf( $handler ->getTranslationAccess( $entity , $operation )); } } // No opinion. return AccessResult::neutral(); } |
Please login to continue.