diff options
author | Morris Jobke <hey@morrisjobke.de> | 2014-06-20 19:01:05 +0200 |
---|---|---|
committer | Morris Jobke <hey@morrisjobke.de> | 2014-06-20 19:01:05 +0200 |
commit | d5819a5ecd26d4c7753f9c9fd0805ef83419cb0a (patch) | |
tree | 74053766aefc5e7b2a0a96c60050aef1581de95a /apps | |
parent | ca96b9d3d5197da9d2686c8fe8e0cdcc2fbfa800 (diff) | |
parent | 8ae2468345d5c5a090098a7477121f71992abaa0 (diff) | |
download | nextcloud-server-d5819a5ecd26d4c7753f9c9fd0805ef83419cb0a.tar.gz nextcloud-server-d5819a5ecd26d4c7753f9c9fd0805ef83419cb0a.zip |
Merge pull request #9108 from owncloud/uploadintofolderfix
Fix many issues with drag and drop upload
Diffstat (limited to 'apps')
-rw-r--r-- | apps/files/ajax/upload.php | 40 | ||||
-rw-r--r-- | apps/files/js/file-upload.js | 2 | ||||
-rw-r--r-- | apps/files/js/filelist.js | 58 | ||||
-rw-r--r-- | apps/files/tests/js/filelistSpec.js | 26 | ||||
-rw-r--r-- | apps/files_sharing/js/public.js | 2 |
5 files changed, 59 insertions, 69 deletions
diff --git a/apps/files/ajax/upload.php b/apps/files/ajax/upload.php index 9750173d110..f9fcfaf13c5 100644 --- a/apps/files/ajax/upload.php +++ b/apps/files/ajax/upload.php @@ -26,7 +26,7 @@ if (empty($_POST['dirToken'])) { // return only read permissions for public upload $allowedPermissions = OCP\PERMISSION_READ; - $public_directory = !empty($_POST['subdir']) ? $_POST['subdir'] : '/'; + $publicDirectory = !empty($_POST['subdir']) ? $_POST['subdir'] : '/'; $linkItem = OCP\Share::getShareByToken($_POST['dirToken']); if ($linkItem === false) { @@ -50,13 +50,15 @@ if (empty($_POST['dirToken'])) { $dir = sprintf( "/%s/%s", $path, - $public_directory + $publicDirectory ); if (!$dir || empty($dir) || $dir === false) { OCP\JSON::error(array('data' => array_merge(array('message' => $l->t('Unable to set upload directory.'))))); die(); } + + $dir = rtrim($dir, '/'); } } @@ -113,33 +115,33 @@ if ($maxUploadFileSize >= 0 and $totalSize > $maxUploadFileSize) { } $result = array(); -$directory = ''; if (strpos($dir, '..') === false) { $fileCount = count($files['name']); for ($i = 0; $i < $fileCount; $i++) { - // Get the files directory - if(isset($_POST['file_directory']) === true) { - $directory = '/'.$_POST['file_directory']; + // target directory for when uploading folders + $relativePath = ''; + if(!empty($_POST['file_directory'])) { + $relativePath = '/'.$_POST['file_directory']; } // $path needs to be normalized - this failed within drag'n'drop upload to a sub-folder if (isset($_POST['resolution']) && $_POST['resolution']==='autorename') { // append a number in brackets like 'filename (2).ext' - $target = OCP\Files::buildNotExistingFileName(stripslashes($dir.$directory), $files['name'][$i]); + $target = OCP\Files::buildNotExistingFileName(stripslashes($dir . $relativePath), $files['name'][$i]); } else { - $target = \OC\Files\Filesystem::normalizePath(stripslashes($dir.$directory).'/'.$files['name'][$i]); + $target = \OC\Files\Filesystem::normalizePath(stripslashes($dir . $relativePath).'/'.$files['name'][$i]); } - - if(empty($directory) === true) - { - $directory = \OC\Files\Filesystem::normalizePath(stripslashes($dir)); - if (isset($public_directory)) { - // If we are uploading from the public app, - // we want to send the relative path in the ajax request. - $directory = $public_directory; - } + + // relative dir to return to the client + if (isset($publicDirectory)) { + // path relative to the public root + $returnedDir = $publicDirectory . $relativePath; + } else { + // full path + $returnedDir = $dir . $relativePath; } + $returnedDir = \OC\Files\Filesystem::normalizePath($returnedDir); if ( ! \OC\Files\Filesystem::file_exists($target) || (isset($_POST['resolution']) && $_POST['resolution']==='replace') @@ -163,7 +165,7 @@ if (strpos($dir, '..') === false) { $data['uploadMaxFilesize'] = $maxUploadFileSize; $data['maxHumanFilesize'] = $maxHumanFileSize; $data['permissions'] = $meta['permissions'] & $allowedPermissions; - $data['directory'] = $directory; + $data['directory'] = $returnedDir; $result[] = $data; } @@ -187,7 +189,7 @@ if (strpos($dir, '..') === false) { $data['uploadMaxFilesize'] = $maxUploadFileSize; $data['maxHumanFilesize'] = $maxHumanFileSize; $data['permissions'] = $meta['permissions'] & $allowedPermissions; - $data['directory'] = $directory; + $data['directory'] = $returnedDir; $result[] = $data; } } diff --git a/apps/files/js/file-upload.js b/apps/files/js/file-upload.js index 6b0ca793681..da58e1c31b8 100644 --- a/apps/files/js/file-upload.js +++ b/apps/files/js/file-upload.js @@ -346,7 +346,7 @@ OC.Upload = { // noone set update parameters, we set the minimum data.formData = { requesttoken: oc_requesttoken, - dir: FileList.getCurrentDirectory(), + dir: data.targetDir || FileList.getCurrentDirectory(), file_directory: fileDirectory }; } diff --git a/apps/files/js/filelist.js b/apps/files/js/filelist.js index 85c5d3f1bb0..241997be2bc 100644 --- a/apps/files/js/filelist.js +++ b/apps/files/js/filelist.js @@ -1561,17 +1561,12 @@ dir = dropTarget.data('dir') || '/'; } - // update folder in form - data.formData = function() { - return [ - {name: 'dir', value: dir}, - {name: 'requesttoken', value: oc_requesttoken}, - {name: 'file_directory', value: data.files[0].relativePath} - ]; - }; + // add target dir + data.targetDir = dir; } else { // we are dropping somewhere inside the file list, which will // upload the file to the current directory + data.targetDir = self.getCurrentDirectory(); // cancel uploads to current dir if no permission var isCreatable = (self.getDirectoryPermissions() & OC.PERMISSION_CREATE) !== 0; @@ -1654,15 +1649,34 @@ data.context.find('td.filesize').text(humanFileSize(size)); } else { // only append new file if uploaded into the current folder - if (file.directory !== '/' && file.directory !== self.getCurrentDirectory()) { + if (file.directory !== self.getCurrentDirectory()) { + // Uploading folders actually uploads a list of files + // for which the target directory (file.directory) might lie deeper + // than the current directory + + var fileDirectory = file.directory.replace('/','').replace(/\/$/, ""); + var currentDirectory = self.getCurrentDirectory().replace('/','').replace(/\/$/, "") + '/'; + + if (currentDirectory !== '/') { + // abort if fileDirectory does not start with current one + if (fileDirectory.indexOf(currentDirectory) !== 0) { + return; + } + + // remove the current directory part + fileDirectory = fileDirectory.substr(currentDirectory.length); + } - var fileDirectory = file.directory.replace('/','').replace(/\/$/, "").split('/'); + // only take the first section of the path + fileDirectory = fileDirectory.split('/'); - if (fileDirectory.length === 1) { + var fd; + // if the first section exists / is a subdir + if (fileDirectory.length) { fileDirectory = fileDirectory[0]; - // Get the directory - var fd = self.findFileEl(fileDirectory); + // See whether it is already in the list + fd = self.findFileEl(fileDirectory); if (fd.length === 0) { var dir = { name: fileDirectory, @@ -1672,19 +1686,15 @@ size: 0, id: file.parentId }; - self.add(dir, {insert: true}); + fd = self.add(dir, {insert: true}); } - } else { - fileDirectory = fileDirectory[0]; - } - fileDirectory = self.findFileEl(fileDirectory); - - // update folder size - size = parseInt(fileDirectory.attr('data-size'), 10); - size += parseInt(file.size, 10); - fileDirectory.attr('data-size', size); - fileDirectory.find('td.filesize').text(humanFileSize(size)); + // update folder size + size = parseInt(fd.attr('data-size'), 10); + size += parseInt(file.size, 10); + fd.attr('data-size', size); + fd.find('td.filesize').text(OC.Util.humanFileSize(size)); + } return; } diff --git a/apps/files/tests/js/filelistSpec.js b/apps/files/tests/js/filelistSpec.js index 7d3bc946dd3..011e73d4b30 100644 --- a/apps/files/tests/js/filelistSpec.js +++ b/apps/files/tests/js/filelistSpec.js @@ -1730,20 +1730,6 @@ describe('OCA.Files.FileList tests', function() { return ev; } - /** - * Convert form data to a flat list - * - * @param formData form data array as used by jquery.upload - * @return map based on the array's key values - */ - function decodeFormData(data) { - var map = {}; - _.each(data.formData(), function(entry) { - map[entry.name] = entry.value; - }); - return map; - } - beforeEach(function() { // simulate data structure from jquery.upload uploadData = { @@ -1803,11 +1789,7 @@ describe('OCA.Files.FileList tests', function() { ev = dropOn(fileList.findFileEl('somedir').find('td:eq(2)'), uploadData); expect(ev.result).not.toEqual(false); - expect(uploadData.formData).toBeDefined(); - formData = decodeFormData(uploadData); - expect(formData.dir).toEqual('/subdir/somedir'); - expect(formData.file_directory).toEqual('fileToUpload.txt'); - expect(formData.requesttoken).toBeDefined(); + expect(uploadData.targetDir).toEqual('/subdir/somedir'); }); it('drop on a breadcrumb inside the table triggers upload to target folder', function() { var ev, formData; @@ -1815,11 +1797,7 @@ describe('OCA.Files.FileList tests', function() { ev = dropOn(fileList.$el.find('.crumb:eq(2)'), uploadData); expect(ev.result).not.toEqual(false); - expect(uploadData.formData).toBeDefined(); - formData = decodeFormData(uploadData); - expect(formData.dir).toEqual('/a/b'); - expect(formData.file_directory).toEqual('fileToUpload.txt'); - expect(formData.requesttoken).toBeDefined(); + expect(uploadData.targetDir).toEqual('/a/b'); }); }); }); diff --git a/apps/files_sharing/js/public.js b/apps/files_sharing/js/public.js index 80631908d24..1d633a655d5 100644 --- a/apps/files_sharing/js/public.js +++ b/apps/files_sharing/js/public.js @@ -128,7 +128,7 @@ OCA.Sharing.PublicApp = { data.formData = { requesttoken: $('#publicUploadRequestToken').val(), dirToken: $('#dirToken').val(), - subdir: self.fileList.getCurrentDirectory(), + subdir: data.targetDir || self.fileList.getCurrentDirectory(), file_directory: fileDirectory }; }); |