2019-11-15 11:49:32 +01:00

143 lines
3.3 KiB
JavaScript

'use strict';
const _ = require('lodash');
const parseMultipartBody = require('../utils/parse-multipart');
const contentManagerService = require('../services/ContentManager');
module.exports = {
/**
* Returns a list of entities of a content-type matching the query parameters
*/
async find(ctx) {
let entities = [];
if (_.has(ctx.request.query, '_q')) {
entities = await contentManagerService.search(
ctx.params,
ctx.request.query
);
} else {
entities = await contentManagerService.fetchAll(
ctx.params,
ctx.request.query
);
}
ctx.body = entities;
},
/**
* Returns an entity of a content type by id
*/
async findOne(ctx) {
const entry = await contentManagerService.fetch(ctx.params);
// Entry not found
if (!entry) {
return ctx.notFound('Entry not found');
}
ctx.body = entry;
},
/**
* Returns a count of entities of a content type matching query parameters
*/
async count(ctx) {
let count;
if (_.has(ctx.request.query, '_q')) {
count = await contentManagerService.countSearch(
ctx.params,
ctx.request.query
);
} else {
count = await contentManagerService.count(ctx.params, ctx.request.query);
}
ctx.body = {
count: _.isNumber(count) ? count : _.toNumber(count),
};
},
/**
* Creates an entity of a content type
*/
async create(ctx) {
const { model } = ctx.params;
try {
if (ctx.is('multipart')) {
const { data, files } = parseMultipartBody(ctx);
ctx.body = await contentManagerService.create(data, {
files,
model,
});
} else {
// Create an entry using `queries` system
ctx.body = await contentManagerService.create(ctx.request.body, {
model,
});
}
strapi.emit('didCreateFirstContentTypeEntry', ctx.params);
} catch (error) {
strapi.log.error(error);
ctx.badRequest(null, [
{
messages: [
{ id: error.message, message: error.message, field: error.field },
],
},
]);
}
},
/**
* Updates an entity of a content type
*/
async update(ctx) {
const { model } = ctx.params;
try {
if (ctx.is('multipart')) {
const { data, files } = parseMultipartBody(ctx);
ctx.body = await contentManagerService.edit(ctx.params, data, {
files,
model,
});
} else {
// Return the last one which is the current model.
ctx.body = await contentManagerService.edit(
ctx.params,
ctx.request.body,
{ model }
);
}
} catch (error) {
strapi.log.error(error);
ctx.badRequest(null, [
{
messages: [
{ id: error.message, message: error.message, field: error.field },
],
},
]);
}
},
/**
* Deletes one entity of a content type matching a query
*/
async delete(ctx) {
ctx.body = await contentManagerService.delete(ctx.params);
},
/**
* Deletes multiple entities of a content type matching a query
*/
async deleteMany(ctx) {
ctx.body = await contentManagerService.deleteMany(
ctx.params,
ctx.request.query
);
},
};