1
0
mirror of https://github.com/phpbb/phpbb.git synced 2025-10-25 05:36:13 +02:00

Merge pull request #3565 from MateBartus/ticket/13793

[ticket/13793] Remove translation on throwing exceptions
This commit is contained in:
Tristan Darricau
2015-05-02 13:21:21 +02:00
14 changed files with 44 additions and 70 deletions

View File

@@ -86,7 +86,6 @@ services:
controller.resolver: controller.resolver:
class: phpbb\controller\resolver class: phpbb\controller\resolver
arguments: arguments:
- @user
- @service_container - @service_container
- %core.root_path% - %core.root_path%
- @template - @template
@@ -98,7 +97,6 @@ services:
- @dbal.conn - @dbal.conn
- @config - @config
- @filesystem - @filesystem
- @user
- %tables.ext% - %tables.ext%
- %core.root_path% - %core.root_path%
- %core.php_ext% - %core.php_ext%

View File

@@ -70,7 +70,7 @@ class acp_extensions
// If they've specified an extension, let's load the metadata manager and validate it. // If they've specified an extension, let's load the metadata manager and validate it.
if ($ext_name) if ($ext_name)
{ {
$md_manager = new \phpbb\extension\metadata_manager($ext_name, $config, $phpbb_extension_manager, $template, $user, $phpbb_root_path); $md_manager = new \phpbb\extension\metadata_manager($ext_name, $config, $phpbb_extension_manager, $template, $phpbb_root_path);
try try
{ {
@@ -78,7 +78,8 @@ class acp_extensions
} }
catch(\phpbb\extension\exception $e) catch(\phpbb\extension\exception $e)
{ {
trigger_error($e, E_USER_WARNING); $message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
trigger_error($message, E_USER_WARNING);
} }
} }
@@ -354,8 +355,9 @@ class acp_extensions
} }
catch(\phpbb\extension\exception $e) catch(\phpbb\extension\exception $e)
{ {
$message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->template->assign_block_vars('disabled', array( $this->template->assign_block_vars('disabled', array(
'META_DISPLAY_NAME' => $this->user->lang('EXTENSION_INVALID_LIST', $name, $e), 'META_DISPLAY_NAME' => $this->user->lang('EXTENSION_INVALID_LIST', $name, $message),
'S_VERSIONCHECK' => false, 'S_VERSIONCHECK' => false,
)); ));
} }
@@ -410,8 +412,9 @@ class acp_extensions
} }
catch(\phpbb\extension\exception $e) catch(\phpbb\extension\exception $e)
{ {
$message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->template->assign_block_vars('disabled', array( $this->template->assign_block_vars('disabled', array(
'META_DISPLAY_NAME' => $this->user->lang('EXTENSION_INVALID_LIST', $name, $e), 'META_DISPLAY_NAME' => $this->user->lang('EXTENSION_INVALID_LIST', $name, $message),
'S_VERSIONCHECK' => false, 'S_VERSIONCHECK' => false,
)); ));
} }
@@ -469,8 +472,9 @@ class acp_extensions
} }
catch(\phpbb\extension\exception $e) catch(\phpbb\extension\exception $e)
{ {
$message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->template->assign_block_vars('disabled', array( $this->template->assign_block_vars('disabled', array(
'META_DISPLAY_NAME' => $this->user->lang('EXTENSION_INVALID_LIST', $name, $e), 'META_DISPLAY_NAME' => $this->user->lang('EXTENSION_INVALID_LIST', $name, $message),
'S_VERSIONCHECK' => false, 'S_VERSIONCHECK' => false,
)); ));
} }

View File

@@ -16,6 +16,6 @@ namespace phpbb\controller;
/** /**
* Controller exception class * Controller exception class
*/ */
class exception extends \RuntimeException class exception extends \phpbb\exception\runtime_exception
{ {
} }

View File

