mirror of
https://github.com/phpbb/phpbb.git
synced 2025-05-12 10:35:20 +02:00
I had forgotten that the container sends the same instance of objects to all services that request it, so in this case all controllers would share the same base url path, which is not desired. PHPBB3-10864
118 lines
2.6 KiB
PHP
118 lines
2.6 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* @package controller
|
|
* @copyright (c) 2012 phpBB Group
|
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
|
*
|
|
*/
|
|
|
|
/**
|
|
* @ignore
|
|
*/
|
|
if (!defined('IN_PHPBB'))
|
|
{
|
|
exit;
|
|
}
|
|
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
/**
|
|
* Controller helper class, contains methods that do things for controllers
|
|
* @package phpBB3
|
|
*/
|
|
class phpbb_controller_helper
|
|
{
|
|
/**
|
|
* Template object
|
|
* @var phpbb_template
|
|
*/
|
|
protected $template;
|
|
|
|
/**
|
|
* User object
|
|
* @var phpbb_user
|
|
*/
|
|
protected $user;
|
|
|
|
/**
|
|
* phpBB root path
|
|
* @var string
|
|
*/
|
|
protected $root_path;
|
|
|
|
/**
|
|
* PHP extension
|
|
* @var string
|
|
*/
|
|
protected $php_ext;
|
|
|
|
/**
|
|
* Constructor
|
|
*
|
|
* @param phpbb_template $template Template object
|
|
* @param phpbb_user $user User object
|
|
* @param string $root_path phpBB root path
|
|
* @param string $php_ext PHP extension
|
|
*/
|
|
public function __construct(phpbb_template $template, phpbb_user $user, $root_path, $php_ext)
|
|
{
|
|
$this->template = $template;
|
|
$this->user = $user;
|
|
$this->root_path = $root_path;
|
|
$this->php_ext = $php_ext;
|
|
}
|
|
|
|
/**
|
|
* Automate setting up the page and creating the response object.
|
|
*
|
|
* @param string $handle The template handle to render
|
|
* @param string $page_title The title of the page to output
|
|
* @param int $status_code The status code to be sent to the page header
|
|
* @return Response object containing rendered page
|
|
*/
|
|
public function render($template_file, $page_title = '', $status_code = 200)
|
|
{
|
|
page_header($page_title);
|
|
|
|
$this->template->set_filenames(array(
|
|
'body' => $template_file,
|
|
));
|
|
|
|
page_footer(true, false, false);
|
|
|
|
return new Response($this->template->assign_display('body'), $status_code);
|
|
}
|
|
|
|
/**
|
|
* Easily generate a URL
|
|
*
|
|
* @param array $url_parts Each array element is a 'folder'
|
|
* i.e. array('my', 'ext') maps to ./app.php/my/ext
|
|
* @param mixed $query The Query string, passed directly into the second
|
|
* argument of append_sid()
|
|
* @return string A URL that has already been run through append_sid()
|
|
*/
|
|
public function url(array $url_parts, $query = '')
|
|
{
|
|
return append_sid($this->root_path . implode('/', $url_parts), $query);
|
|
}
|
|
|
|
/**
|
|
* Output an error, effectively the same thing as trigger_error
|
|
*
|
|
* @param string $code The error code (e.g. 404, 500, 503, etc.)
|
|
* @param string $message The error message
|
|
* @return Response A Reponse instance
|
|
*/
|
|
public function error($code = 500, $message = '')
|
|
{
|
|
$this->template->assign_vars(array(
|
|
'MESSAGE_TEXT' => $message,
|
|
'MESSAGE_TITLE' => $this->user->lang('INFORMATION'),
|
|
));
|
|
|
|
return $this->render('message_body.html', $this->user->lang('INFORMATION'), $code);
|
|
}
|
|
}
|