Skip to content

Commit

Permalink
More fixes to file upload
Browse files Browse the repository at this point in the history
  • Loading branch information
Vincent Petry authored and rullzer committed Sep 6, 2016
1 parent 9b4e9a7 commit 95e3183
Show file tree
Hide file tree
Showing 4 changed files with 72 additions and 23 deletions.
28 changes: 15 additions & 13 deletions apps/files/js/file-upload.js
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,14 @@ OC.FileUpload.prototype = {
this.data.headers['X-OC-Mtime'] = file.lastModified / 1000;
}

var userName = this.uploader.filesClient.getUserName();
var password = this.uploader.filesClient.getPassword();
if (userName) {
// copy username/password from DAV client
this.data.headers['Authorization'] =
'Basic ' + btoa(userName + ':' + (password || ''));
}

if (!this.uploader.isXHRUpload()) {
data.formData = [];

Expand All @@ -222,7 +230,7 @@ OC.FileUpload.prototype = {
&& this.getFile().size > this.uploader.fileUploadParam.maxChunkSize
) {
data.isChunked = true;
chunkFolderPromise = this.uploader.davClient.createDirectory(
chunkFolderPromise = this.uploader.filesClient.createDirectory(
'uploads/' + encodeURIComponent(OC.getCurrentUser().uid) + '/' + encodeURIComponent(this.getId())
);
// TODO: if fails, it means same id already existed, need to retry
Expand All @@ -248,7 +256,7 @@ OC.FileUpload.prototype = {
}

var uid = OC.getCurrentUser().uid;
return this.uploader.davClient.move(
return this.uploader.filesClient.move(
'uploads/' + encodeURIComponent(uid) + '/' + encodeURIComponent(this.getId()) + '/.file',
'files/' + encodeURIComponent(uid) + '/' + OC.joinPaths(this.getFullPath(), this.getFileName())
);
Expand All @@ -260,7 +268,7 @@ OC.FileUpload.prototype = {
abort: function() {
if (this.data.isChunked) {
// delete transfer directory for this upload
this.uploader.davClient.remove(
this.uploader.filesClient.remove(
'uploads/' + encodeURIComponent(OC.getCurrentUser().uid) + '/' + encodeURIComponent(this.getId())
);
}
Expand Down Expand Up @@ -343,7 +351,7 @@ OC.Uploader.prototype = _.extend({
/**
* @type Array<OC.FileUpload>
*/
_uploads: [],
_uploads: {},

/**
* List of directories known to exist.
Expand Down Expand Up @@ -586,7 +594,7 @@ OC.Uploader.prototype = _.extend({
onReplace:function(upload) {
this.log('replace', null, upload);
upload.setConflictMode(OC.FileUpload.CONFLICT_MODE_OVERWRITE);
upload.submit();
this.submitUploads([upload]);
},
/**
* handle uploading a file and letting the server decide a new name
Expand All @@ -595,7 +603,7 @@ OC.Uploader.prototype = _.extend({
onAutorename:function(upload) {
this.log('autorename', null, upload);
upload.setConflictMode(OC.FileUpload.CONFLICT_MODE_AUTORENAME);
upload.submit();
this.submitUploads([upload]);
},
_trace:false, //TODO implement log handler for JS per class?
log:function(caption, e, data) {
Expand Down Expand Up @@ -707,19 +715,13 @@ OC.Uploader.prototype = _.extend({

this.fileList = options.fileList;
this.filesClient = options.filesClient || OC.Files.getClient();
this.davClient = new OC.Files.Client({
host: OC.getHost(),
port: OC.getPort(),
root: OC.getRootPath() + '/remote.php/dav/',
useHTTPS: OC.getProtocol() === 'https'
});

$uploadEl = $($uploadEl);
this.$uploadEl = $uploadEl;

if ($uploadEl.exists()) {
$('#uploadprogresswrapper .stop').on('click', function() {
this.cancelUploads();
self.cancelUploads();
});

this.fileUploadParam = {
Expand Down
24 changes: 16 additions & 8 deletions apps/files/js/filelist.js
Original file line number Diff line number Diff line change
Expand Up @@ -2763,8 +2763,13 @@
if (OC.isSamePath(OC.dirname(upload.getFullPath() + '/'), self.getCurrentDirectory())) {
self._uploads[fileName] = fetchInfoPromise;
}

var uploadText = self.$fileList.find('tr .uploadtext');
self.showFileBusyState(uploadText.closest('tr'), false);
uploadText.fadeOut();
uploadText.attr('currentUploads', 0);
});
uploader.on('createdfolder', function(e, fullPath) {
uploader.on('createdfolder', function(fullPath) {
self.addAndFetchFileInfo(OC.basename(fullPath), OC.dirname(fullPath));
});
uploader.on('stop', function() {
Expand All @@ -2782,20 +2787,23 @@
self.highlightFiles(fileNames);
});
self.updateStorageStatistics();

var uploadText = self.$fileList.find('tr .uploadtext');
self.showFileBusyState(uploadText.closest('tr'), false);
uploadText.fadeOut();
uploadText.attr('currentUploads', 0);
});
uploader.on('fail', function(e, data) {
self._uploader.log('filelist handle fileuploadfail', e, data);

self._uploads = [];

//if user pressed cancel hide upload chrome
if (data.errorThrown === 'abort') {
//cleanup uploading to a dir
var uploadText = self.$fileList.find('tr .uploadtext');
self.showFileBusyState(uploadText.closest('tr'), false);
uploadText.fadeOut();
uploadText.attr('currentUploads', 0);
}
//cleanup uploading to a dir
var uploadText = self.$fileList.find('tr .uploadtext');
self.showFileBusyState(uploadText.closest('tr'), false);
uploadText.fadeOut();
uploadText.attr('currentUploads', 0);
self.updateStorageStatistics();
});

Expand Down
2 changes: 1 addition & 1 deletion apps/files/tests/js/filelistSpec.js
Original file line number Diff line number Diff line change
Expand Up @@ -2721,7 +2721,7 @@ describe('OCA.Files.FileList tests', function() {
it('fetches folder info', function() {
var fetchInfoStub = sinon.stub(fileList, 'addAndFetchFileInfo');

uploader.trigger('createdfolder', {}, '/subdir/newfolder');
uploader.trigger('createdfolder', '/subdir/newfolder');

expect(fetchInfoStub.calledOnce).toEqual(true);
expect(fetchInfoStub.getCall(0).args[0]).toEqual('newfolder');
Expand Down
41 changes: 40 additions & 1 deletion core/js/files/client.js
Original file line number Diff line number Diff line change
Expand Up @@ -718,8 +718,47 @@
*/
addFileInfoParser: function(parserFunction) {
this._fileInfoParsers.push(parserFunction);
}
},

/**
* Returns the dav.Client instance used internally
*
* @since 9.2
* @return {dav.Client}
*/
getClient: function() {
return this._client;
},

/**
* Returns the user name
*
* @since 9.2
* @return {String} userName
*/
getUserName: function() {
return this._client.userName;
},

/**
* Returns the password
*
* @since 9.2
* @return {String} password
*/
getPassword: function() {
return this._client.password;
},

/**
* Returns the base URL
*
* @since 9.2
* @return {String} base URL
*/
getBaseUrl: function() {
return this._client.baseUrl;
}
};

/**
Expand Down

0 comments on commit 95e3183

Please sign in to comment.