[ticket/13280] Only run sanitizer for server superglobal and modify tests

PHPBB3-13280
This commit is contained in:
Marc Alexander 2014-11-04 16:54:45 +01:00
parent 3986470b3c
commit 32881dbe31
2 changed files with 9 additions and 4 deletions

View file

@ -31,7 +31,8 @@ class symfony_request extends Request
}; };
// This function is meant for additional handling of server variables // This function is meant for additional handling of server variables
$server_sanitizer = function(&$value, $key) { $server_sanitizer = function(&$value, $key) use ($sanitizer) {
$sanitizer($value, $key);
$value = str_replace('&', '&', $value); $value = str_replace('&', '&', $value);
}; };
@ -43,11 +44,10 @@ class symfony_request extends Request
array_walk_recursive($get_parameters, $sanitizer); array_walk_recursive($get_parameters, $sanitizer);
array_walk_recursive($post_parameters, $sanitizer); array_walk_recursive($post_parameters, $sanitizer);
array_walk_recursive($server_parameters, $sanitizer);
array_walk_recursive($files_parameters, $sanitizer); array_walk_recursive($files_parameters, $sanitizer);
array_walk_recursive($cookie_parameters, $sanitizer); array_walk_recursive($cookie_parameters, $sanitizer);
// Run additional sanitizer for server superglobal // Run special sanitizer for server superglobal
array_walk_recursive($server_parameters, $server_sanitizer); array_walk_recursive($server_parameters, $server_sanitizer);
parent::__construct($get_parameters, $post_parameters, array(), $cookie_parameters, $files_parameters, $server_parameters); parent::__construct($get_parameters, $post_parameters, array(), $cookie_parameters, $files_parameters, $server_parameters);

View file

@ -84,8 +84,13 @@ class phpbb_security_extract_current_page_test extends phpbb_security_test_base
protected function sanitizer($value) protected function sanitizer($value)
{ {
$type_cast_helper = new \phpbb\request\type_cast_helper(); // Fix for objects passed in phpunit
$type_cast_helper->set_var($value, $value, gettype($value), true); if (is_object($value))
{
return $value; return $value;
} }
$type_cast_helper = new \phpbb\request\type_cast_helper();
$type_cast_helper->set_var($value, $value, gettype($value), true);
return str_replace('&', '&', $value);
}
} }