From baf9138b272ae3f51486d9e517adade07d55b80c Mon Sep 17 00:00:00 2001 From: Jason Williams Date: Thu, 31 Jul 2014 13:41:10 +0000 Subject: [PATCH] Update user roles in store after owner transfer Closes #3466 - Transferring the owner role is now done via a separate endpoint and not through Ember-Data. As a result the user role data needs to be updated manually. - Updated the owner endpoint to return a response body containing the updated user objects. - Updated tests. --- core/client/controllers/modals/transfer-owner.js | 13 ++++++++++++- core/server/api/users.js | 4 ++-- core/server/models/user.js | 6 ++++++ core/test/integration/api/api_users_spec.js | 12 +++++++----- 4 files changed, 27 insertions(+), 8 deletions(-) diff --git a/core/client/controllers/modals/transfer-owner.js b/core/client/controllers/modals/transfer-owner.js index 5afa0a36d3..a861283dc3 100644 --- a/core/client/controllers/modals/transfer-owner.js +++ b/core/client/controllers/modals/transfer-owner.js @@ -14,7 +14,18 @@ var TransferOwnerController = Ember.Controller.extend({ 'id': user.get('id') }] } - }).then(function () { + }).then(function (response) { + // manually update the roles for the users that just changed roles + // because store.pushPayload is not working with embedded relations + if (response && Ember.isArray(response.users)) { + response.users.forEach(function (userJSON) { + var user = self.store.getById('user', userJSON.id), + role = self.store.getById('role', userJSON.roles[0].id); + + user.set('role', role); + }); + } + self.notifications.closePassive(); self.notifications.showSuccess('Ownership successfully transferred to ' + user.get('name')); }).catch(function (error) { diff --git a/core/server/api/users.js b/core/server/api/users.js index f9c408bcc9..580e8ac6fc 100644 --- a/core/server/api/users.js +++ b/core/server/api/users.js @@ -296,8 +296,8 @@ users = { return canThis(options.context).assign.role(ownerRole); }).then(function () { return utils.checkObject(object, 'owner').then(function (checkedOwnerTransfer) { - return dataProvider.User.transferOwnership(checkedOwnerTransfer.owner[0], options).then(function () { - return when.resolve({owner: [{message: 'Ownership transferred successfully.'}]}); + return dataProvider.User.transferOwnership(checkedOwnerTransfer.owner[0], options).then(function (updatedUsers) { + return when.resolve({ users: updatedUsers }); }).catch(function (error) { return when.reject(new errors.ValidationError(error.message)); }); diff --git a/core/server/models/user.js b/core/server/models/user.js index cbc327801d..16b07950a3 100644 --- a/core/server/models/user.js +++ b/core/server/models/user.js @@ -757,6 +757,12 @@ User = ghostBookshelf.Model.extend({ }).then(function () { // assign owner role to a new user return assignUser.roles().updatePivot({role_id: ownerRole.id}); + }).then(function () { + return Users.forge() + .query('whereIn', 'id', [contextUser.id, assignUser.id]) + .fetch({ withRelated: ['roles'] }); + }).then(function (users) { + return users.toJSON({ include: ['roles'] }); }); }, diff --git a/core/test/integration/api/api_users_spec.js b/core/test/integration/api/api_users_spec.js index 8673e0ee85..ebb5acb7f2 100644 --- a/core/test/integration/api/api_users_spec.js +++ b/core/test/integration/api/api_users_spec.js @@ -898,11 +898,13 @@ describe('Users API', function () { {id: userIdFor.admin} ]}, context.owner ).then(function (response) { - should.exist(response); - should.exist(response.owner); - response.owner.should.have.length(1); - response.owner[0].message.should.eql('Ownership transferred successfully.'); - done(); + should.exist(response); + response.users.should.have.length(2); + testUtils.API.checkResponse(response.users[0], 'user', ['roles']); + testUtils.API.checkResponse(response.users[1], 'user', ['roles']); + response.users[0].roles[0].id.should.equal(1); + response.users[1].roles[0].id.should.equal(4); + done(); }).catch(done); });