[CORE][Controller] Make it possible for plugins to add different content-types to existing routes
This commit is contained in:
parent
8e45637277
commit
fd3b57dc24
@ -37,11 +37,9 @@ use App\Util\Exception\RedirectException;
|
|||||||
use Exception;
|
use Exception;
|
||||||
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
|
||||||
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
||||||
use Symfony\Component\HttpFoundation\JsonResponse;
|
|
||||||
use Symfony\Component\HttpFoundation\RedirectResponse;
|
use Symfony\Component\HttpFoundation\RedirectResponse;
|
||||||
use Symfony\Component\HttpFoundation\Request;
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
use Symfony\Component\HttpFoundation\RequestStack;
|
use Symfony\Component\HttpFoundation\RequestStack;
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
|
||||||
use Symfony\Component\HttpKernel\Event\ControllerEvent;
|
use Symfony\Component\HttpKernel\Event\ControllerEvent;
|
||||||
use Symfony\Component\HttpKernel\Event\ExceptionEvent;
|
use Symfony\Component\HttpKernel\Event\ExceptionEvent;
|
||||||
use Symfony\Component\HttpKernel\Event\ViewEvent;
|
use Symfony\Component\HttpKernel\Event\ViewEvent;
|
||||||
@ -50,7 +48,7 @@ use Symfony\Component\HttpKernel\KernelEvents;
|
|||||||
class Controller extends AbstractController implements EventSubscriberInterface
|
class Controller extends AbstractController implements EventSubscriberInterface
|
||||||
{
|
{
|
||||||
private array $vars = [];
|
private array $vars = [];
|
||||||
private ?Request $request = null;
|
protected ?Request $request = null;
|
||||||
|
|
||||||
public function __construct(RequestStack $requestStack)
|
public function __construct(RequestStack $requestStack)
|
||||||
{
|
{
|
||||||
@ -83,7 +81,7 @@ class Controller extends AbstractController implements EventSubscriberInterface
|
|||||||
$request = $event->getRequest();
|
$request = $event->getRequest();
|
||||||
|
|
||||||
$this->request = $request;
|
$this->request = $request;
|
||||||
$this->vars = ['controler' => $controller, 'request' => $request, 'have_user' => Common::user() !== null];
|
$this->vars = ['controller' => $controller, 'request' => $request, 'have_user' => Common::user() !== null];
|
||||||
Event::handle('StartTwigPopulateVars', [&$this->vars]);
|
Event::handle('StartTwigPopulateVars', [&$this->vars]);
|
||||||
|
|
||||||
$event->stopPropagation();
|
$event->stopPropagation();
|
||||||
@ -110,19 +108,25 @@ class Controller extends AbstractController implements EventSubscriberInterface
|
|||||||
$template = $this->vars['_template'];
|
$template = $this->vars['_template'];
|
||||||
unset($this->vars['_template'], $this->vars['request'], $response['_template']);
|
unset($this->vars['_template'], $this->vars['request'], $response['_template']);
|
||||||
|
|
||||||
// Respond in the the most preffered acceptable content type
|
// Respond in the most preferred acceptable content type
|
||||||
$accept = $request->getAcceptableContentTypes() ?: ['text/html'];
|
$accept = $request->getAcceptableContentTypes() ?: ['text/html'];
|
||||||
$format = $request->getFormat($accept[0]);
|
$format = $request->getFormat($accept[0]);
|
||||||
switch ($format) {
|
switch ($format) {
|
||||||
case 'html':
|
case 'html':
|
||||||
$event->setResponse($this->render($template, $this->vars));
|
$event->setResponse($this->render($template, $this->vars));
|
||||||
break;
|
break;
|
||||||
case 'json':
|
|
||||||
case 'jsonld':
|
|
||||||
$event->setResponse(new JsonResponse($response));
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
throw new ClientException(_m('Unsupported format: {format}', ['format' => $format]), 406); // 406 Not Acceptable
|
$potential_response = null;
|
||||||
|
if (Event::handle('RouteInFormat', [
|
||||||
|
'route' => $this->vars['controller'][1],
|
||||||
|
'accept' => $accept,
|
||||||
|
'vars' => $this->vars,
|
||||||
|
'response' => &$potential_response,
|
||||||
|
])) {
|
||||||
|
throw new ClientException(_m('Unsupported format: {format}', ['format' => $format]), 406); // 406 Not Acceptable
|
||||||
|
} else {
|
||||||
|
$event->setResponse($potential_response);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Event::handle('CleanupModule');
|
Event::handle('CleanupModule');
|
||||||
|
@ -30,7 +30,7 @@ use DateTime;
|
|||||||
/**
|
/**
|
||||||
* Base class to all entities, with some utilities
|
* Base class to all entities, with some utilities
|
||||||
*/
|
*/
|
||||||
abstract class Entity implements \JsonSerializable
|
abstract class Entity
|
||||||
{
|
{
|
||||||
public function __call(string $name , array $arguments): mixed
|
public function __call(string $name , array $arguments): mixed
|
||||||
{
|
{
|
||||||
@ -130,17 +130,4 @@ abstract class Entity implements \JsonSerializable
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Called when json_encode encounters this object. Not all
|
|
||||||
* entities will need json encoding, so it doesn't make sense to
|
|
||||||
* make this abstract
|
|
||||||
*
|
|
||||||
* @throw ServerException
|
|
||||||
* @codeCoverageIgnore
|
|
||||||
*/
|
|
||||||
public function jsonSerialize()
|
|
||||||
{
|
|
||||||
throw new ServerException(_m('Unimplemented method'));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user