grapher/lib/query/hypernova/buildAggregatePipeline.js
2017-11-24 16:32:42 +02:00

65 lines
No EOL
1.5 KiB
JavaScript

import { _ } from 'meteor/underscore';
export default function (childCollectionNode, filters, options, userId) {
let containsDottedFields = false;
const linker = childCollectionNode.linker;
const linkStorageField = linker.linkStorageField;
const collection = childCollectionNode.collection;
let pipeline = [];
if (collection.firewall) {
collection.firewall(filters, options, userId);
}
pipeline.push({$match: filters});
if (options.sort && _.keys(options.sort).length > 0) {
pipeline.push({$sort: options.sort})
}
let _id = linkStorageField;
if (linker.isMeta()) {
_id += '._id';
}
let dataPush = {
_id: '$_id'
};
_.each(options.fields, (value, field) => {
if (field.indexOf('.') >= 0) {
containsDottedFields = true;
}
const safeField = field.replace('.', '___');
dataPush[safeField] = '$' + field
});
if (linker.isMeta()) {
dataPush[linkStorageField] = '$' + linkStorageField;
}
pipeline.push({
$group: {
_id: "$" + _id,
data: {
$push: dataPush
}
}
});
if (options.limit || options.skip) {
let $slice = ["$data"];
if (options.skip) $slice.push(options.skip);
if (options.limit) $slice.push(options.limit);
pipeline.push({
$project: {
_id: 1,
data: {$slice}
}
})
}
return {pipeline, containsDottedFields};
}