1
0
mirror of https://github.com/phpbb/phpbb.git synced 2025-02-25 12:33:29 +01:00

[ticket/14269] Use http_exceptions in the installer instead of die()

PHPBB3-14269
This commit is contained in:
Mate Bartus 2015-11-04 14:00:59 +01:00
parent 1316fe2084
commit 93b37b24c2
5 changed files with 147 additions and 2 deletions

View File

@ -32,6 +32,15 @@ services:
- @filesystem
- %core.root_path%
kernel_exception_subscriber:
class: phpbb\install\event\kernel_exception_subscriber
arguments:
- @phpbb.installer.controller.helper
- @language
- @template
tags:
- { name: kernel.event_subscriber }
language.loader:
parent: language.loader_abstract

View File

@ -82,6 +82,9 @@ $lang = array_merge($lang, array(
<p>Only those databases supported on your server will be displayed.',
'ACP_LINK' => 'Take me to <a href="%1$s">the ACP</a>',
'INSTALL_PHPBB_IS_ALREADY_INSTALLED' => 'phpBB is already installed.',
'INSTALL_PHPBB_IS_NOT_INSTALLED' => 'phpBB is not installed yet.'
));
// Requirements translation

View File

@ -13,6 +13,7 @@
namespace phpbb\install\controller;
use phpbb\exception\http_exception;
use phpbb\install\helper\install_helper;
use phpbb\install\helper\navigation\navigation_provider;
use Symfony\Component\HttpFoundation\StreamedResponse;
@ -97,12 +98,14 @@ class install
* Controller logic
*
* @return Response|StreamedResponse
*
* @throws http_exception When phpBB is already installed
*/
public function handle()
{
if ($this->install_helper->is_phpbb_installed())
{
die ('phpBB is already installed');
throw new http_exception(404, 'INSTALL_PHPBB_IS_ALREADY_INSTALLED');
}
$this->template->assign_vars(array(

View File

@ -13,6 +13,7 @@
namespace phpbb\install\controller;
use phpbb\exception\http_exception;
use phpbb\install\helper\install_helper;
use phpbb\install\helper\iohandler\factory;
use phpbb\install\helper\navigation\navigation_provider;
@ -93,12 +94,16 @@ class update
/**
* Controller entry point
*
* @return Response|StreamedResponse
*
* @throws http_exception When phpBB is not installed
*/
public function handle()
{
if (!$this->install_helper->is_phpbb_installed())
{
die ('phpBB is not installed');
throw new http_exception(404, 'INSTALL_PHPBB_IS_NOT_INSTALLED');
}
$this->template->assign_vars(array(

View File

@ -0,0 +1,125 @@
<?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\install\event;
use phpbb\exception\exception_interface;
use phpbb\install\controller\helper;
use phpbb\language\language;
use phpbb\template\template;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface;
use Symfony\Component\HttpKernel\KernelEvents;
use Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent;
/**
* Exception handler for the installer
*/
class kernel_exception_subscriber implements EventSubscriberInterface
{
/**
* @var helper
*/
protected $controller_helper;
/**
* @var language
*/
protected $language;
/**
* @var template
*/
protected $template;
/**
* Constructor
*
* @param helper $controller_helper
* @param language $language
* @param template $template
*/
public function __construct(helper $controller_helper, language $language, template $template)
{
$this->controller_helper = $controller_helper;
$this->language = $language;
$this->template = $template;
}
/**
* This listener is run when the KernelEvents::EXCEPTION event is triggered
*
* @param GetResponseForExceptionEvent $event
*/
public function on_kernel_exception(GetResponseForExceptionEvent $event)
{
$exception = $event->getException();
$message = $exception->getMessage();
if ($exception instanceof exception_interface)
{
$message = $this->language->lang_array($message, $exception->get_parameters());
}
if (!$event->getRequest()->isXmlHttpRequest())
{
$this->template->assign_vars(array(
'TITLE' => $this->language->lang('INFORMATION'),
'BODY' => $message,
));
$response = $this->controller_helper->render(
'installer_main.html',
$this->language->lang('INFORMATION'),
false,
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());
}
$event->setResponse($response);
}
/**
* Returns an array of the events the object is subscribed to
*
* @return array Array of the events the object is subscribed to
*/
static public function getSubscribedEvents()
{
return array(
KernelEvents::EXCEPTION => 'on_kernel_exception',
);
}
}