[ticket/13192] Add method for generating valid user page links

PHPBB3-13192
This commit is contained in:
Marc Alexander 2014-10-21 22:16:53 -05:00
parent e43d1781bf
commit 40497ec824
2 changed files with 52 additions and 0 deletions

View file

@ -445,4 +445,35 @@ class path_helper
return $url_parts['base'] . (($params) ? '?' . $this->glue_url_params($params) : '');
}
/**
* Get a valid user page
*
* @param string $user_page The current user page
* @param bool $mod_rewrite Whether mod_rewrite is enabled, default: false
*
* @return string A valid user page based on user page and mod_rewrite
*/
public function get_valid_user_page($user_page, $mod_rewrite = false)
{
// We need to be cautious here.
// On some situations, the redirect path is an absolute URL, sometimes a relative path
// For a relative path, let's prefix it with $phpbb_root_path to point to the correct location,
// else we use the URL directly.
$url_parts = parse_url($user_page);
// URL
if ($url_parts === false || empty($url_parts['scheme']) || empty($url_parts['host']))
{
// Remove 'app.php/' from the page, when rewrite is enabled
if ($mod_rewrite && strpos($user_page, 'app.' . $this->php_ext . '/') === 0)
{
$user_page = substr($user_page, strlen('app.' . $this->php_ext . '/'));
}
$user_page = $this->get_phpbb_root_path() . $user_page;
}
return $user_page;
}
}

View file

@ -421,4 +421,25 @@ class phpbb_path_helper_test extends phpbb_test_case
{
$this->assertEquals($this->phpbb_root_path . $expected, $this->path_helper->get_web_root_path_from_ajax_referer($referer_url, $board_url));
}
public function data_get_valid_user_page()
{
return array(
// array( current page , mod_rewrite setting , expected output )
array('index', true, 'index'),
array('index', false, 'index'),
array('foo/index', true, 'foo/index'),
array('foo/index', false, 'foo/index'),
array('app.php/foo', false, 'app.php/foo'),
array('app.php/foo', true, 'foo'),
);
}
/**
* @dataProvider data_get_valid_user_page
*/
public function test_get_valid_user_page($page, $mod_rewrite, $expected)
{
$this->assertEquals($this->phpbb_root_path . $expected, $this->path_helper->get_valid_user_page($page, $mod_rewrite));
}
}