import ValidationEngine from 'ghost/mixins/validation-engine'; import NProgressSaveMixin from 'ghost/mixins/nprogress-save'; var User = DS.Model.extend(NProgressSaveMixin, ValidationEngine, { validationType: 'user', uuid: DS.attr('string'), name: DS.attr('string'), slug: DS.attr('string'), email: DS.attr('string'), image: DS.attr('string'), cover: DS.attr('string'), bio: DS.attr('string'), website: DS.attr('string'), location: DS.attr('string'), accessibility: DS.attr('string'), status: DS.attr('string'), language: DS.attr('string', {defaultValue: 'en_US'}), meta_title: DS.attr('string'), meta_description: DS.attr('string'), last_login: DS.attr('moment-date'), created_at: DS.attr('moment-date'), created_by: DS.belongsTo('user', { async: true }), updated_at: DS.attr('moment-date'), updated_by: DS.belongsTo('user', { async: true }), roles: DS.hasMany('role', { embedded: 'always' }), // TODO: Once client-side permissions are in place, // remove the hard role check. isAuthor: Ember.computed('roles', function () { return this.get('roles').objectAt(0).get('name').toLowerCase() === 'author'; }), // TODO: Once client-side permissions are in place, // remove the hard role check. isEditor: Ember.computed('roles', function () { return this.get('roles').objectAt(0).get('name').toLowerCase() === 'editor'; }), saveNewPassword: function () { var url = this.get('ghostPaths.url').api('users', 'password'); return ic.ajax.request(url, { type: 'PUT', data: { password: [{ 'oldPassword': this.get('password'), 'newPassword': this.get('newPassword'), 'ne2Password': this.get('ne2Password') }] } }); }, resendInvite: function () { var userData = {}; userData.email = this.get('email'); return ic.ajax.request(this.get('ghostPaths.url').api('users'), { type: 'POST', data: JSON.stringify({users: [userData]}), contentType: 'application/json' }); }, passwordValidationErrors: function () { var validationErrors = []; if (!validator.equals(this.get('newPassword'), this.get('ne2Password'))) { validationErrors.push({message: 'Your new passwords do not match'}); } if (!validator.isLength(this.get('newPassword'), 8)) { validationErrors.push({message: 'Your password is not long enough. It must be at least 8 characters long.'}); } return validationErrors; }.property('password', 'newPassword', 'ne2Password'), isPasswordValid: Ember.computed.empty('passwordValidationErrors.[]'), active: function () { return _.contains(['active', 'warn-1', 'warn-2', 'warn-3', 'warn-4', 'locked'], this.get('status')); }.property('status'), invited: function () { return _.contains(['invited', 'invited-pending'], this.get('status')); }.property('status'), pending: Ember.computed.equal('status', 'invited-pending').property('status') }); export default User;