243 lines
7.2 KiB
Plaintext
Raw Normal View History

2016-03-18 11:12:50 +01:00
'use strict';
2016-03-25 22:22:34 +01:00
/**
* <%= filename %> service
*
* @description: A set of functions similar to controller's actions to avoid code duplication.
2016-03-25 22:22:34 +01:00
*/
// Public dependencies.
2016-03-18 11:12:50 +01:00
const _ = require('lodash');
2016-03-25 22:22:34 +01:00
2018-12-04 17:05:03 +01:00
// Strapi utilities.
const utils = require('strapi-hook-bookshelf/lib/utils/');
2016-03-18 11:12:50 +01:00
module.exports = {
/**
* Promise to fetch all <%= idPluralized %>.
2016-03-18 11:12:50 +01:00
*
* @return {Promise}
*/
fetchAll: (params) => {
// Convert `params` object to filters compatible with Bookshelf.
const filters = strapi.utils.models.convertParams('<%= globalID.toLowerCase() %>', params);
// Select field to populate.
const populate = <%= globalID %>.associations
.filter(ast => ast.autoPopulate !== false)
.map(ast => ast.alias);
2017-09-13 12:18:54 +02:00
return <%= globalID %>.query(function(qb) {
2018-12-04 17:05:03 +01:00
_.forEach(filters.where, (where, key) => {
if (_.isArray(where.value) && where.symbol !== 'IN') {
for (const value in where.value) {
qb[value ? 'where' : 'orWhere'](key, where.symbol, where.value[value])
}
} else {
2018-12-04 17:05:03 +01:00
qb.where(key, where.symbol, where.value);
}
2018-12-04 17:05:03 +01:00
});
if (filters.sort) {
qb.orderBy(filters.sort.key, filters.sort.order);
}
2018-12-04 17:05:03 +01:00
qb.offset(filters.start);
qb.limit(filters.limit);
2017-09-13 12:18:54 +02:00
}).fetchAll({
withRelated: populate
2016-03-18 11:12:50 +01:00
});
},
/**
* Promise to fetch a/an <%= id %>.
2016-03-18 11:12:50 +01:00
*
* @return {Promise}
*/
fetch: (params) => {
// Select field to populate.
const populate = <%= globalID %>.associations
.filter(ast => ast.autoPopulate !== false)
.map(ast => ast.alias);
return <%= globalID %>.forge(_.pick(params, 'id')).fetch({
withRelated: populate
2016-03-18 11:12:50 +01:00
});
},
/**
* Promise to count a/an <%= id %>.
*
* @return {Promise}
*/
count: (params) => {
// Convert `params` object to filters compatible with Bookshelf.
const filters = strapi.utils.models.convertParams('<%= globalID.toLowerCase() %>', params);
return <%= globalID %>.query(function(qb) {
_.forEach(filters.where, (where, key) => {
if (_.isArray(where.value)) {
for (const value in where.value) {
qb[value ? 'where' : 'orWhere'](key, where.symbol, where.value[value]);
}
} else {
qb.where(key, where.symbol, where.value);
}
});
}).count();
},
2016-03-18 11:12:50 +01:00
/**
* Promise to add a/an <%= id %>.
2016-03-18 11:12:50 +01:00
*
* @return {Promise}
*/
add: async (values) => {
// Extract values related to relational data.
const relations = _.pick(values, <%= globalID %>.associations.map(ast => ast.alias));
const data = _.omit(values, <%= globalID %>.associations.map(ast => ast.alias));
// Create entry with no-relational data.
const entry = await <%= globalID %>.forge(data).save();
// Create relational data and return the entry.
return <%= globalID %>.updateRelations({ id: entry.id , values: relations });
2016-03-18 11:12:50 +01:00
},
/**
* Promise to edit a/an <%= id %>.
2016-03-18 11:12:50 +01:00
*
* @return {Promise}
*/
edit: async (params, values) => {
// Extract values related to relational data.
const relations = _.pick(values, <%= globalID %>.associations.map(ast => ast.alias));
const data = _.omit(values, <%= globalID %>.associations.map(ast => ast.alias));
// Create entry with no-relational data.
2018-10-04 17:17:25 +02:00
const entry = <%= globalID %>.forge(params).save(data);
// Create relational data and return the entry.
return <%= globalID %>.updateRelations(Object.assign(params, { values: relations }));
2016-03-18 11:12:50 +01:00
},
/**
* Promise to remove a/an <%= id %>.
2016-03-18 11:12:50 +01:00
*
* @return {Promise}
*/
remove: async (params) => {
params.values = {};
<%= globalID %>.associations.map(association => {
switch (association.nature) {
case 'oneWay':
case 'oneToOne':
case 'manyToOne':
case 'oneToManyMorph':
params.values[association.alias] = null;
break;
case 'oneToMany':
case 'manyToMany':
case 'manyToManyMorph':
params.values[association.alias] = [];
break;
default:
}
});
await <%= globalID %>.updateRelations(params);
return <%= globalID %>.forge(params).destroy();
2018-11-21 16:47:01 +01:00
},
2018-07-05 11:28:55 +02:00
/**
* Promise to search a/an <%= id %>.
*
* @return {Promise}
*/
search: async (params) => {
// Convert `params` object to filters compatible with Bookshelf.
const filters = strapi.utils.models.convertParams('<%= globalID.toLowerCase() %>', params);
// Select field to populate.
const populate = <%= globalID %>.associations
.filter(ast => ast.autoPopulate !== false)
.map(ast => ast.alias);
const associations = <%= globalID %>.associations.map(x => x.alias);
const searchText = Object.keys(<%= globalID %>._attributes)
.filter(attribute => attribute !== <%= globalID %>.primaryKey && !associations.includes(attribute))
.filter(attribute => ['string', 'text'].includes(<%= globalID %>._attributes[attribute].type));
const searchNoText = Object.keys(<%= globalID %>._attributes)
.filter(attribute => attribute !== <%= globalID %>.primaryKey && !associations.includes(attribute))
.filter(attribute => !['string', 'text', 'boolean', 'integer', 'decimal', 'float'].includes(<%= globalID %>._attributes[attribute].type));
const searchInt = Object.keys(<%= globalID %>._attributes)
.filter(attribute => attribute !== <%= globalID %>.primaryKey && !associations.includes(attribute))
.filter(attribute => ['integer', 'decimal', 'float'].includes(<%= globalID %>._attributes[attribute].type));
const searchBool = Object.keys(<%= globalID %>._attributes)
.filter(attribute => attribute !== <%= globalID %>.primaryKey && !associations.includes(attribute))
.filter(attribute => ['boolean'].includes(<%= globalID %>._attributes[attribute].type));
const query = (params._q || '').replace(/[^a-zA-Z0-9.-\s]+/g, '');
return <%= globalID %>.query(qb => {
// Search in columns which are not text value.
searchNoText.forEach(attribute => {
qb.orWhereRaw(`LOWER(${attribute}) LIKE '%${_.toLower(query)}%'`);
});
if (!_.isNaN(_.toNumber(query))) {
searchInt.forEach(attribute => {
qb.orWhereRaw(`${attribute} = ${_.toNumber(query)}`);
});
}
if (query === 'true' || query === 'false') {
searchBool.forEach(attribute => {
qb.orWhereRaw(`${attribute} = ${_.toNumber(query === 'true')}`);
});
}
// Search in columns with text using index.
switch (<%= globalID %>.client) {
case 'pg': {
const searchQuery = searchText.map(attribute =>
_.toLower(attribute) === attribute
? `to_tsvector(${attribute})`
: `to_tsvector('${attribute}')`
);
qb.orWhereRaw(`${searchQuery.join(' || ')} @@ to_tsquery(?)`, query);
break;
}
default:
qb.orWhereRaw(`MATCH(${searchText.join(',')}) AGAINST(? IN BOOLEAN MODE)`, `*${query}*`);
break;
}
if (filters.sort) {
qb.orderBy(filters.sort.key, filters.sort.order);
}
if (filters.skip) {
qb.offset(_.toNumber(filters.skip));
}
if (filters.limit) {
qb.limit(_.toNumber(filters.limit));
}
}).fetchAll({
width: populate
});
2016-03-18 11:12:50 +01:00
}
};