mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-08 10:34:34 +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);
|
|
}
|
|
}
|