aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engine/lib/filestore.php33
-rw-r--r--engine/tests/objects/filestore.php2
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);