AccessTokenAccessControlHandler.php in Simple OAuth (OAuth2) & OpenID Connect 8.2        
                          
                  
                        
  
  
  
  
File
  src/AccessTokenAccessControlHandler.php
  
    View source  
  <?php
namespace Drupal\simple_oauth;
use Drupal\Core\Entity\EntityAccessControlHandler;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\Core\Access\AccessResult;
class AccessTokenAccessControlHandler extends EntityAccessControlHandler {
  
  protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) {
    if ($admin_permission = $this->entityType
      ->getAdminPermission()) {
      return AccessResult::allowedIfHasPermission($account, $admin_permission);
    }
    
    $is_owner = $account
      ->id() == $entity
      ->get('auth_user_id')->target_id;
    $is_owner_access = AccessResult::allowedIf($is_owner)
      ->addCacheableDependency($entity);
    if (!in_array($operation, [
      'view',
      'update',
      'delete',
    ])) {
      return AccessResult::neutral();
    }
    return $is_owner_access
      ->andIf(AccessResult::allowedIfHasPermission($account, sprintf('%s own simple_oauth entities', $operation)));
  }
  
  protected function checkCreateAccess(AccountInterface $account, array $context, $entity_bundle = NULL) {
    return AccessResult::allowedIfHasPermission($account, 'add access token entities');
  }
}