From cc4001fce7934b49e6e7888a602b9bb9c33cf37f Mon Sep 17 00:00:00 2001 From: tuscanhobbit Date: Tue, 24 Jun 2014 12:05:11 +0200 Subject: Fixes to links and forward URLs in filestorage --- include/attach.php | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) (limited to 'include/attach.php') diff --git a/include/attach.php b/include/attach.php index a3ee3f0ef..bf58566fe 100644 --- a/include/attach.php +++ b/include/attach.php @@ -834,6 +834,45 @@ function get_cloudpath($arr) { return $path; } +function get_parent_cloudpath($channel_id, $channel_name, $attachHash) { + //Build directory tree and redirect + $parentHash = $attachHash; + do { + $parentHash = findFolderHashByAttachHash($channel_id, $parentHash); + if ($parentHash) { + $parentName = findFilenameByHash($channel_id, $parentHash); + $parentFullPath = $parentName."/".$parentFullPath; + } + } while ($parentHash); + $parentFullPath = z_root() . "/cloud/" . $channel_name . "/" . $parentFullPath; + goaway($parentFullPath); +} +function findFolderHashByAttachHash($channel_id, $attachHash) { + $r = q("select * from attach where uid = %d and hash = '%s' limit 1", + intval($channel_id), dbesc($attachHash) + ); + $hash = ""; + if($r) { + foreach($r as $rr) { + $hash = $rr['folder']; + } + } + return $hash; +} +function findFilenameByHash($channel_id, $attachHash) { + $r = q("select * from attach where uid = %d and hash = '%s' limit 1", + intval($channel_id), dbesc($attachHash) + ); + $filename = ""; + if($r) { + foreach($r as $rr) { + $filename = $rr['filename']; + } + } + return $filename; +} + + /** * * @param $in -- cgit v1.2.3 From 4c78c3bdee5ac6c70f4de7886734e6ef06b37a26 Mon Sep 17 00:00:00 2001 From: tuscanhobbit Date: Tue, 24 Jun 2014 12:13:54 +0200 Subject: Oops I left some debug stuff around --- include/attach.php | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) (limited to 'include/attach.php') diff --git a/include/attach.php b/include/attach.php index bf58566fe..f5eaaa448 100644 --- a/include/attach.php +++ b/include/attach.php @@ -834,20 +834,26 @@ function get_cloudpath($arr) { return $path; } +/** + * @brief Returns path to parent folder in cloud/. + * + * @param $arr + * @return string with the folder path + */ function get_parent_cloudpath($channel_id, $channel_name, $attachHash) { //Build directory tree and redirect $parentHash = $attachHash; do { - $parentHash = findFolderHashByAttachHash($channel_id, $parentHash); + $parentHash = find_folder_hash_by_attach_hash($channel_id, $parentHash); if ($parentHash) { - $parentName = findFilenameByHash($channel_id, $parentHash); + $parentName = find_filename_by_hash($channel_id, $parentHash); $parentFullPath = $parentName."/".$parentFullPath; } } while ($parentHash); $parentFullPath = z_root() . "/cloud/" . $channel_name . "/" . $parentFullPath; - goaway($parentFullPath); + return $parentFullPath; } -function findFolderHashByAttachHash($channel_id, $attachHash) { +function find_folder_hash_by_attach_hash($channel_id, $attachHash) { $r = q("select * from attach where uid = %d and hash = '%s' limit 1", intval($channel_id), dbesc($attachHash) ); @@ -859,7 +865,7 @@ function findFolderHashByAttachHash($channel_id, $attachHash) { } return $hash; } -function findFilenameByHash($channel_id, $attachHash) { +function find_filename_by_hash($channel_id, $attachHash) { $r = q("select * from attach where uid = %d and hash = '%s' limit 1", intval($channel_id), dbesc($attachHash) ); -- cgit v1.2.3