Files
NodeBB/src/categories/data.js

89 lines
2.5 KiB
JavaScript
Raw Normal View History

2015-09-25 17:38:58 -04:00
'use strict';
var validator = require('validator');
var db = require('../database');
const intFields = [
'cid', 'parentCid', 'disabled', 'isSection', 'order',
'topic_count', 'post_count', 'numRecentReplies',
];
2015-09-25 17:38:58 -04:00
2018-10-20 17:07:32 -04:00
module.exports = function (Categories) {
2019-07-16 00:41:42 -04:00
Categories.getCategoriesFields = async function (cids, fields) {
2015-09-25 17:38:58 -04:00
if (!Array.isArray(cids) || !cids.length) {
2019-07-16 00:41:42 -04:00
return [];
2015-09-25 17:38:58 -04:00
}
2019-07-16 00:41:42 -04:00
let categories;
const keys = cids.map(cid => 'category:' + cid);
if (fields.length) {
categories = await db.getObjectsFields(keys, fields);
} else {
categories = await db.getObjects(keys);
}
categories.forEach(category => modifyCategory(category, fields));
return categories;
2015-09-25 17:38:58 -04:00
};
2019-07-16 00:41:42 -04:00
Categories.getCategoryData = async function (cid) {
const categories = await Categories.getCategoriesFields([cid], []);
return categories && categories.length ? categories[0] : null;
2018-10-20 17:07:32 -04:00
};
2019-07-16 00:41:42 -04:00
Categories.getCategoriesData = async function (cids) {
return await Categories.getCategoriesFields(cids, []);
2018-10-20 17:07:32 -04:00
};
2019-07-16 00:41:42 -04:00
Categories.getCategoryField = async function (cid, field) {
const category = await Categories.getCategoryFields(cid, [field]);
return category ? category[field] : null;
2018-10-20 17:07:32 -04:00
};
2019-07-16 00:41:42 -04:00
Categories.getCategoryFields = async function (cid, fields) {
const categories = await Categories.getCategoriesFields([cid], fields);
return categories ? categories[0] : null;
2018-10-20 17:07:32 -04:00
};
2019-07-16 00:41:42 -04:00
Categories.getAllCategoryFields = async function (fields) {
const cids = await Categories.getAllCidsFromSet('categories:cid');
return await Categories.getCategoriesFields(cids, fields);
2015-09-25 17:38:58 -04:00
};
2019-07-16 00:41:42 -04:00
Categories.setCategoryField = async function (cid, field, value) {
await db.setObjectField('category:' + cid, field, value);
2015-09-25 17:38:58 -04:00
};
2019-07-16 00:41:42 -04:00
Categories.incrementCategoryFieldBy = async function (cid, field, value) {
await db.incrObjectFieldBy('category:' + cid, field, value);
2015-09-25 17:38:58 -04:00
};
2017-02-18 02:30:48 -07:00
};
2018-10-20 17:07:32 -04:00
2018-10-25 19:58:01 -04:00
function modifyCategory(category, fields) {
2018-10-20 17:07:32 -04:00
if (!category) {
return;
}
2018-10-25 19:58:01 -04:00
db.parseIntFields(category, intFields, fields);
2018-10-20 17:07:32 -04:00
if (category.hasOwnProperty('name')) {
category.name = validator.escape(String(category.name || ''));
}
if (category.hasOwnProperty('icon')) {
category.icon = category.icon || 'hidden';
}
if (category.hasOwnProperty('post_count')) {
category.totalPostCount = category.post_count;
}
if (category.hasOwnProperty('topic_count')) {
category.totalTopicCount = category.topic_count;
}
if (category.description) {
category.description = validator.escape(String(category.description));
category.descriptionParsed = category.descriptionParsed || category.description;
}
}