mirror of
				https://github.com/alchemy-fr/Phraseanet.git
				synced 2025-10-26 11:23:13 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			106 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /*
 | |
|  * This file is part of Phraseanet
 | |
|  *
 | |
|  * (c) 2005-2016 Alchemy
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| namespace Alchemy\Phrasea\Controller;
 | |
| 
 | |
| use Alchemy\Phrasea\Application;
 | |
| use Alchemy\Phrasea\Authorization\AuthorizationChecker;
 | |
| use Alchemy\Phrasea\Model\Entities\User;
 | |
| use Symfony\Component\Form\FormBuilderInterface;
 | |
| use Symfony\Component\Form\FormInterface;
 | |
| use Symfony\Component\HttpFoundation\Response;
 | |
| use Symfony\Component\HttpFoundation\StreamedResponse;
 | |
| 
 | |
| abstract class BaseController
 | |
| {
 | |
|     /** @var Application */
 | |
|     protected $app;
 | |
| 
 | |
|     public function __construct(Application $app)
 | |
|     {
 | |
|         $this->app = $app;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @return User
 | |
|      */
 | |
|     public function getAuthenticatedUser()
 | |
|     {
 | |
|         return $this->app['authentication']->getUser();
 | |
|     }
 | |
| 
 | |
|     public function render($view, array $parameters = [], Response $response = null)
 | |
|     {
 | |
|         /** @var \Twig_Environment $twig */
 | |
|         $twig = $this->app['twig'];
 | |
| 
 | |
|         if ($response instanceof StreamedResponse) {
 | |
|             $response->setCallback(function () use ($twig, $view, $parameters) {
 | |
|                 $twig->display($view, $parameters);
 | |
|             });
 | |
| 
 | |
|             return $response;
 | |
|         }
 | |
| 
 | |
|         if (null === $response) {
 | |
|             $response = new Response();
 | |
|         }
 | |
|         $response->setContent($twig->render($view, $parameters));
 | |
| 
 | |
|         return $response;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param string $method
 | |
|      * @param mixed  $formType
 | |
|      * @param array  $options
 | |
|      * @param mixed  $data
 | |
|      * @return FormInterface
 | |
|      */
 | |
|     public function createApiForm($method = 'POST', $formType = 'form', array $options = [], $data = null)
 | |
|     {
 | |
|         return $this->app['form.factory']->createNamed(
 | |
|             'data',
 | |
|             $formType,
 | |
|             $data,
 | |
|             array_merge(['method' => $method, 'csrf_protection' => false], $options)
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param string $method
 | |
|      * @param mixed  $formType
 | |
|      * @param array  $options
 | |
|      * @param mixed  $data
 | |
|      * @return FormBuilderInterface
 | |
|      */
 | |
|     public function createApiFormBuilder($method = 'POST', $formType = 'form', array $options = [], $data = null)
 | |
|     {
 | |
|         return $this->app['form.factory']->createNamedBuilder(
 | |
|             'data',
 | |
|             $formType,
 | |
|             $data,
 | |
|             array_merge(['method' => $method, 'csrf_protection' => false], $options)
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param mixed $attributes
 | |
|      * @param mixed $object
 | |
|      * @return bool
 | |
|      */
 | |
|     public function isGranted($attributes, $object = null)
 | |
|     {
 | |
|         /** @var AuthorizationChecker $authorizationChecker */
 | |
|         $authorizationChecker = $this->app['phraseanet.authorization_checker'];
 | |
| 
 | |
|         return $authorizationChecker->isGranted($attributes, $object);
 | |
|     }
 | |
| }
 | 
