aboutsummaryrefslogblamecommitdiffhomepage
path: root/src/Wallabag/ApiBundle/Controller/WallabagRestController.php
blob: e927a8903a26af16f796fa8016e6dad7322d5b5a (plain) (tree)
1
2
3
4
5
6
7
8
9

     
                                        
 
                                                
                                                                    
                                     
 
                                                      
 
                                               
     
                                                                                                          



                                              
       
                                                             
                                                                                             
      
                                                                  
       
                                                         
     
                                                                            

                                                                                                                                             

         
 
<?php

namespace Wallabag\ApiBundle\Controller;

use FOS\RestBundle\Controller\FOSRestController;
use Symfony\Component\Security\Core\Exception\AccessDeniedException;
use Wallabag\CoreBundle\Entity\Entry;

class WallabagRestController extends FOSRestController
{
    protected function validateAuthentication()
    {
        if (false === $this->get('security.authorization_checker')->isGranted('IS_AUTHENTICATED_FULLY')) {
            throw new AccessDeniedException();
        }
    }

    /**
     * Validate that the first id is equal to the second one.
     * If not, throw exception. It means a user try to access information from an other user.
     *
     * @param int $requestUserId User id from the requested source
     */
    protected function validateUserAccess($requestUserId)
    {
        $user = $this->get('security.token_storage')->getToken()->getUser();
        if ($requestUserId != $user->getId()) {
            throw $this->createAccessDeniedException('Access forbidden. Entry user id: '.$requestUserId.', logged user id: '.$user->getId());
        }
    }
}