diff options
author | icewind1991 <robin@icewind.nl> | 2014-07-04 16:39:00 +0200 |
---|---|---|
committer | icewind1991 <robin@icewind.nl> | 2014-07-04 16:39:00 +0200 |
commit | d3fab824f7052a8df400890833a0f6743769422c (patch) | |
tree | eb04908d6deb044ab6fd2f73030efce561efeaf2 /apps | |
parent | 5e89b53e78240cf3eee02db02ae5c409dc1bcc1f (diff) | |
parent | 4fe1cdd2a7a1930d8ca0cb5bc23e5bfa22be6e55 (diff) | |
download | nextcloud-server-d3fab824f7052a8df400890833a0f6743769422c.tar.gz nextcloud-server-d3fab824f7052a8df400890833a0f6743769422c.zip |
Merge pull request #9445 from owncloud/filelist-auth-error
Reload the page when the files app encounters an authentication error
Diffstat (limited to 'apps')
-rw-r--r-- | apps/files/js/filelist.js | 11 | ||||
-rw-r--r-- | apps/files/tests/js/filelistSpec.js | 26 |
2 files changed, 35 insertions, 2 deletions
diff --git a/apps/files/js/filelist.js b/apps/files/js/filelist.js index 9c6d31ee017..3e311655c91 100644 --- a/apps/files/js/filelist.js +++ b/apps/files/js/filelist.js @@ -947,6 +947,13 @@ this.hideMask(); if (!result || result.status === 'error') { + // if the error is not related to folder we're trying to load, reload the page to handle logout etc + if (result.data.error === 'authentication_error' || + result.data.error === 'token_expired' || + result.data.error === 'application_not_enabled' + ) { + OC.redirect(OC.generateUrl('apps/files')); + } OC.Notification.show(result.data.message); return false; } @@ -970,7 +977,7 @@ } this.setFiles(result.data.files); - return true + return true; }, updateStorageStatistics: function(force) { @@ -1568,7 +1575,7 @@ numMatch=base.match(/\((\d+)\)/); var num=2; if (numMatch && numMatch.length>0) { - num=parseInt(numMatch[numMatch.length-1])+1; + num=parseInt(numMatch[numMatch.length-1], 10)+1; base=base.split('('); base.pop(); base=$.trim(base.join('(')); diff --git a/apps/files/tests/js/filelistSpec.js b/apps/files/tests/js/filelistSpec.js index 713cd5468d8..ae22ae0123e 100644 --- a/apps/files/tests/js/filelistSpec.js +++ b/apps/files/tests/js/filelistSpec.js @@ -1933,4 +1933,30 @@ describe('OCA.Files.FileList tests', function() { }); }); }); + describe('Handeling errors', function () { + beforeEach(function () { + redirectStub = sinon.stub(OC, 'redirect'); + + fileList = new OCA.Files.FileList($('#app-content-files')); + }); + afterEach(function () { + fileList = undefined; + + redirectStub.restore(); + }); + it('reloads the page on authentication errors', function () { + fileList.reload(); + fakeServer.requests[0].respond( + 200, + { 'Content-Type': 'application/json' }, + JSON.stringify({ + status: 'error', + data: { + 'error': 'authentication_error' + } + }) + ); + expect(redirectStub.calledWith(OC.generateUrl('apps/files'))).toEqual(true); + }); + }); }); |