@@ -22,12 +22,6 @@ use Symfony\Component\HttpFoundation\Request;
*/ */
class resolver implements ControllerResolverInterface class resolver implements ControllerResolverInterface
{ {
/**
* User object
* @var \phpbb\user
*/
protected $user;
/** /**
* ContainerInterface object * ContainerInterface object
* @var ContainerInterface * @var ContainerInterface
@@ -55,14 +49,12 @@ class resolver implements ControllerResolverInterface
/** /**
* Construct method * Construct method
* *
* @param \phpbb\user $user User Object
* @param ContainerInterface $container ContainerInterface object * @param ContainerInterface $container ContainerInterface object
* @param string $phpbb_root_path Relative path to phpBB root * @param string $phpbb_root_path Relative path to phpBB root
* @param \phpbb\template\template $template * @param \phpbb\template\template $template
*/ */
public function __construct(\phpbb\user $user, ContainerInterface $container, $phpbb_root_path, \phpbb\template\template $template = null) public function __construct(ContainerInterface $container, $phpbb_root_path, \phpbb\template\template $template = null)
{ {
$this->user = $user;
$this->container = $container; $this->container = $container;
$this->template = $template; $this->template = $template;
$this->type_cast_helper = new \phpbb\request\type_cast_helper(); $this->type_cast_helper = new \phpbb\request\type_cast_helper();
@@ -82,20 +74,20 @@ class resolver implements ControllerResolverInterface
if (!$controller) if (!$controller)
{ {
throw new \phpbb\controller\exception($this->user->lang['CONTROLLER_NOT_SPECIFIED']); throw new \phpbb\controller\exception('CONTROLLER_NOT_SPECIFIED');
} }
// Require a method name along with the service name // Require a method name along with the service name
if (stripos($controller, ':') === false) if (stripos($controller, ':') === false)
{ {
throw new \phpbb\controller\exception($this->user->lang['CONTROLLER_METHOD_NOT_SPECIFIED']); throw new \phpbb\controller\exception('CONTROLLER_METHOD_NOT_SPECIFIED');
} }
list($service, $method) = explode(':', $controller); list($service, $method) = explode(':', $controller);
if (!$this->container->has($service)) if (!$this->container->has($service))
{ {
throw new \phpbb\controller\exception($this->user->lang('CONTROLLER_SERVICE_UNDEFINED', $service)); throw new \phpbb\controller\exception('CONTROLLER_SERVICE_UNDEFINED', array($service));
} }
$controller_object = $this->container->get($service); $controller_object = $this->container->get($service);
@@ -166,7 +158,7 @@ class resolver implements ControllerResolverInterface
} }
else else
{ {
throw new \phpbb\controller\exception($this->user->lang('CONTROLLER_ARGUMENT_VALUE_MISSING', $param->getPosition() + 1, get_class($object) . ':' . $method, $param->name)); throw new \phpbb\controller\exception('CONTROLLER_ARGUMENT_VALUE_MISSING', array($param->getPosition() + 1, get_class($object) . ':' . $method, $param->name));
} }
} }

View File

@@ -16,10 +16,6 @@ namespace phpbb\extension;
/** /**
* Exception class for metadata * Exception class for metadata
*/ */
class exception extends \UnexpectedValueException class exception extends \phpbb\exception\runtime_exception
{ {
public function __toString()
{
return $this->getMessage();
}
} }

View File

