Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) Safe-mode: OFF (not secure) /var/www/html/wincloud_gateway/node_modules/strapi-database/lib/queries/ drwxr-xr-x | |
| Viewing file: Select action/file-type: 'use strict';
const { prop, assoc } = require('lodash/fp');
const { MANY_RELATIONS } = require('strapi-utils').relations.constants;
const { isVisibleAttribute } = require('strapi-utils').contentTypes;
const createRelationsCountsQuery = ({ model, fn, connectorQuery }) => {
// fetch counter map
const fetchCounters = async (...args) => {
const results = await connectorQuery.fetchRelationCounters(...args);
return results.reduce((map, { id, count }) => assoc(id, Number(count), map), {});
};
return async function(params, populate) {
const toCount = [];
const toPopulate = [];
model.associations
.filter(assoc => !populate || populate.includes(assoc.alias))
.forEach(assoc => {
if (MANY_RELATIONS.includes(assoc.nature) && isVisibleAttribute(model, assoc.alias)) {
return toCount.push(assoc);
}
toPopulate.push(assoc.alias);
});
const { results, pagination } = await fn(params, toPopulate);
const resultsIds = results.map(prop('id'));
const counters = await Promise.all(
toCount.map(async ({ alias }) => ({
field: alias,
counts: await fetchCounters(alias, resultsIds),
}))
);
results.forEach(entity => {
counters.forEach(({ field, counts }) => {
entity[field] = { count: counts[entity.id] || 0 };
});
});
return {
results,
pagination,
};
};
};
module.exports = {
createRelationsCountsQuery,
};
|
:: Command execute :: | |
--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0455 ]-- |