mirror of
https://github.com/strapi/strapi.git
synced 2025-10-24 14:29:58 +00:00
133 lines
3.0 KiB
JavaScript
133 lines
3.0 KiB
JavaScript
'use strict';
|
|
|
|
const _ = require('lodash');
|
|
const { ApplicationError } = require('@strapi/utils').errors;
|
|
const {
|
|
validateUserCreationInput,
|
|
validateUserUpdateInput,
|
|
validateUsersDeleteInput,
|
|
} = require('../validation/user');
|
|
|
|
const { getService } = require('../utils');
|
|
|
|
module.exports = {
|
|
async create(ctx) {
|
|
const { body } = ctx.request;
|
|
|
|
await validateUserCreationInput(body);
|
|
|
|
const attributes = _.pick(body, [
|
|
'firstname',
|
|
'lastname',
|
|
'email',
|
|
'roles',
|
|
'preferedLanguage',
|
|
]);
|
|
|
|
const userAlreadyExists = await getService('user').exists({
|
|
email: attributes.email,
|
|
});
|
|
|
|
if (userAlreadyExists) {
|
|
throw new ApplicationError('Email already taken');
|
|
}
|
|
|
|
const createdUser = await getService('user').create(attributes);
|
|
|
|
const userInfo = getService('user').sanitizeUser(createdUser);
|
|
|
|
// Note: We need to assign manually the registrationToken to the
|
|
// final user payload so that it's not removed in the sanitation process.
|
|
Object.assign(userInfo, { registrationToken: createdUser.registrationToken });
|
|
|
|
// Send 201 created
|
|
ctx.created({ data: userInfo });
|
|
},
|
|
|
|
async find(ctx) {
|
|
const userService = getService('user');
|
|
|
|
const { results, pagination } = await userService.findPage(ctx.query);
|
|
|
|
ctx.body = {
|
|
data: {
|
|
results: results.map(user => userService.sanitizeUser(user)),
|
|
pagination,
|
|
},
|
|
};
|
|
},
|
|
|
|
async findOne(ctx) {
|
|
const { id } = ctx.params;
|
|
|
|
const user = await getService('user').findOne(id);
|
|
|
|
if (!user) {
|
|
return ctx.notFound('User does not exist');
|
|
}
|
|
|
|
ctx.body = {
|
|
data: getService('user').sanitizeUser(user),
|
|
};
|
|
},
|
|
|
|
async update(ctx) {
|
|
const { id } = ctx.params;
|
|
const { body: input } = ctx.request;
|
|
|
|
await validateUserUpdateInput(input);
|
|
|
|
if (_.has(input, 'email')) {
|
|
const uniqueEmailCheck = await getService('user').exists({
|
|
id: { $ne: id },
|
|
email: input.email,
|
|
});
|
|
|
|
if (uniqueEmailCheck) {
|
|
throw new ApplicationError('A user with this email address already exists');
|
|
}
|
|
}
|
|
|
|
const updatedUser = await getService('user').updateById(id, input);
|
|
|
|
if (!updatedUser) {
|
|
return ctx.notFound('User does not exist');
|
|
}
|
|
|
|
ctx.body = {
|
|
data: getService('user').sanitizeUser(updatedUser),
|
|
};
|
|
},
|
|
|
|
async deleteOne(ctx) {
|
|
const { id } = ctx.params;
|
|
|
|
const deletedUser = await getService('user').deleteById(id);
|
|
|
|
if (!deletedUser) {
|
|
return ctx.notFound('User not found');
|
|
}
|
|
|
|
return ctx.deleted({
|
|
data: getService('user').sanitizeUser(deletedUser),
|
|
});
|
|
},
|
|
|
|
/**
|
|
* Delete several users
|
|
* @param {KoaContext} ctx - koa context
|
|
*/
|
|
async deleteMany(ctx) {
|
|
const { body } = ctx.request;
|
|
await validateUsersDeleteInput(body);
|
|
|
|
const users = await getService('user').deleteByIds(body.ids);
|
|
|
|
const sanitizedUsers = users.map(getService('user').sanitizeUser);
|
|
|
|
return ctx.deleted({
|
|
data: sanitizedUsers,
|
|
});
|
|
},
|
|
};
|