[CORE][Controller] Make it possible for plugins to add different content-types to existing routes

This commit is contained in:
Diogo Peralta Cordeiro 2021-08-24 05:30:54 +01:00 committed by Hugo Sales
parent 8e45637277
commit fd3b57dc24
Signed by: someonewithpc
GPG Key ID: 7D0C7EAFC9D835A0
2 changed files with 15 additions and 24 deletions

View File

@ -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:
$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 throw new ClientException(_m('Unsupported format: {format}', ['format' => $format]), 406); // 406 Not Acceptable
} else {
$event->setResponse($potential_response);
}
} }
Event::handle('CleanupModule'); Event::handle('CleanupModule');

View File

@ -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'));
}
} }