From e1ac6a53dd587fcee6902b6702d6c2dd83530fb1 Mon Sep 17 00:00:00 2001 From: Katharina Irrgang Date: Fri, 14 Oct 2016 16:37:40 +0200 Subject: [PATCH] =?UTF-8?q?=F0=9F=8E=A8=20=20gravatar=20lookup=20in=20savi?= =?UTF-8?q?ng=20hook=20(#7561)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit refs #7432 - in preparation for more User model cleanup - look for gravatar when email has changed - run onSaving tasks in parallel in User model --- core/server/models/user.js | 55 +++++++++++++++++++++++--------------- core/server/utils/index.js | 3 ++- 2 files changed, 36 insertions(+), 22 deletions(-) diff --git a/core/server/models/user.js b/core/server/models/user.js index 7e51d0a544..111140b098 100644 --- a/core/server/models/user.js +++ b/core/server/models/user.js @@ -73,20 +73,45 @@ User = ghostBookshelf.Model.extend({ model.emitChange('edited'); }, + /** + * Lookup Gravatar if email changes to update image url + * Generating a slug requires a db call to look for conflicting slugs + */ onSaving: function onSaving(newPage, attr, options) { - /*jshint unused:false*/ - var self = this; + var self = this, + tasks = []; ghostBookshelf.Model.prototype.onSaving.apply(this, arguments); - if (this.hasChanged('slug') || !this.get('slug')) { - // Generating a slug requires a db call to look for conflicting slugs - return ghostBookshelf.Model.generateSlug(User, this.get('slug') || this.get('name'), - {status: 'all', transacting: options.transacting, shortSlug: !this.get('slug')}) - .then(function then(slug) { - self.set({slug: slug}); + if (self.hasChanged('email')) { + tasks.gravatar = (function lookUpGravatar() { + return gravatar.lookup({ + email: self.get('email') + }).then(function (response) { + if (response && response.image) { + self.set('image', response.image); + } }); + })(); } + + if (this.hasChanged('slug') || !this.get('slug')) { + tasks.slug = (function generateSlug() { + return ghostBookshelf.Model.generateSlug( + User, + self.get('slug') || self.get('name'), + { + status: 'all', + transacting: options.transacting, + shortSlug: !self.get('slug') + }) + .then(function then(slug) { + self.set({slug: slug}); + }); + })(); + } + + return Promise.props(tasks); }, // For the user model ONLY it is possible to disable validations. @@ -404,11 +429,6 @@ User = ghostBookshelf.Model.extend({ return generatePasswordHash(userData.password).then(function then(hash) { // Assign the hashed password userData.password = hash; - return gravatar.lookup(userData); - }).then(function then(response) { - if (response && response.image) { - userData.image = response.image; - } // Save the user with the hashed password return ghostBookshelf.Model.add.call(self, userData, options); @@ -451,14 +471,7 @@ User = ghostBookshelf.Model.extend({ // Assign the hashed password userData.password = hash; - return gravatar.lookup(userData) - .then(function (response) { - if (response && response.image) { - userData.image = response.image; - } - - return ghostBookshelf.Model.generateSlug.call(this, User, userData.name, options); - }); + return ghostBookshelf.Model.generateSlug.call(this, User, userData.name, options); }).then(function then(slug) { userData.slug = slug; return self.edit.call(self, userData, options); diff --git a/core/server/utils/index.js b/core/server/utils/index.js index a24d40422f..4eda940475 100644 --- a/core/server/utils/index.js +++ b/core/server/utils/index.js @@ -106,7 +106,8 @@ utils = { readThemes: require('./read-themes'), generateAssetHash: require('./asset-hash'), url: require('./url'), - tokens: require('./tokens') + tokens: require('./tokens'), + sequence: require('./sequence') }; module.exports = utils;