1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-19 05:09:43 +02:00
planka/server/api/helpers/update-user.js

114 lines
3.1 KiB
JavaScript
Raw Normal View History

2019-08-31 04:07:25 +05:00
const path = require('path');
const bcrypt = require('bcrypt');
2020-04-21 05:04:34 +05:00
const rimraf = require('rimraf');
2019-08-31 04:07:25 +05:00
module.exports = {
inputs: {
record: {
type: 'ref',
required: true,
2019-08-31 04:07:25 +05:00
},
values: {
type: 'json',
2020-04-03 00:35:25 +05:00
custom: (value) =>
_.isPlainObject(value) &&
(_.isUndefined(value.email) || _.isString(value.email)) &&
2020-04-03 00:35:25 +05:00
(_.isUndefined(value.password) || _.isString(value.password)) &&
2020-04-21 05:04:34 +05:00
(!value.username || _.isString(value.username)) &&
(_.isUndefined(value.avatarUrl) || _.isNull(value.avatarUrl)),
required: true,
2019-08-31 04:07:25 +05:00
},
request: {
type: 'ref',
},
2019-08-31 04:07:25 +05:00
},
exits: {
2020-04-03 00:35:25 +05:00
emailAlreadyInUse: {},
usernameAlreadyInUse: {},
},
async fn(inputs, exits) {
2019-08-31 04:07:25 +05:00
if (!_.isUndefined(inputs.values.email)) {
// eslint-disable-next-line no-param-reassign
2019-08-31 04:07:25 +05:00
inputs.values.email = inputs.values.email.toLowerCase();
}
let isOnlyPasswordChange = false;
2019-08-31 04:07:25 +05:00
if (!_.isUndefined(inputs.values.password)) {
// eslint-disable-next-line no-param-reassign
2019-08-31 04:07:25 +05:00
inputs.values.password = bcrypt.hashSync(inputs.values.password, 10);
if (Object.keys(inputs.values).length === 1) {
isOnlyPasswordChange = true;
}
2019-08-31 04:07:25 +05:00
}
2020-04-03 00:35:25 +05:00
if (inputs.values.username) {
// eslint-disable-next-line no-param-reassign
inputs.values.username = inputs.values.username.toLowerCase();
}
2020-04-21 05:04:34 +05:00
if (!_.isUndefined(inputs.values.avatarUrl)) {
/* eslint-disable no-param-reassign */
inputs.values.avatarDirname = null;
delete inputs.values.avatarUrl;
/* eslint-enable no-param-reassign */
}
2019-08-31 04:07:25 +05:00
const user = await User.updateOne({
id: inputs.record.id,
deletedAt: null,
})
.set(inputs.values)
.intercept(
{
message:
'Unexpected error from database adapter: conflicting key value violates exclusion constraint "user_email_unique"',
},
2020-04-03 00:35:25 +05:00
'emailAlreadyInUse',
)
.intercept(
{
message:
'Unexpected error from database adapter: conflicting key value violates exclusion constraint "user_username_unique"',
},
'usernameAlreadyInUse',
);
2019-08-31 04:07:25 +05:00
if (user) {
2020-04-21 05:04:34 +05:00
if (inputs.record.avatarDirname && user.avatarDirname !== inputs.record.avatarDirname) {
2019-08-31 04:07:25 +05:00
try {
2020-04-21 05:04:34 +05:00
rimraf.sync(path.join(sails.config.custom.userAvatarsPath, inputs.record.avatarDirname));
} catch (error) {
console.warn(error.stack); // eslint-disable-line no-console
}
2019-08-31 04:07:25 +05:00
}
if (!isOnlyPasswordChange) {
const adminUserIds = await sails.helpers.getAdminUserIds();
2019-08-31 04:07:25 +05:00
const projectIds = await sails.helpers.getMembershipProjectIdsForUser(user.id);
2019-08-31 04:07:25 +05:00
const userIdsForProject = await sails.helpers.getMembershipUserIdsForProject(projectIds);
2019-08-31 04:07:25 +05:00
const userIds = _.union([user.id], adminUserIds, userIdsForProject);
2019-08-31 04:07:25 +05:00
2020-04-03 00:35:25 +05:00
userIds.forEach((userId) => {
sails.sockets.broadcast(
`user:${userId}`,
'userUpdate',
{
item: user,
},
inputs.request,
);
});
}
2019-08-31 04:07:25 +05:00
}
return exits.success(user);
},
2019-08-31 04:07:25 +05:00
};