141 lines
3.5 KiB
JavaScript
Raw Normal View History

'use strict';
const _ = require('lodash');
/**
* A set of functions called "actions" for `ContentManager`
*/
module.exports = {
2017-05-11 10:54:44 +02:00
models: async ctx => {
ctx.body = _.mapValues(strapi.models, model =>
_.pick(model, [
'info',
2017-05-11 10:54:44 +02:00
'connection',
'collectionName',
'attributes',
'identity',
'globalId',
'globalName',
'orm',
'loadedModel',
'primaryKey',
'associations'
2017-05-11 10:54:44 +02:00
])
);
},
2017-05-11 10:54:44 +02:00
find: async ctx => {
const { limit, skip = 0, sort, query, queryAttribute } = ctx.request.query;
2017-04-11 11:34:59 +02:00
// Find entries using `queries` system
const entries = await strapi.query(ctx.params.model).find({
limit,
skip,
2017-06-18 17:23:58 +02:00
sort,
query,
queryAttribute
});
ctx.body = entries;
},
2017-05-11 10:54:44 +02:00
count: async ctx => {
// Count using `queries` system
const count = await strapi.query(ctx.params.model).count();
2017-04-11 11:34:59 +02:00
ctx.body = {
count,
2017-04-11 11:34:59 +02:00
};
},
2017-05-11 10:54:44 +02:00
findOne: async ctx => {
// Find an entry using `queries` system
const entry = await strapi.query(ctx.params.model).findOne({
id: ctx.params.id
});
// Entry not found
if (!entry) {
return (ctx.notFound('Entry not found'));
}
2017-05-04 19:05:41 +02:00
ctx.body = entry;
2017-04-21 17:19:41 +02:00
},
2017-05-11 10:54:44 +02:00
create: async ctx => {
// Create an entry using `queries` system
const entryCreated = await strapi.query(ctx.params.model).create({
values: ctx.request.body
});
2017-05-05 11:40:52 +02:00
ctx.body = entryCreated;
},
2017-05-11 10:54:44 +02:00
update: async ctx => {
2017-09-11 18:17:09 +02:00
const virtualFields = [];
const params = {
2017-08-30 17:56:52 +02:00
id: ctx.params.id,
values: ctx.request.body
2017-09-11 18:17:09 +02:00
};
2017-04-21 17:19:41 +02:00
2017-09-11 18:17:09 +02:00
// Retrieve current record.
const response = await strapi.query(ctx.params.model).findOne(params) || {};
// Save current model into variable to get virtual and p
const model = strapi.models[ctx.params.model];
// Only update fields which are on this document.
const values = Object.keys(params.values).reduce((acc, current) => {
if (!model.schema.virtuals.hasOwnProperty(current)) {
acc[current] = params.values[current];
} else if (response[current] && _.isArray(response[current]) && current !== 'id'){
const details = model.attributes[current];
const toAdd = _.differenceWith(params.values[current], response[current], _.isEqual);
const toRemove = _.differenceWith(response[current], params.values[current], _.isEqual);
toAdd.forEach(value => {
value[details.via] = params.values[model.primaryKey];
virtualFields.push(strapi.query(details.model || details.collection).update({
id: value.id || value[model.primaryKey] || '_id',
values: value
}));
});
toRemove.forEach(value => {
value[details.via] = null;
virtualFields.push(strapi.query(details.model || details.collection).update({
id: value.id || value[model.primaryKey] || '_id',
values: value
}));
});
}
return acc;
}, {});
// Add current model to the flow of updates.
virtualFields.push(strapi.query(ctx.params.model).update({
id: params.id,
values
}));
// Update virtuals fields.
const process = await Promise.all(virtualFields);
// Return the last one which is the current model.
ctx.body = process[process.length - 1];
2017-04-21 17:52:18 +02:00
},
2017-05-11 10:54:44 +02:00
delete: async ctx => {
// Delete an entry using `queries` system
const entryDeleted = await strapi.query(ctx.params.model).delete({
id: ctx.params.id
});
2017-04-21 17:52:18 +02:00
ctx.body = entryDeleted;
2017-05-11 10:54:44 +02:00
},
};