mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-07 20:08:53 +00:00
Merge branch 'develop-ascraeus' into develop
* develop-ascraeus: [ticket/13361] Rename exception to runtime_exception [ticket/13361] Fix the JsonResponse in the exception listener [ticket/13361] Add tests [ticket/13361] Support ajax request (send a json response) [ticket/13361] Improve the exception listener
This commit is contained in:
commit
f9f43141a9
6 changed files with 299 additions and 13 deletions
|
@ -187,6 +187,8 @@ class helper
|
|||
* @param string $message The error message
|
||||
* @param int $code The error code (e.g. 404, 500, 503, etc.)
|
||||
* @return Response A Response instance
|
||||
*
|
||||
* @deprecated 3.1.3 (To be removed: 3.3.0) Use exceptions instead.
|
||||
*/
|
||||
public function error($message, $code = 500)
|
||||
{
|
||||
|
|
|
@ -14,9 +14,10 @@
|
|||
namespace phpbb\event;
|
||||
|
||||
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
||||
use Symfony\Component\HttpFoundation\JsonResponse;
|
||||
use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface;
|
||||
use Symfony\Component\HttpKernel\KernelEvents;
|
||||
use Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent;
|
||||
use Symfony\Component\HttpKernel\Exception\HttpException;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
|
||||
class kernel_exception_subscriber implements EventSubscriberInterface
|
||||
|
@ -53,23 +54,55 @@ class kernel_exception_subscriber implements EventSubscriberInterface
|
|||
*/
|
||||
public function on_kernel_exception(GetResponseForExceptionEvent $event)
|
||||
{
|
||||
page_header($this->user->lang('INFORMATION'));
|
||||
|
||||
$exception = $event->getException();
|
||||
|
||||
$this->template->assign_vars(array(
|
||||
'MESSAGE_TITLE' => $this->user->lang('INFORMATION'),
|
||||
'MESSAGE_TEXT' => $exception->getMessage(),
|
||||
));
|
||||
$message = $exception->getMessage();
|
||||
|
||||
$this->template->set_filenames(array(
|
||||
'body' => 'message_body.html',
|
||||
));
|
||||
if ($exception instanceof \phpbb\exception\exception_interface)
|
||||
{
|
||||
$message = call_user_func_array(array($this->user, 'lang'), array_merge(array($message), $exception->get_parameters()));
|
||||
}
|
||||
|
||||
page_footer(true, false, false);
|
||||
if (!$event->getRequest()->isXmlHttpRequest())
|
||||
{
|
||||
page_header($this->user->lang('INFORMATION'));
|
||||
|
||||
$this->template->assign_vars(array(
|
||||
'MESSAGE_TITLE' => $this->user->lang('INFORMATION'),
|
||||
'MESSAGE_TEXT' => $message,
|
||||
));
|
||||
|
||||
$this->template->set_filenames(array(
|
||||
'body' => 'message_body.html',
|
||||
));
|
||||
|
||||
page_footer(true, false, false);
|
||||
|
||||
$response = new Response($this->template->assign_display('body'), 500);
|
||||
}
|
||||
else
|
||||
{
|
||||
$data = array();
|
||||
|
||||
if (!empty($message))
|
||||
{
|
||||
$data['message'] = $message;
|
||||
}
|
||||
|
||||
if (defined('DEBUG'))
|
||||
{
|
||||
$data['trace'] = $exception->getTrace();
|
||||
}
|
||||
|
||||
$response = new JsonResponse($data, 500);
|
||||
}
|
||||
|
||||
if ($exception instanceof HttpExceptionInterface)
|
||||
{
|
||||
$response->setStatusCode($exception->getStatusCode());
|
||||
$response->headers->add($exception->getHeaders());
|
||||
}
|
||||
|
||||
$status_code = $exception instanceof HttpException ? $exception->getStatusCode() : 500;
|
||||
$response = new Response($this->template->assign_display('body'), $status_code);
|
||||
$event->setResponse($response);
|
||||
}
|
||||
|
||||
|
|
29
phpBB/phpbb/exception/exception_interface.php
Normal file
29
phpBB/phpbb/exception/exception_interface.php
Normal file
|
@ -0,0 +1,29 @@
|
|||
<?php
|
||||
/**
|
||||
*
|
||||
* This file is part of the phpBB Forum Software package.
|
||||
*
|
||||
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
||||
* @license GNU General Public License, version 2 (GPL-2.0)
|
||||
*
|
||||
* For full copyright and license information, please see
|
||||
* the docs/CREDITS.txt file.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace phpbb\exception;
|
||||
|
||||
/**
|
||||
* Interface exception_interface
|
||||
*
|
||||
* Define an exception which support a language var as message.
|
||||
*/
|
||||
interface exception_interface
|
||||
{
|
||||
/**
|
||||
* Return the arguments associated with the message if it's a language var.
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function get_parameters();
|
||||
}
|
70
phpBB/phpbb/exception/http_exception.php
Normal file
70
phpBB/phpbb/exception/http_exception.php
Normal file
|
@ -0,0 +1,70 @@
|
|||
<?php
|
||||
/**
|
||||
*
|
||||
* This file is part of the phpBB Forum Software package.
|
||||
*
|
||||
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
||||
* @license GNU General Public License, version 2 (GPL-2.0)
|
||||
*
|
||||
* For full copyright and license information, please see
|
||||
* the docs/CREDITS.txt file.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace phpbb\exception;
|
||||
|
||||
use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface;
|
||||
|
||||
/**
|
||||
* Class http_exception
|
||||
*/
|
||||
class http_exception extends runtime_exception implements HttpExceptionInterface
|
||||
{
|
||||
/**
|
||||
* Http status code.
|
||||
*
|
||||
* @var integer
|
||||
*/
|
||||
private $status_code;
|
||||
|
||||
/**
|
||||
* Additional headers to set in the response.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private $headers;
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
*
|
||||
* @param integer $status_code The http status code.
|
||||
* @param string $message The Exception message to throw (must be a language variable).
|
||||
* @param array $parameters The parameters to use with the language var.
|
||||
* @param \Exception $previous The previous exception used for the exception chaining.
|
||||
* @param array $headers Additional headers to set in the response.
|
||||
* @param integer $code The Exception code.
|
||||
*/
|
||||
public function __construct($status_code, $message = "", array $parameters = array(), \Exception $previous = null, array $headers = array(), $code = 0)
|
||||
{
|
||||
$this->status_code = $status_code;
|
||||
$this->headers = $headers;
|
||||
|
||||
parent::__construct($message, $parameters, $previous, $code);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function getStatusCode()
|
||||
{
|
||||
return $this->status_code;
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function getHeaders()
|
||||
{
|
||||
return $this->headers;
|
||||
}
|
||||
}
|
52
phpBB/phpbb/exception/runtime_exception.php
Normal file
52
phpBB/phpbb/exception/runtime_exception.php
Normal file
|
@ -0,0 +1,52 @@
|
|||
<?php
|
||||
/**
|
||||
*
|
||||
* This file is part of the phpBB Forum Software package.
|
||||
*
|
||||
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
||||
* @license GNU General Public License, version 2 (GPL-2.0)
|
||||
*
|
||||
* For full copyright and license information, please see
|
||||
* the docs/CREDITS.txt file.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace phpbb\exception;
|
||||
|
||||
/**
|
||||
* Class runtime_exception
|
||||
*
|
||||
* Define an exception which support a language var as message.
|
||||
*/
|
||||
class runtime_exception extends \RuntimeException implements exception_interface
|
||||
{
|
||||
/**
|
||||
* Parameters to use with the language var.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private $parameters;
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
*
|
||||
* @param string $message The Exception message to throw (must be a language variable).
|
||||
* @param array $parameters The parameters to use with the language var.
|
||||
* @param \Exception $previous The previous runtime_exception used for the runtime_exception chaining.
|
||||
* @param integer $code The Exception code.
|
||||
*/
|
||||
public function __construct($message = "", array $parameters = array(), \Exception $previous = null, $code = 0)
|
||||
{
|
||||
$this->parameters = $parameters;
|
||||
|
||||
parent::__construct($message, $code, $previous);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function get_parameters()
|
||||
{
|
||||
return $this->parameters;
|
||||
}
|
||||
}
|
100
tests/event/exception_listener_test.php
Normal file
100
tests/event/exception_listener_test.php
Normal file
|
@ -0,0 +1,100 @@
|
|||
<?php
|
||||
/**
|
||||
*
|
||||
* This file is part of the phpBB Forum Software package.
|
||||
*
|
||||
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
||||
* @license GNU General Public License, version 2 (GPL-2.0)
|
||||
*
|
||||
* For full copyright and license information, please see
|
||||
* the docs/CREDITS.txt file.
|
||||
*
|
||||
*/
|
||||
|
||||
require_once dirname(__FILE__) . '/../../phpBB/includes/functions.php';
|
||||
|
||||
class exception_listener extends phpbb_test_case
|
||||
{
|
||||
public function phpbb_exception_data()
|
||||
{
|
||||
return array(
|
||||
array(
|
||||
true,
|
||||
new \Exception(),
|
||||
array(
|
||||
'status_code' => 500,
|
||||
),
|
||||
),
|
||||
array(
|
||||
true,
|
||||
new \Exception('AJAX_ERROR_TEXT'),
|
||||
array(
|
||||
'status_code' => 500,
|
||||
'content' => 'AJAX_ERROR_TEXT',
|
||||
),
|
||||
),
|
||||
array(
|
||||
true,
|
||||
new \phpbb\exception\runtime_exception('AJAX_ERROR_TEXT'),
|
||||
array(
|
||||
'status_code' => 500,
|
||||
'content' => 'Something went wrong when processing your request.',
|
||||
),
|
||||
),
|
||||
array(
|
||||
true,
|
||||
new \Symfony\Component\HttpKernel\Exception\HttpException(404, 'AJAX_ERROR_TEXT'),
|
||||
array(
|
||||
'status_code' => 404,
|
||||
'content' => 'AJAX_ERROR_TEXT',
|
||||
),
|
||||
),
|
||||
array(
|
||||
true,
|
||||
new \phpbb\exception\http_exception(404, 'AJAX_ERROR_TEXT'),
|
||||
array(
|
||||
'status_code' => 404,
|
||||
'content' => 'Something went wrong when processing your request.',
|
||||
),
|
||||
),
|
||||
array(
|
||||
true,
|
||||
new \phpbb\exception\http_exception(404, 'CURRENT_TIME', array('today')),
|
||||
array(
|
||||
'status_code' => 404,
|
||||
'content' => 'It is currently today',
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider phpbb_exception_data
|
||||
*/
|
||||
public function test_phpbb_exception($is_ajax, $exception, $expected)
|
||||
{
|
||||
$request = \Symfony\Component\HttpFoundation\Request::create('test.php', 'GET', array(), array(), array(), $is_ajax ? array('HTTP_X_REQUESTED_WITH' => 'XMLHttpRequest') : array());
|
||||
|
||||
$template = $this->getMockBuilder('\phpbb\template\twig\twig')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
|
||||
$user = new \phpbb\user('\phpbb\datetime');
|
||||
$user->add_lang('common');
|
||||
|
||||
$exception_listener = new \phpbb\event\kernel_exception_subscriber($template, $user);
|
||||
|
||||
$event = new \Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent($this->getMock('Symfony\Component\HttpKernel\HttpKernelInterface'), $request, \Symfony\Component\HttpKernel\HttpKernelInterface::MASTER_REQUEST, $exception);
|
||||
$exception_listener->on_kernel_exception($event);
|
||||
|
||||
$response = $event->getResponse();
|
||||
|
||||
$this->assertEquals($expected['status_code'], $response->getStatusCode());
|
||||
$this->assertEquals($is_ajax, $response instanceof \Symfony\Component\HttpFoundation\JsonResponse);
|
||||
|
||||
if (isset($expected['content']))
|
||||
{
|
||||
$this->assertContains($expected['content'], $response->getContent());
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue