diff options
-rw-r--r-- | engine/lib/filestore.php | 33 | ||||
-rw-r--r-- | engine/tests/objects/filestore.php | 2 |
2 files changed, 8 insertions, 27 deletions
diff --git a/engine/lib/filestore.php b/engine/lib/filestore.php index 92e8a760e..455d011d5 100644 --- a/engine/lib/filestore.php +++ b/engine/lib/filestore.php @@ -367,32 +367,13 @@ class ElggDiskFilestore extends ElggFilestore { * @return str */ protected function deprecated_file_matrix($filename) { - $invalid_fs_chars = '*\'\\/"!$%^&*.%(){}[]#~?<>;|¬`@-+='; - - $matrix = ""; - - $name = $filename; - $filename = $this->mb_str_split($filename); - if (!$filename) { - return false; - } - - $len = count($filename); - if ($len>$this->matrix_depth) { - $len = $this->matrix_depth; - } - - for ($n = 0; $n < $len; $n++) { - // Prevent a matrix being formed with unsafe characters - $char = $filename[$n]; - if (strpos($invalid_fs_chars, $char)!==false) { - $char = '_'; - } - - $matrix .= $char . "/"; - } - - return $matrix.$name."/"; + // throw a warning for using deprecated method + $error = 'Deprecated use of ElggDiskFilestore::make_file_matrix. '; + $error .= 'Username passed instead of guid.'; + elgg_log($error, WARNING); + + $user = new ElggUser($filename); + return $this->user_file_matrix($user->guid); } public function getParameters() { diff --git a/engine/tests/objects/filestore.php b/engine/tests/objects/filestore.php index 0a11c265b..a262a7c3f 100644 --- a/engine/tests/objects/filestore.php +++ b/engine/tests/objects/filestore.php @@ -52,7 +52,7 @@ class ElggCoreFilestoreTest extends ElggCoreUnitTest { // check matrix with username $user_dir = $this->filestore->make_file_matrix($user->username); - $this->assertIdentical($user_dir, "f/i/l/e/T/fileTest/"); + $this->assertIdentical($user_dir, "$created/$user->guid/"); // check matrix with guid $guid_dir = $this->filestore->make_file_matrix($user->guid); |