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');
|
2020-07-06 16:25:25 +02:00
|
|
|
const adminUserController = require('./user/admin');
|
|
|
|
const apiUserController = require('./user/api');
|
2019-09-12 10:50:52 +02:00
|
|
|
const { sanitizeEntity } = require('strapi-utils');
|
|
|
|
|
|
|
|
const sanitizeUser = user =>
|
|
|
|
sanitizeEntity(user, {
|
2019-09-18 17:29:09 +02:00
|
|
|
model: strapi.query('user', 'users-permissions').model,
|
2019-09-12 10:50:52 +02:00
|
|
|
});
|
2017-12-04 15:35:45 +01:00
|
|
|
|
2020-07-06 16:25:25 +02:00
|
|
|
const resolveController = ctx => {
|
|
|
|
const {
|
|
|
|
state: { isAuthenticatedAdmin },
|
|
|
|
} = ctx;
|
|
|
|
|
|
|
|
return isAuthenticatedAdmin ? adminUserController : apiUserController;
|
|
|
|
};
|
|
|
|
|
|
|
|
const resolveControllerMethod = method => ctx => {
|
|
|
|
const controller = resolveController(ctx);
|
|
|
|
const callbackFn = controller[method];
|
|
|
|
|
|
|
|
if (!_.isFunction(callbackFn)) {
|
|
|
|
return ctx.notFound();
|
|
|
|
}
|
|
|
|
|
|
|
|
return callbackFn(ctx);
|
|
|
|
};
|
2017-11-14 11:11:22 +01:00
|
|
|
|
2019-07-15 23:16:50 +02:00
|
|
|
module.exports = {
|
2020-07-06 16:25:25 +02:00
|
|
|
create: resolveControllerMethod('create'),
|
|
|
|
update: resolveControllerMethod('update'),
|
|
|
|
|
2017-11-14 11:11:22 +01:00
|
|
|
/**
|
|
|
|
* Retrieve user records.
|
|
|
|
* @return {Object|Array}
|
|
|
|
*/
|
2019-07-15 23:16:50 +02:00
|
|
|
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
|
2020-03-06 19:16:23 +01:00
|
|
|
users = await strapi.query('user', 'users-permissions').search(ctx.query, populate);
|
2019-05-21 16:18:18 +02:00
|
|
|
} else {
|
2020-03-06 19:16:23 +01:00
|
|
|
users = await strapi.plugins['users-permissions'].services.user.fetchAll(ctx.query, populate);
|
2019-05-21 16:18:18 +02:00
|
|
|
}
|
|
|
|
|
2020-07-06 16:25:25 +02:00
|
|
|
ctx.body = users.map(sanitizeUser);
|
2020-04-17 17:33:21 +02:00
|
|
|
},
|
|
|
|
|
2017-11-14 11:11:22 +01:00
|
|
|
/**
|
|
|
|
* Retrieve a user record.
|
|
|
|
* @return {Object}
|
|
|
|
*/
|
2019-07-15 23:16:50 +02:00
|
|
|
async findOne(ctx) {
|
2019-07-16 16:26:53 +02:00
|
|
|
const { id } = ctx.params;
|
|
|
|
let data = await strapi.plugins['users-permissions'].services.user.fetch({
|
|
|
|
id,
|
|
|
|
});
|
2017-12-06 14:15:27 +01:00
|
|
|
|
|
|
|
if (data) {
|
2019-07-15 23:16:50 +02:00
|
|
|
data = sanitizeUser(data);
|
2017-12-06 14:15:27 +01:00
|
|
|
}
|
2017-11-14 11:11:22 +01:00
|
|
|
|
|
|
|
// Send 200 `ok`
|
2020-07-06 16:25:25 +02:00
|
|
|
ctx.body = data;
|
2017-11-14 11:11:22 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2020-07-06 16:25:25 +02:00
|
|
|
* Retrieve user count.
|
|
|
|
* @return {Number}
|
2017-11-14 11:11:22 +01:00
|
|
|
*/
|
2020-07-06 16:25:25 +02:00
|
|
|
async count(ctx) {
|
|
|
|
if (ctx.query._q) {
|
|
|
|
return await strapi.plugins['users-permissions'].services.user.countSearch(ctx.query);
|
2017-12-06 15:11:55 +01:00
|
|
|
}
|
2020-07-06 16:25:25 +02:00
|
|
|
ctx.body = await strapi.plugins['users-permissions'].services.user.count(ctx.query);
|
2017-11-14 11:11:22 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2020-07-06 16:25:25 +02:00
|
|
|
* Destroy a/an user record.
|
2017-11-14 11:11:22 +01:00
|
|
|
* @return {Object}
|
|
|
|
*/
|
2020-07-06 16:25:25 +02:00
|
|
|
async destroy(ctx) {
|
2019-07-16 16:26:53 +02:00
|
|
|
const { id } = ctx.params;
|
2020-07-06 16:25:25 +02:00
|
|
|
const data = await strapi.plugins['users-permissions'].services.user.remove({ id });
|
|
|
|
ctx.send(sanitizeUser(data));
|
|
|
|
},
|
2019-07-16 16:26:53 +02:00
|
|
|
|
2020-07-06 16:25:25 +02:00
|
|
|
async destroyAll(ctx) {
|
|
|
|
const {
|
|
|
|
request: { query },
|
|
|
|
} = ctx;
|
2019-07-16 16:26:53 +02:00
|
|
|
|
2020-07-06 16:25:25 +02:00
|
|
|
const toRemove = Object.values(_.omit(query, 'source'));
|
|
|
|
const { primaryKey } = strapi.query('user', 'users-permissions');
|
|
|
|
const finalQuery = { [`${primaryKey}_in`]: toRemove, _limit: 100 };
|
2019-07-16 16:26:53 +02:00
|
|
|
|
2020-07-06 16:25:25 +02:00
|
|
|
const data = await strapi.plugins['users-permissions'].services.user.removeAll(finalQuery);
|
2019-07-16 16:26:53 +02:00
|
|
|
|
2020-07-06 16:25:25 +02:00
|
|
|
ctx.send(data);
|
2017-11-14 11:11:22 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2020-07-06 16:25:25 +02:00
|
|
|
* Retrieve authenticated user.
|
|
|
|
* @return {Object|Array}
|
2017-11-14 11:11:22 +01:00
|
|
|
*/
|
2020-07-06 16:25:25 +02:00
|
|
|
async me(ctx) {
|
|
|
|
const user = ctx.state.user;
|
2018-06-06 16:20:52 +02:00
|
|
|
|
2020-07-06 16:25:25 +02:00
|
|
|
if (!user) {
|
|
|
|
return ctx.badRequest(null, [{ messages: [{ id: 'No authorization header was found' }] }]);
|
|
|
|
}
|
2018-06-06 16:20:52 +02:00
|
|
|
|
2020-07-06 16:25:25 +02:00
|
|
|
ctx.body = sanitizeUser(user);
|
2019-07-15 23:16:50 +02:00
|
|
|
},
|
2017-11-14 11:11:22 +01:00
|
|
|
};
|