src/Security/ChannelSettingVoter.php line 19

Open in your IDE?
  1. <?php
  2. /**
  3.  * @license SILK SOFTWARE HOUSE SP Z O O
  4.  */
  5. namespace App\Security;
  6. use App\Entity\ChannelSetting;
  7. use App\Entity\Customer;
  8. use App\Entity\License;
  9. use App\Entity\Measurement;
  10. use App\Entity\User;
  11. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  12. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  13. /**
  14.  * Class ChannelSettingVoter.
  15.  */
  16. class ChannelSettingVoter extends Voter
  17. {
  18.     const EDIT 'edit';
  19.     const DELETE 'delete';
  20.     /**
  21.      * Supports.
  22.      *
  23.      * @param string  $attribute
  24.      * @param License $subject
  25.      *
  26.      * @return bool
  27.      */
  28.     protected function supports($attribute$subject)
  29.     {
  30.         // if the attribute isn't one we support, return false
  31.         if (!in_array($attribute, [self::DELETEself::EDIT])) {
  32.             return false;
  33.         }
  34.         if (!$subject instanceof ChannelSetting) {
  35.             return false;
  36.         }
  37.         return true;
  38.     }
  39.     /**
  40.      * Vote on attribute.
  41.      *
  42.      * @param string         $attribute
  43.      * @param ChannelSetting $subject
  44.      * @param TokenInterface $token
  45.      *
  46.      * @return bool
  47.      */
  48.     protected function voteOnAttribute($attribute$subjectTokenInterface $token)
  49.     {
  50.         $user $token->getUser();
  51.         if (!$user instanceof User) {
  52.             // the user must be logged in; if not, deny access
  53.             return false;
  54.         }
  55.         if ($user->hasRole('ROLE_ADMIN')) {
  56.             return true;
  57.         }
  58.         if (!$subject->getChannel()) {
  59.             return true;
  60.         }
  61.         return $user->getActiveCustomer()
  62.             && $user->getActiveCustomer()->getId() === $subject->getChannel()->getMeasurement()->getCustomer()->getId();
  63.     }
  64. }