fleet/website/api/controllers/account/update-password.js
eashaw e335e835c9
Add customer portal and license dispenser to fleetdm.com (#3546)
* Add images for customer portal, dashboard, and email templates

* updated email layout and reset password template, new email template

* update ajax-button component to have an optional spinner

* updated cloud-error & stripe-card-element component styles

* updates to user model, add quote and subscription

* Login, signup, forgot password, update profile

* link to customer portal from pricing

* new-license page, bootstrap updates

* create quote action, dashboard page, update routes

* Add new page styles to importer, update component styles

* updates to js-timestamp

* update modal styles and layout

* using @submitted on ajax form, controller updates

* Update create-quote.js

* updates to quote model, action updates, truncate license key on dashboard

* update email layout, subscribe action, user model

* Update importer.less

* style updates, order confirmation

* use correct font

* style updates

* create license key

* new-license page changes

* signup page changes

* add billing format to js-timestamp component, dashboard updates, change password

* swap get started link for customers

* order -> subscription

* Update login.ejs

* Lint fixes, page updates, mobile styles

* remove edit-profile route, update layout, bootstrap, forms

* change customer-layout name to match other layout names, update copyright year in layouts

* changes requested from code review and #3570

* submit button width, contact font-size

* Update dashboard.less

* Update bootstrap-overrides.less

* slack logo update, login text
2022-01-04 20:02:42 -06:00

54 lines
1.1 KiB
JavaScript
Vendored

module.exports = {
friendlyName: 'Update password',
description: 'Update the password for the logged-in user.',
inputs: {
oldPassword: {
description: 'The new, unencrypted password.',
example: 'abc123v2',
required: true
},
newPassword: {
description: 'The new, unencrypted password.',
example: 'abc123v2',
required: true
}
},
exits: {
success: {
description: 'The requesting user agent has been successfully changed their password.',
},
badPassword: {
description: `The provided password does not match the user's current password.`,
responseType: 'unauthorized'
}
},
fn: async function (inputs) {
await sails.helpers.passwords.checkPassword(inputs.oldPassword, this.req.me.password)
.intercept('incorrect', 'badPassword');
// Hash the new password.
var hashed = await sails.helpers.passwords.hashPassword(inputs.newPassword);
// Update the record for the logged-in user.
await User.updateOne({ id: this.req.me.id })
.set({
password: hashed
});
}
};