mirror of
https://github.com/strapi/strapi.git
synced 2025-10-17 02:53:22 +00:00
126 lines
3.4 KiB
JavaScript
126 lines
3.4 KiB
JavaScript
'use strict';
|
|
|
|
const _ = require('lodash');
|
|
const utils = require('@strapi/utils');
|
|
const { getService } = require('../../utils');
|
|
const { validateCreateUserBody, validateUpdateUserBody } = require('../validation/user');
|
|
|
|
const { sanitize } = utils;
|
|
const { ApplicationError, ValidationError } = utils.errors;
|
|
|
|
const sanitizeOutput = (user, ctx) => {
|
|
const schema = strapi.getModel('plugin::users-permissions.user');
|
|
const { auth } = ctx.state;
|
|
|
|
return sanitize.contentAPI.output(user, schema, { auth });
|
|
};
|
|
|
|
module.exports = {
|
|
/**
|
|
* Create a/an user record.
|
|
* @return {Object}
|
|
*/
|
|
async create(ctx) {
|
|
const advanced = await strapi
|
|
.store({ type: 'plugin', name: 'users-permissions', key: 'advanced' })
|
|
.get();
|
|
|
|
await validateCreateUserBody(ctx.request.body);
|
|
|
|
const { email, username, role } = ctx.request.body;
|
|
|
|
const userWithSameUsername = await strapi
|
|
.query('plugin::users-permissions.user')
|
|
.findOne({ where: { username } });
|
|
|
|
if (userWithSameUsername) {
|
|
if (!email) throw new ApplicationError('Username already taken');
|
|
}
|
|
|
|
if (advanced.unique_email) {
|
|
const userWithSameEmail = await strapi
|
|
.query('plugin::users-permissions.user')
|
|
.findOne({ where: { email: email.toLowerCase() } });
|
|
|
|
if (userWithSameEmail) {
|
|
throw new ApplicationError('Email already taken');
|
|
}
|
|
}
|
|
|
|
const user = {
|
|
...ctx.request.body,
|
|
provider: 'local',
|
|
};
|
|
|
|
user.email = _.toLower(user.email);
|
|
|
|
if (!role) {
|
|
const defaultRole = await strapi
|
|
.query('plugin::users-permissions.role')
|
|
.findOne({ where: { type: advanced.default_role } });
|
|
|
|
user.role = defaultRole.id;
|
|
}
|
|
|
|
try {
|
|
const data = await getService('user').add(user);
|
|
const sanitizedData = await sanitizeOutput(data, ctx);
|
|
|
|
ctx.created(sanitizedData);
|
|
} catch (error) {
|
|
throw new ApplicationError(error.message);
|
|
}
|
|
},
|
|
|
|
/**
|
|
* Update a/an user record.
|
|
* @return {Object}
|
|
*/
|
|
async update(ctx) {
|
|
const advancedConfigs = await strapi
|
|
.store({ type: 'plugin', name: 'users-permissions', key: 'advanced' })
|
|
.get();
|
|
|
|
const { id } = ctx.params;
|
|
const { email, username, password } = ctx.request.body;
|
|
|
|
const user = await getService('user').fetch({ id });
|
|
|
|
await validateUpdateUserBody(ctx.request.body);
|
|
|
|
if (user.provider === 'local' && _.has(ctx.request.body, 'password') && !password) {
|
|
throw new ValidationError('password.notNull');
|
|
}
|
|
|
|
if (_.has(ctx.request.body, 'username')) {
|
|
const userWithSameUsername = await strapi
|
|
.query('plugin::users-permissions.user')
|
|
.findOne({ where: { username } });
|
|
|
|
if (userWithSameUsername && userWithSameUsername.id != id) {
|
|
throw new ApplicationError('Username already taken');
|
|
}
|
|
}
|
|
|
|
if (_.has(ctx.request.body, 'email') && advancedConfigs.unique_email) {
|
|
const userWithSameEmail = await strapi
|
|
.query('plugin::users-permissions.user')
|
|
.findOne({ where: { email: email.toLowerCase() } });
|
|
|
|
if (userWithSameEmail && userWithSameEmail.id != id) {
|
|
throw new ApplicationError('Email already taken');
|
|
}
|
|
ctx.request.body.email = ctx.request.body.email.toLowerCase();
|
|
}
|
|
|
|
let updateData = {
|
|
...ctx.request.body,
|
|
};
|
|
|
|
const data = await getService('user').edit({ id }, updateData);
|
|
const sanitizedData = await sanitizeOutput(data, ctx);
|
|
|
|
ctx.send(sanitizedData);
|
|
},
|
|
};
|