246 lines
5.4 KiB
JavaScript
Raw Normal View History

2017-11-14 11:11:22 +01:00
'use strict';
/**
* User.js controller
*
* @description: A set of functions called "actions" for managing `User`.
*/
2017-12-04 15:35:45 +01:00
const _ = require('lodash');
const sanitizeUser = user => _.omit(user, ['password', 'resetPasswordToken']);
const formatError = error => [
{ messages: [{ id: error.id, message: error.message, field: error.field }] },
];
2017-11-14 11:11:22 +01:00
module.exports = {
2017-11-14 11:11:22 +01:00
/**
* Retrieve user records.
* @return {Object|Array}
*/
async find(ctx, next, { populate } = {}) {
let users;
2017-11-14 11:11:22 +01:00
2019-05-21 16:18:18 +02:00
if (_.has(ctx.query, '_q')) {
// use core strapi query to search for users
users = await strapi
.query('user', 'users-permissions')
.search(ctx.query, populate);
} else {
users = await strapi.plugins['users-permissions'].services.user.fetchAll(
ctx.query,
populate
);
2019-05-21 16:18:18 +02:00
}
const data = users.map(sanitizeUser);
2017-11-14 11:11:22 +01:00
ctx.send(data);
},
/**
* Retrieve authenticated user.
* @return {Object|Array}
*/
async me(ctx) {
const user = ctx.state.user;
if (!user) {
return ctx.badRequest(null, [
{ messages: [{ id: 'No authorization header was found' }] },
]);
}
const data = sanitizeUser(user);
ctx.send(data);
},
2017-11-14 11:11:22 +01:00
/**
* Retrieve a user record.
* @return {Object}
*/
async findOne(ctx) {
const { id } = ctx.params;
let data = await strapi.plugins['users-permissions'].services.user.fetch({
id,
});
if (data) {
data = sanitizeUser(data);
}
2017-11-14 11:11:22 +01:00
// Send 200 `ok`
ctx.send(data);
},
/**
* Create a/an user record.
* @return {Object}
*/
async create(ctx) {
const advanced = await strapi
.store({
environment: '',
type: 'plugin',
name: 'users-permissions',
key: 'advanced',
})
.get();
const { email, username, password, role } = ctx.request.body;
if (!email) return ctx.badRequest('missing.email');
if (!username) return ctx.badRequest('missing.username');
if (!password) return ctx.badRequest('missing.password');
const userWithSameUsername = await strapi
.query('user', 'users-permissions')
.findOne({ username });
if (userWithSameUsername) {
return ctx.badRequest(
null,
formatError({
id: 'Auth.form.error.username.taken',
message: 'Username already taken.',
field: ['username'],
})
);
}
if (advanced.unique_email) {
const userWithSameEmail = await strapi
.query('user', 'users-permissions')
.findOne({ email });
2018-01-26 09:37:24 +01:00
if (userWithSameEmail) {
return ctx.badRequest(
null,
formatError({
id: 'Auth.form.error.email.taken',
message: 'Email already taken.',
field: ['email'],
})
);
2018-01-26 09:37:24 +01:00
}
}
const user = {
...ctx.request.body,
provider: 'local',
};
if (!role) {
const defaultRole = await strapi
.query('role', 'users-permissions')
.findOne({ type: advanced.default_role }, []);
user.role = defaultRole.id;
}
2017-12-06 15:11:55 +01:00
try {
const data = await strapi.plugins['users-permissions'].services.user.add(
user
);
2017-12-06 15:11:55 +01:00
ctx.created(data);
} catch (error) {
ctx.badRequest(null, formatError(error));
2017-12-06 15:11:55 +01:00
}
2017-11-14 11:11:22 +01:00
},
/**
* Update a/an user record.
* @return {Object}
*/
async update(ctx) {
const advancedConfigs = await strapi
.store({
environment: '',
type: 'plugin',
name: 'users-permissions',
key: 'advanced',
})
.get();
2017-12-04 15:35:45 +01:00
const { id } = ctx.params;
const { email, username, password } = ctx.request.body;
2017-12-04 15:35:45 +01:00
if (!email) return ctx.badRequest('missing.email');
if (!username) return ctx.badRequest('missing.username');
if (!password) return ctx.badRequest('missing.password');
const userWithSameUsername = await strapi
.query('user', 'users-permissions')
.findOne({ username });
2017-11-14 11:11:22 +01:00
if (userWithSameUsername && userWithSameUsername.id != id) {
return ctx.badRequest(
null,
formatError({
id: 'Auth.form.error.username.taken',
message: 'username.alreadyTaken.',
field: ['username'],
})
);
2017-12-06 15:11:55 +01:00
}
if (advancedConfigs.unique_email) {
const userWithSameEmail = await strapi
.query('user', 'users-permissions')
.findOne({ email });
if (userWithSameEmail && userWithSameEmail.id != id) {
return ctx.badRequest(
null,
formatError({
id: 'Auth.form.error.email.taken',
message: 'Eamil already taken',
field: ['email'],
})
);
}
}
const user = await strapi.plugins['users-permissions'].services.user.fetch({
id,
});
let updateData = {
...ctx.request.body,
};
if (password === user.password) {
delete updateData.password;
}
const data = await strapi.plugins['users-permissions'].services.user.edit(
{ id },
updateData
);
ctx.send(data);
2017-11-14 11:11:22 +01:00
},
/**
* Destroy a/an user record.
* @return {Object}
*/
async destroy(ctx) {
2019-07-16 16:49:36 +02:00
const { id } = ctx.params;
const data = await strapi.plugins['users-permissions'].services.user.remove(
2019-07-16 16:49:36 +02:00
{ id }
);
ctx.send(data);
},
async destroyAll(ctx) {
const data = await strapi.plugins[
'users-permissions'
].services.user.removeAll(ctx.params, ctx.request.query);
2017-11-14 11:11:22 +01:00
ctx.send(data);
},
2017-11-14 11:11:22 +01:00
};