126 lines
2.9 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 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, {
model: strapi.query('user', 'users-permissions').model,
2019-09-12 10:50:52 +02:00
});
2017-12-04 15:35:45 +01: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
module.exports = {
create: resolveControllerMethod('create'),
update: resolveControllerMethod('update'),
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);
2019-05-21 16:18:18 +02:00
} else {
users = await strapi.plugins['users-permissions'].services.user.fetchAll(ctx.query, populate);
2019-05-21 16:18:18 +02:00
}
ctx.body = users.map(sanitizeUser);
},
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.body = data;
2017-11-14 11:11:22 +01:00
},
/**
* Retrieve user count.
* @return {Number}
2017-11-14 11:11:22 +01: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
}
ctx.body = await strapi.plugins['users-permissions'].services.user.count(ctx.query);
2017-11-14 11:11:22 +01:00
},
/**
* Destroy a/an user record.
2017-11-14 11:11:22 +01:00
* @return {Object}
*/
async destroy(ctx) {
const { id } = ctx.params;
const data = await strapi.plugins['users-permissions'].services.user.remove({ id });
ctx.send(sanitizeUser(data));
},
async destroyAll(ctx) {
const {
request: { query },
} = ctx;
const toRemove = Object.values(_.omit(query, 'source'));
const { primaryKey } = strapi.query('user', 'users-permissions');
const finalQuery = { [`${primaryKey}_in`]: toRemove, _limit: 100 };
const data = await strapi.plugins['users-permissions'].services.user.removeAll(finalQuery);
ctx.send(data);
2017-11-14 11:11:22 +01:00
},
/**
* Retrieve authenticated user.
* @return {Object|Array}
2017-11-14 11:11:22 +01:00
*/
async me(ctx) {
const user = ctx.state.user;
if (!user) {
return ctx.badRequest(null, [{ messages: [{ id: 'No authorization header was found' }] }]);
}
ctx.body = sanitizeUser(user);
},
2017-11-14 11:11:22 +01:00
};