@@ -26,7 +26,6 @@ class manager
protected $db; protected $db;
protected $config; protected $config;
protected $cache; protected $cache;
protected $user;
protected $php_ext; protected $php_ext;
protected $extensions; protected $extensions;
protected $extension_table; protected $extension_table;
@@ -40,14 +39,13 @@ class manager
* @param \phpbb\db\driver\driver_interface $db A database connection * @param \phpbb\db\driver\driver_interface $db A database connection
* @param \phpbb\config\config $config Config object * @param \phpbb\config\config $config Config object
* @param \phpbb\filesystem\filesystem_interface $filesystem * @param \phpbb\filesystem\filesystem_interface $filesystem
* @param \phpbb\user $user User object
* @param string $extension_table The name of the table holding extensions * @param string $extension_table The name of the table holding extensions
* @param string $phpbb_root_path Path to the phpbb includes directory. * @param string $phpbb_root_path Path to the phpbb includes directory.
* @param string $php_ext php file extension, defaults to php * @param string $php_ext php file extension, defaults to php
* @param \phpbb\cache\driver\driver_interface $cache A cache instance or null * @param \phpbb\cache\driver\driver_interface $cache A cache instance or null
* @param string $cache_name The name of the cache variable, defaults to _ext * @param string $cache_name The name of the cache variable, defaults to _ext
*/ */
public function __construct(ContainerInterface $container, \phpbb\db\driver\driver_interface $db, \phpbb\config\config $config, \phpbb\filesystem\filesystem_interface $filesystem, \phpbb\user $user, $extension_table, $phpbb_root_path, $php_ext = 'php', \phpbb\cache\driver\driver_interface $cache = null, $cache_name = '_ext') public function __construct(ContainerInterface $container, \phpbb\db\driver\driver_interface $db, \phpbb\config\config $config, \phpbb\filesystem\filesystem_interface $filesystem, $extension_table, $phpbb_root_path, $php_ext = 'php', \phpbb\cache\driver\driver_interface $cache = null, $cache_name = '_ext')
{ {
$this->cache = $cache; $this->cache = $cache;
$this->cache_name = $cache_name; $this->cache_name = $cache_name;
@@ -58,7 +56,6 @@ class manager
$this->filesystem = $filesystem; $this->filesystem = $filesystem;
$this->phpbb_root_path = $phpbb_root_path; $this->phpbb_root_path = $phpbb_root_path;
$this->php_ext = $php_ext; $this->php_ext = $php_ext;
$this->user = $user;
$this->extensions = ($this->cache) ? $this->cache->get($this->cache_name) : false; $this->extensions = ($this->cache) ? $this->cache->get($this->cache_name) : false;
@@ -154,7 +151,7 @@ class manager
*/ */
public function create_extension_metadata_manager($name, \phpbb\template\template $template) public function create_extension_metadata_manager($name, \phpbb\template\template $template)
{ {
return new \phpbb\extension\metadata_manager($name, $this->config, $this, $template, $this->user, $this->phpbb_root_path); return new \phpbb\extension\metadata_manager($name, $this->config, $this, $template, $this->phpbb_root_path);
} }
/** /**

View File

@@ -36,12 +36,6 @@ class metadata_manager
*/ */
protected $template; protected $template;
/**
* phpBB User instance
* @var \phpbb\user
*/
protected $user;
/** /**
* phpBB root path * phpBB root path
* @var string * @var string
@@ -73,15 +67,13 @@ class metadata_manager
* @param \phpbb\config\config $config phpBB Config instance * @param \phpbb\config\config $config phpBB Config instance
* @param \phpbb\extension\manager $extension_manager An instance of the phpBB extension manager * @param \phpbb\extension\manager $extension_manager An instance of the phpBB extension manager
* @param \phpbb\template\template $template phpBB Template instance * @param \phpbb\template\template $template phpBB Template instance
* @param \phpbb\user $user User instance
* @param string $phpbb_root_path Path to the phpbb includes directory. * @param string $phpbb_root_path Path to the phpbb includes directory.
*/ */
public function __construct($ext_name, \phpbb\config\config $config, \phpbb\extension\manager $extension_manager, \phpbb\template\template $template, \phpbb\user $user, $phpbb_root_path) public function __construct($ext_name, \phpbb\config\config $config, \phpbb\extension\manager $extension_manager, \phpbb\template\template $template, $phpbb_root_path)
{ {
$this->config = $config; $this->config = $config;
$this->extension_manager = $extension_manager; $this->extension_manager = $extension_manager;
$this->template = $template; $this->template = $template;
$this->user = $user;
$this->phpbb_root_path = $phpbb_root_path; $this->phpbb_root_path = $phpbb_root_path;
$this->ext_name = $ext_name; $this->ext_name = $ext_name;
@@ -149,7 +141,7 @@ class metadata_manager
if (!file_exists($this->metadata_file)) if (!file_exists($this->metadata_file))
{ {
throw new \phpbb\extension\exception($this->user->lang('FILE_NOT_FOUND', $this->metadata_file)); throw new \phpbb\extension\exception('FILE_NOT_FOUND', array($this->metadata_file));
} }
} }
@@ -163,18 +155,18 @@ class metadata_manager
{ {
if (!file_exists($this->metadata_file)) if (!file_exists($this->metadata_file))
{ {
throw new \phpbb\extension\exception($this->user->lang('FILE_NOT_FOUND', $this->metadata_file)); throw new \phpbb\extension\exception('FILE_NOT_FOUND', array($this->metadata_file));
} }
else else
{ {
if (!($file_contents = file_get_contents($this->metadata_file))) if (!($file_contents = file_get_contents($this->metadata_file)))
{ {
throw new \phpbb\extension\exception($this->user->lang('FILE_CONTENT_ERR', $this->metadata_file)); throw new \phpbb\extension\exception('FILE_CONTENT_ERR', array($this->metadata_file));
} }
if (($metadata = json_decode($file_contents, true)) === null) if (($metadata = json_decode($file_contents, true)) === null)
{ {
throw new \phpbb\extension\exception($this->user->lang('FILE_JSON_DECODE_ERR', $this->metadata_file)); throw new \phpbb\extension\exception('FILE_JSON_DECODE_ERR', array($this->metadata_file));
} }
array_walk_recursive($metadata, array($this, 'sanitize_json')); array_walk_recursive($metadata, array($this, 'sanitize_json'));
@@ -246,12 +238,12 @@ class metadata_manager
{ {
if (!isset($this->metadata[$name])) if (!isset($this->metadata[$name]))
{ {
throw new \phpbb\extension\exception($this->user->lang('META_FIELD_NOT_SET', $name)); throw new \phpbb\extension\exception('META_FIELD_NOT_SET', array($name));
} }
if (!preg_match($fields[$name], $this->metadata[$name])) if (!preg_match($fields[$name], $this->metadata[$name]))
{ {
throw new \phpbb\extension\exception($this->user->lang('META_FIELD_INVALID', $name)); throw new \phpbb\extension\exception('META_FIELD_INVALID', array($name));
} }
} }
break; break;
@@ -270,14 +262,14 @@ class metadata_manager
{ {
if (empty($this->metadata['authors'])) if (empty($this->metadata['authors']))
{ {
throw new \phpbb\extension\exception($this->user->lang('META_FIELD_NOT_SET', 'authors')); throw new \phpbb\extension\exception('META_FIELD_NOT_SET', array('authors'));
} }
foreach ($this->metadata['authors'] as $author) foreach ($this->metadata['authors'] as $author)
{ {
if (!isset($author['name'])) if (!isset($author['name']))
{ {
throw new \phpbb\extension\exception($this->user->lang('META_FIELD_NOT_SET', 'author name')); throw new \phpbb\extension\exception('META_FIELD_NOT_SET', array('author name'));
} }
} }

View File

@@ -17,10 +17,6 @@ namespace phpbb\notification;
* Notifications exception * Notifications exception
*/ */
class exception extends \Exception class exception extends \phpbb\exception\runtime_exception
{ {
public function __toString()
{
return $this->getMessage();
}
} }

View File

@@ -943,7 +943,7 @@ class manager
{ {
if (!isset($this->notification_types[$notification_type_name]) && !isset($this->notification_types['notification.type.' . $notification_type_name])) if (!isset($this->notification_types[$notification_type_name]) && !isset($this->notification_types['notification.type.' . $notification_type_name]))
{ {
throw new \phpbb\notification\exception($this->user->lang('NOTIFICATION_TYPE_NOT_EXIST', $notification_type_name)); throw new \phpbb\notification\exception('NOTIFICATION_TYPE_NOT_EXIST', array($notification_type_name));
} }
$sql = 'INSERT INTO ' . $this->notification_types_table . ' ' . $this->db->sql_build_array('INSERT', array( $sql = 'INSERT INTO ' . $this->notification_types_table . ' ' . $this->db->sql_build_array('INSERT', array(

View File

@@ -82,7 +82,7 @@ class phpbb_controller_controller_test extends phpbb_test_case
include(__DIR__.'/phpbb/controller/foo.php'); include(__DIR__.'/phpbb/controller/foo.php');
} }
$resolver = new \phpbb\controller\resolver(new \phpbb\user('\phpbb\datetime'), $container, dirname(__FILE__) . '/'); $resolver = new \phpbb\controller\resolver($container, dirname(__FILE__) . '/');
$symfony_request = new Request(); $symfony_request = new Request();
$symfony_request->attributes->set('_controller', 'foo.controller:handle'); $symfony_request->attributes->set('_controller', 'foo.controller:handle');

View File

@@ -63,14 +63,12 @@ class phpbb_dbal_migrator_test extends phpbb_database_test_case
); );
$container->set('migrator', $this->migrator); $container->set('migrator', $this->migrator);
$container->set('dispatcher', new phpbb_mock_event_dispatcher()); $container->set('dispatcher', new phpbb_mock_event_dispatcher());
$user = new \phpbb\user('\phpbb\datetime');
$this->extension_manager = new \phpbb\extension\manager( $this->extension_manager = new \phpbb\extension\manager(
$container, $container,
$this->db, $this->db,
$this->config, $this->config,
new phpbb\filesystem\filesystem(), new phpbb\filesystem\filesystem(),
$user,
'phpbb_ext', 'phpbb_ext',
dirname(__FILE__) . '/../../phpBB/', dirname(__FILE__) . '/../../phpBB/',
'php', 'php',

View File

@@ -155,7 +155,6 @@ class phpbb_extension_manager_test extends phpbb_database_test_case
$phpbb_root_path = __DIR__ . './../../phpBB/'; $phpbb_root_path = __DIR__ . './../../phpBB/';
$php_ext = 'php'; $php_ext = 'php';
$table_prefix = 'phpbb_'; $table_prefix = 'phpbb_';
$user = new \phpbb\user('\phpbb\user');
$container = new phpbb_mock_container_builder(); $container = new phpbb_mock_container_builder();
@@ -178,7 +177,6 @@ class phpbb_extension_manager_test extends phpbb_database_test_case
$db, $db,
$config, $config,
new \phpbb\filesystem\filesystem(), new \phpbb\filesystem\filesystem(),
$user,
'phpbb_ext', 'phpbb_ext',
dirname(__FILE__) . '/', dirname(__FILE__) . '/',
$php_ext, $php_ext,

View File

@@ -99,7 +99,6 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
$this->db, $this->db,
$this->config, $this->config,
new \phpbb\filesystem\filesystem(), new \phpbb\filesystem\filesystem(),
$this->user,
'phpbb_ext', 'phpbb_ext',
$this->phpbb_root_path, $this->phpbb_root_path,
$this->phpEx, $this->phpEx,
@@ -120,7 +119,8 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
} }
catch (\phpbb\extension\exception $e) catch (\phpbb\extension\exception $e)
{ {
$this->assertEquals((string) $e, $this->user->lang('FILE_NOT_FOUND', $this->phpbb_root_path . $this->extension_manager->get_extension_path($ext_name) . 'composer.json')); $message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->assertEquals($message, $this->user->lang('FILE_NOT_FOUND', $this->phpbb_root_path . $this->extension_manager->get_extension_path($ext_name) . 'composer.json'));
} }
} }
@@ -137,7 +137,8 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
} }
catch (\phpbb\extension\exception $e) catch (\phpbb\extension\exception $e)
{ {
$this->fail($e); $message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->fail($message);
} }
$json = json_decode(file_get_contents($this->phpbb_root_path . 'ext/vendor2/foo/composer.json'), true); $json = json_decode(file_get_contents($this->phpbb_root_path . 'ext/vendor2/foo/composer.json'), true);
@@ -169,7 +170,8 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
} }
catch(\phpbb\extension\exception $e) catch(\phpbb\extension\exception $e)
{ {
$this->assertEquals((string) $e, $this->user->lang('META_FIELD_NOT_SET', $field_name)); $message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->assertEquals($message, $this->user->lang('META_FIELD_NOT_SET', $field_name));
} }
} }
@@ -183,7 +185,8 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
} }
catch (\phpbb\extension\exception $e) catch (\phpbb\extension\exception $e)
{ {
$this->assertEquals((string) $e, $this->user->lang('META_FIELD_NOT_SET', 'authors')); $message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->assertEquals($message, $this->user->lang('META_FIELD_NOT_SET', 'authors'));
} }
$manager->merge_metadata(array( $manager->merge_metadata(array(
@@ -199,7 +202,8 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
} }
catch (\phpbb\extension\exception $e) catch (\phpbb\extension\exception $e)
{ {
$this->assertEquals((string) $e, $this->user->lang('META_FIELD_NOT_SET', 'author name')); $message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->assertEquals($message, $this->user->lang('META_FIELD_NOT_SET', 'author name'));
} }
} }
@@ -232,7 +236,8 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
} }
catch(\phpbb\extension\exception $e) catch(\phpbb\extension\exception $e)
{ {
$this->assertEquals((string) $e, $this->user->lang('META_FIELD_INVALID', $field_name)); $message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->assertEquals($message, $this->user->lang('META_FIELD_INVALID', $field_name));
} }
} }
@@ -256,7 +261,8 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
} }
catch(\phpbb\extension\exception $e) catch(\phpbb\extension\exception $e)
{ {
$this->fail($e); $message = call_user_func_array(array($this->user, 'lang'), array_merge(array($e->getMessage()), $e->get_parameters()));
$this->fail($message);
} }
} }
@@ -352,7 +358,6 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case
$this->config, $this->config,
$this->extension_manager, $this->extension_manager,
$this->template, $this->template,
$this->user,
$this->phpbb_root_path $this->phpbb_root_path
); );
} }

View File

@@ -248,14 +248,12 @@ class phpbb_functional_test_case extends phpbb_test_case
); );
$container->set('migrator', $migrator); $container->set('migrator', $migrator);
$container->set('dispatcher', new phpbb_mock_event_dispatcher()); $container->set('dispatcher', new phpbb_mock_event_dispatcher());
$user = new \phpbb\user('\phpbb\datetime');
$extension_manager = new \phpbb\extension\manager( $extension_manager = new \phpbb\extension\manager(
$container, $container,
$db, $db,
$config, $config,
new phpbb\filesystem\filesystem(), new phpbb\filesystem\filesystem(),
$user,
self::$config['table_prefix'] . 'ext', self::$config['table_prefix'] . 'ext',
dirname(__FILE__) . '/', dirname(__FILE__) . '/',
$phpEx, $phpEx,