mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-11 05:48:51 +00:00
[ticket/11768] Added core.text_formatter_s9e_renderer_setup event
PHPBB3-11768
This commit is contained in:
parent
c891881321
commit
af4f9b860f
4 changed files with 61 additions and 6 deletions
|
@ -52,6 +52,7 @@ services:
|
||||||
- %text_formatter.cache.dir%
|
- %text_formatter.cache.dir%
|
||||||
- %text_formatter.cache.renderer.key%
|
- %text_formatter.cache.renderer.key%
|
||||||
- @text_formatter.s9e.factory
|
- @text_formatter.s9e.factory
|
||||||
|
- @dispatcher
|
||||||
calls:
|
calls:
|
||||||
- [configure_smilies_path, [@config, @path_helper]]
|
- [configure_smilies_path, [@config, @path_helper]]
|
||||||
- [configure_user, [@user, @config, @auth]]
|
- [configure_user, [@user, @config, @auth]]
|
||||||
|
|
|
@ -23,6 +23,11 @@ class renderer implements \phpbb\textformatter\renderer_interface
|
||||||
*/
|
*/
|
||||||
protected $censor;
|
protected $censor;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \phpbb\event\dispatcher_interface
|
||||||
|
*/
|
||||||
|
protected $dispatcher;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var \s9e\TextFormatter\Renderer
|
* @var \s9e\TextFormatter\Renderer
|
||||||
*/
|
*/
|
||||||
|
@ -55,8 +60,9 @@ class renderer implements \phpbb\textformatter\renderer_interface
|
||||||
* @param string $cache_dir Path to the cache dir
|
* @param string $cache_dir Path to the cache dir
|
||||||
* @param string $key Cache key
|
* @param string $key Cache key
|
||||||
* @param factory $factory
|
* @param factory $factory
|
||||||
|
* @param \phpbb\event\dispatcher_interface $dispatcher
|
||||||
*/
|
*/
|
||||||
public function __construct(\phpbb\cache\driver\driver_interface $cache, $cache_dir, $key, factory $factory)
|
public function __construct(\phpbb\cache\driver\driver_interface $cache, $cache_dir, $key, factory $factory, \phpbb\event\dispatcher_interface $dispatcher)
|
||||||
{
|
{
|
||||||
$renderer_data = $cache->get($key);
|
$renderer_data = $cache->get($key);
|
||||||
if ($renderer_data)
|
if ($renderer_data)
|
||||||
|
@ -81,18 +87,29 @@ class renderer implements \phpbb\textformatter\renderer_interface
|
||||||
$censor = $renderer_data['censor'];
|
$censor = $renderer_data['censor'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!isset($renderer))
|
if (!isset($renderer))
|
||||||
{
|
{
|
||||||
$objects = $factory->regenerate();
|
$objects = $factory->regenerate();
|
||||||
$renderer = $objects['renderer'];
|
$renderer = $objects['renderer'];
|
||||||
}
|
}
|
||||||
|
$self = $this;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configure the renderer service
|
||||||
|
*
|
||||||
|
* @event core.text_formatter_s9e_renderer_setup
|
||||||
|
* @var \s9e\TextFormatter\Renderer renderer s9e\TextFormatter renderer instance
|
||||||
|
* @var \phpbb\textformatter\s9e\renderer self This renderer service
|
||||||
|
* @since 3.2.0-a1
|
||||||
|
*/
|
||||||
|
$vars = array('renderer', 'self');
|
||||||
|
extract($dispatcher->trigger_event('core.text_formatter_s9e_renderer_setup', compact($vars)));
|
||||||
|
|
||||||
if (isset($censor))
|
if (isset($censor))
|
||||||
{
|
{
|
||||||
$this->censor = $censor;
|
$this->censor = $censor;
|
||||||
}
|
}
|
||||||
|
$this->dispatcher = $dispatcher;
|
||||||
$this->renderer = $renderer;
|
$this->renderer = $renderer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -426,6 +426,7 @@ class phpbb_test_case_helpers
|
||||||
$cache_key_parser = $prefix . '_parser';
|
$cache_key_parser = $prefix . '_parser';
|
||||||
$cache_key_renderer = $prefix . '_renderer';
|
$cache_key_renderer = $prefix . '_renderer';
|
||||||
$container->set('cache.driver', $cache);
|
$container->set('cache.driver', $cache);
|
||||||
|
$container->setParameter('cache.dir', $cache_dir);
|
||||||
|
|
||||||
// Create a path_helper
|
// Create a path_helper
|
||||||
if (!$container->has('path_helper'))
|
if (!$container->has('path_helper'))
|
||||||
|
@ -500,7 +501,8 @@ class phpbb_test_case_helpers
|
||||||
$cache,
|
$cache,
|
||||||
$cache_dir,
|
$cache_dir,
|
||||||
$cache_key_renderer,
|
$cache_key_renderer,
|
||||||
$factory
|
$factory,
|
||||||
|
$dispatcher
|
||||||
);
|
);
|
||||||
|
|
||||||
$config = ($container->has('config'))
|
$config = ($container->has('config'))
|
||||||
|
|
|
@ -43,7 +43,8 @@ class phpbb_textformatter_s9e_renderer_test extends phpbb_test_case
|
||||||
$cache,
|
$cache,
|
||||||
$this->get_cache_dir(),
|
$this->get_cache_dir(),
|
||||||
'_foo_renderer',
|
'_foo_renderer',
|
||||||
$factory
|
$factory,
|
||||||
|
new phpbb_mock_event_dispatcher
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,7 +69,8 @@ class phpbb_textformatter_s9e_renderer_test extends phpbb_test_case
|
||||||
$cache,
|
$cache,
|
||||||
$this->get_cache_dir(),
|
$this->get_cache_dir(),
|
||||||
'_foo_renderer',
|
'_foo_renderer',
|
||||||
$factory
|
$factory,
|
||||||
|
new phpbb_mock_event_dispatcher
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -354,4 +356,37 @@ class phpbb_textformatter_s9e_renderer_test extends phpbb_test_case
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @testdox The constructor triggers a core.text_formatter_s9e_renderer_setup event
|
||||||
|
*/
|
||||||
|
public function test_setup_event()
|
||||||
|
{
|
||||||
|
$container = $this->get_test_case_helpers()->set_s9e_services();
|
||||||
|
$dispatcher = $this->getMock('phpbb\\event\\dispatcher_interface');
|
||||||
|
$dispatcher
|
||||||
|
->expects($this->once())
|
||||||
|
->method('trigger_event')
|
||||||
|
->with(
|
||||||
|
'core.text_formatter_s9e_renderer_setup',
|
||||||
|
$this->callback(array($this, 'setup_event_callback'))
|
||||||
|
)
|
||||||
|
->will($this->returnArgument(1));
|
||||||
|
|
||||||
|
new \phpbb\textformatter\s9e\renderer(
|
||||||
|
$container->get('cache.driver'),
|
||||||
|
$container->getParameter('cache.dir'),
|
||||||
|
'_foo_renderer',
|
||||||
|
$container->get('text_formatter.s9e.factory'),
|
||||||
|
$dispatcher
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setup_event_callback($vars)
|
||||||
|
{
|
||||||
|
return isset($vars['renderer'])
|
||||||
|
&& $vars['renderer'] instanceof \s9e\TextFormatter\Renderer
|
||||||
|
&& isset($vars['self'])
|
||||||
|
&& $vars['self'] instanceof \phpbb\textformatter\s9e\renderer;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue