Skip to content
Snippets Groups Projects
Commit 0611d4d5 authored by Chris Gross's avatar Chris Gross
Browse files

7.x-1.13 Release Candidate 2

parent 56bc883d
No related branches found
Tags 7.x-1.13-rc2
No related merge requests found
Drupal 7.xx, xxxx-xx-xx (development version) Drupal 7.xx, xxxx-xx-xx (development version)
----------------------- -----------------------
Drupal 7.65, 2019-03-20
-----------------------
- Fixed security issues:
- SA-CORE-2019-004
Drupal 7.64, 2019-02-06 Drupal 7.64, 2019-02-06
----------------------- -----------------------
- [regression] Unset the 'host' header in drupal_http_request() during redirect - [regression] Unset the 'host' header in drupal_http_request() during redirect
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
/** /**
* The current system version. * The current system version.
*/ */
define('VERSION', '7.64'); define('VERSION', '7.65');
/** /**
* Core API compatibility. * Core API compatibility.
......
...@@ -997,8 +997,15 @@ function file_build_uri($path) { ...@@ -997,8 +997,15 @@ function file_build_uri($path) {
* @return * @return
* The destination filepath, or FALSE if the file already exists * The destination filepath, or FALSE if the file already exists
* and FILE_EXISTS_ERROR is specified. * and FILE_EXISTS_ERROR is specified.
*
* @throws RuntimeException
* Thrown if the filename contains invalid UTF-8.
*/ */
function file_destination($destination, $replace) { function file_destination($destination, $replace) {
$basename = drupal_basename($destination);
if (!drupal_validate_utf8($basename)) {
throw new RuntimeException(sprintf("Invalid filename '%s'", $basename));
}
if (file_exists($destination)) { if (file_exists($destination)) {
switch ($replace) { switch ($replace) {
case FILE_EXISTS_REPLACE: case FILE_EXISTS_REPLACE:
...@@ -1006,7 +1013,6 @@ function file_destination($destination, $replace) { ...@@ -1006,7 +1013,6 @@ function file_destination($destination, $replace) {
break; break;
case FILE_EXISTS_RENAME: case FILE_EXISTS_RENAME:
$basename = drupal_basename($destination);
$directory = drupal_dirname($destination); $directory = drupal_dirname($destination);
$destination = file_create_filename($basename, $directory); $destination = file_create_filename($basename, $directory);
break; break;
...@@ -1222,11 +1228,20 @@ function file_unmunge_filename($filename) { ...@@ -1222,11 +1228,20 @@ function file_unmunge_filename($filename) {
* @return * @return
* File path consisting of $directory and a unique filename based off * File path consisting of $directory and a unique filename based off
* of $basename. * of $basename.
*
* @throws RuntimeException
* Thrown if the $basename is not valid UTF-8 or another error occurs
* stripping control characters.
*/ */
function file_create_filename($basename, $directory) { function file_create_filename($basename, $directory) {
$original = $basename;
// Strip control characters (ASCII value < 32). Though these are allowed in // Strip control characters (ASCII value < 32). Though these are allowed in
// some filesystems, not many applications handle them well. // some filesystems, not many applications handle them well.
$basename = preg_replace('/[\x00-\x1F]/u', '_', $basename); $basename = preg_replace('/[\x00-\x1F]/u', '_', $basename);
if (preg_last_error() !== PREG_NO_ERROR) {
throw new RuntimeException(sprintf("Invalid filename '%s'", $original));
}
if (substr(PHP_OS, 0, 3) == 'WIN') { if (substr(PHP_OS, 0, 3) == 'WIN') {
// These characters are not allowed in Windows filenames // These characters are not allowed in Windows filenames
$basename = str_replace(array(':', '*', '?', '"', '<', '>', '|'), '_', $basename); $basename = str_replace(array(':', '*', '?', '"', '<', '>', '|'), '_', $basename);
...@@ -1567,7 +1582,13 @@ function file_save_upload($form_field_name, $validators = array(), $destination ...@@ -1567,7 +1582,13 @@ function file_save_upload($form_field_name, $validators = array(), $destination
if (substr($destination, -1) != '/') { if (substr($destination, -1) != '/') {
$destination .= '/'; $destination .= '/';
} }
$file->destination = file_destination($destination . $file->filename, $replace); try {
$file->destination = file_destination($destination . $file->filename, $replace);
}
catch (RuntimeException $e) {
drupal_set_message(t('The file %source could not be uploaded because the name is invalid.', array('%source' => $form_field_name)), 'error');
return FALSE;
}
// If file_destination() returns FALSE then $replace == FILE_EXISTS_ERROR and // If file_destination() returns FALSE then $replace == FILE_EXISTS_ERROR and
// there's an existing file so we need to bail. // there's an existing file so we need to bail.
if ($file->destination === FALSE) { if ($file->destination === FALSE) {
......
...@@ -957,6 +957,15 @@ class FileDirectoryTest extends FileTestCase { ...@@ -957,6 +957,15 @@ class FileDirectoryTest extends FileTestCase {
$path = file_create_filename($basename, $directory); $path = file_create_filename($basename, $directory);
$this->assertEqual($path, $expected, format_string('Creating a new filepath from %original equals %new.', array('%new' => $path, '%original' => $original)), 'File'); $this->assertEqual($path, $expected, format_string('Creating a new filepath from %original equals %new.', array('%new' => $path, '%original' => $original)), 'File');
try {
$filename = "a\xFFtest\x80€.txt";
file_create_filename($filename, $directory);
$this->fail('Expected exception not thrown');
}
catch (RuntimeException $e) {
$this->assertEqual("Invalid filename '$filename'", $e->getMessage());
}
// @TODO: Finally we copy a file into a directory several times, to ensure a properly iterating filename suffix. // @TODO: Finally we copy a file into a directory several times, to ensure a properly iterating filename suffix.
} }
...@@ -989,6 +998,14 @@ class FileDirectoryTest extends FileTestCase { ...@@ -989,6 +998,14 @@ class FileDirectoryTest extends FileTestCase {
$this->assertNotEqual($path, $destination, 'A new filepath destination is created when filepath destination already exists with FILE_EXISTS_RENAME.', 'File'); $this->assertNotEqual($path, $destination, 'A new filepath destination is created when filepath destination already exists with FILE_EXISTS_RENAME.', 'File');
$path = file_destination($destination, FILE_EXISTS_ERROR); $path = file_destination($destination, FILE_EXISTS_ERROR);
$this->assertEqual($path, FALSE, 'An error is returned when filepath destination already exists with FILE_EXISTS_ERROR.', 'File'); $this->assertEqual($path, FALSE, 'An error is returned when filepath destination already exists with FILE_EXISTS_ERROR.', 'File');
try {
file_destination("core/misc/a\xFFtest\x80€.txt", FILE_EXISTS_REPLACE);
$this->fail('Expected exception not thrown');
}
catch (RuntimeException $e) {
$this->assertEqual("Invalid filename 'a\xFFtest\x80€.txt'", $e->getMessage());
}
} }
/** /**
......
WCM Base 7.x-1.13-rc2, 2019-03-20
---------------------------------
- WCM Base: Updated Drupal core to 7.65 per SA-CORE-2019-004.
WCM Base 7.x-1.13-rc1, 2019-03-13 WCM Base 7.x-1.13-rc1, 2019-03-13
--------------------------------- ---------------------------------
- WCM Base: - WCM Base:
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment