feat: async refactor
parent
47e30a67be
commit
3a9d83a44b
@ -1,36 +1,30 @@
|
||||
|
||||
'use strict';
|
||||
|
||||
var async = require('async');
|
||||
var nconf = require('nconf');
|
||||
var validator = require('validator');
|
||||
const nconf = require('nconf');
|
||||
const validator = require('validator');
|
||||
|
||||
var helpers = require('./helpers');
|
||||
var recentController = require('./recent');
|
||||
const helpers = require('./helpers');
|
||||
const recentController = require('./recent');
|
||||
|
||||
var popularController = module.exports;
|
||||
const popularController = module.exports;
|
||||
|
||||
popularController.get = function (req, res, next) {
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
recentController.getData(req, 'popular', 'posts', next);
|
||||
},
|
||||
function (data, next) {
|
||||
if (!data) {
|
||||
return next();
|
||||
}
|
||||
var term = helpers.terms[req.query.term] || 'alltime';
|
||||
if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/popular') || req.originalUrl.startsWith(nconf.get('relative_path') + '/popular')) {
|
||||
data.title = '[[pages:popular-' + term + ']]';
|
||||
var breadcrumbs = [{ text: '[[global:header.popular]]' }];
|
||||
data.breadcrumbs = helpers.buildBreadcrumbs(breadcrumbs);
|
||||
}
|
||||
var feedQs = data.rssFeedUrl.split('?')[1];
|
||||
data.rssFeedUrl = nconf.get('relative_path') + '/popular/' + (validator.escape(String(req.query.term)) || 'alltime') + '.rss';
|
||||
if (req.loggedIn) {
|
||||
data.rssFeedUrl += '?' + feedQs;
|
||||
}
|
||||
res.render('popular', data);
|
||||
},
|
||||
], next);
|
||||
popularController.get = async function (req, res, next) {
|
||||
const data = await recentController.getData(req, 'popular', 'posts');
|
||||
if (!data) {
|
||||
return next();
|
||||
}
|
||||
const term = helpers.terms[req.query.term] || 'alltime';
|
||||
if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/popular') || req.originalUrl.startsWith(nconf.get('relative_path') + '/popular')) {
|
||||
data.title = '[[pages:popular-' + term + ']]';
|
||||
const breadcrumbs = [{ text: '[[global:header.popular]]' }];
|
||||
data.breadcrumbs = helpers.buildBreadcrumbs(breadcrumbs);
|
||||
}
|
||||
|
||||
const feedQs = data.rssFeedUrl.split('?')[1];
|
||||
data.rssFeedUrl = nconf.get('relative_path') + '/popular/' + (validator.escape(String(req.query.term)) || 'alltime') + '.rss';
|
||||
if (req.loggedIn) {
|
||||
data.rssFeedUrl += '?' + feedQs;
|
||||
}
|
||||
res.render('popular', data);
|
||||
};
|
||||
|
@ -1,131 +1,93 @@
|
||||
|
||||
'use strict';
|
||||
|
||||
var async = require('async');
|
||||
var nconf = require('nconf');
|
||||
|
||||
var user = require('../user');
|
||||
var categories = require('../categories');
|
||||
var topics = require('../topics');
|
||||
var meta = require('../meta');
|
||||
var helpers = require('./helpers');
|
||||
var pagination = require('../pagination');
|
||||
var privileges = require('../privileges');
|
||||
|
||||
var recentController = module.exports;
|
||||
|
||||
recentController.get = function (req, res, next) {
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
recentController.getData(req, 'recent', 'recent', next);
|
||||
},
|
||||
function (data, next) {
|
||||
if (!data) {
|
||||
return next();
|
||||
}
|
||||
res.render('recent', data);
|
||||
},
|
||||
], next);
|
||||
const nconf = require('nconf');
|
||||
|
||||
const user = require('../user');
|
||||
const categories = require('../categories');
|
||||
const topics = require('../topics');
|
||||
const meta = require('../meta');
|
||||
const helpers = require('./helpers');
|
||||
const pagination = require('../pagination');
|
||||
const privileges = require('../privileges');
|
||||
|
||||
const recentController = module.exports;
|
||||
|
||||
recentController.get = async function (req, res, next) {
|
||||
const data = await recentController.getData(req, 'recent', 'recent');
|
||||
if (!data) {
|
||||
return next();
|
||||
}
|
||||
res.render('recent', data);
|
||||
};
|
||||
|
||||
recentController.getData = function (req, url, sort, callback) {
|
||||
var page = parseInt(req.query.page, 10) || 1;
|
||||
var stop = 0;
|
||||
var term = helpers.terms[req.query.term];
|
||||
var settings;
|
||||
var cid = req.query.cid;
|
||||
var filter = req.query.filter || '';
|
||||
var categoryData;
|
||||
var rssToken;
|
||||
var canPost;
|
||||
recentController.getData = async function (req, url, sort) {
|
||||
const page = parseInt(req.query.page, 10) || 1;
|
||||
let term = helpers.terms[req.query.term];
|
||||
const cid = req.query.cid;
|
||||
const filter = req.query.filter || '';
|
||||
|
||||
if (!helpers.validFilters[filter] || (!term && req.query.term)) {
|
||||
return callback(null, null);
|
||||
return null;
|
||||
}
|
||||
term = term || 'alltime';
|
||||
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
async.parallel({
|
||||
settings: function (next) {
|
||||
user.getSettings(req.uid, next);
|
||||
},
|
||||
categories: function (next) {
|
||||
const states = [categories.watchStates.watching, categories.watchStates.notwatching];
|
||||
if (filter === 'watched') {
|
||||
states.push(categories.watchStates.ignoring);
|
||||
}
|
||||
helpers.getCategoriesByStates(req.uid, cid, states, next);
|
||||
},
|
||||
rssToken: function (next) {
|
||||
user.auth.getFeedToken(req.uid, next);
|
||||
},
|
||||
canPost: function (next) {
|
||||
canPostTopic(req.uid, next);
|
||||
},
|
||||
}, next);
|
||||
},
|
||||
function (results, next) {
|
||||
rssToken = results.rssToken;
|
||||
settings = results.settings;
|
||||
categoryData = results.categories;
|
||||
canPost = results.canPost;
|
||||
|
||||
var start = Math.max(0, (page - 1) * settings.topicsPerPage);
|
||||
stop = start + settings.topicsPerPage - 1;
|
||||
|
||||
topics.getSortedTopics({
|
||||
cids: cid,
|
||||
uid: req.uid,
|
||||
start: start,
|
||||
stop: stop,
|
||||
filter: filter,
|
||||
term: term,
|
||||
sort: sort,
|
||||
query: req.query,
|
||||
}, next);
|
||||
},
|
||||
function (data, next) {
|
||||
data.canPost = canPost;
|
||||
data.categories = categoryData.categories;
|
||||
data.allCategoriesUrl = url + helpers.buildQueryString('', filter, '');
|
||||
data.selectedCategory = categoryData.selectedCategory;
|
||||
data.selectedCids = categoryData.selectedCids;
|
||||
data['feeds:disableRSS'] = meta.config['feeds:disableRSS'];
|
||||
data.rssFeedUrl = nconf.get('relative_path') + '/' + url + '.rss';
|
||||
if (req.loggedIn) {
|
||||
data.rssFeedUrl += '?uid=' + req.uid + '&token=' + rssToken;
|
||||
}
|
||||
data.title = meta.config.homePageTitle || '[[pages:home]]';
|
||||
|
||||
data.filters = helpers.buildFilters(url, filter, req.query);
|
||||
data.selectedFilter = data.filters.find(filter => filter && filter.selected);
|
||||
data.terms = helpers.buildTerms(url, term, req.query);
|
||||
data.selectedTerm = data.terms.find(term => term && term.selected);
|
||||
|
||||
var pageCount = Math.max(1, Math.ceil(data.topicCount / settings.topicsPerPage));
|
||||
data.pagination = pagination.create(page, pageCount, req.query);
|
||||
|
||||
if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/' + url) || req.originalUrl.startsWith(nconf.get('relative_path') + '/' + url)) {
|
||||
data.title = '[[pages:' + url + ']]';
|
||||
data.breadcrumbs = helpers.buildBreadcrumbs([{ text: '[[' + url + ':title]]' }]);
|
||||
}
|
||||
|
||||
next(null, data);
|
||||
},
|
||||
], callback);
|
||||
const states = [categories.watchStates.watching, categories.watchStates.notwatching];
|
||||
if (filter === 'watched') {
|
||||
states.push(categories.watchStates.ignoring);
|
||||
}
|
||||
|
||||
const [settings, categoryData, rssToken, canPost] = await Promise.all([
|
||||
user.getSettings(req.uid),
|
||||
helpers.getCategoriesByStates(req.uid, cid, states),
|
||||
user.auth.getFeedToken(req.uid),
|
||||
canPostTopic(req.uid),
|
||||
]);
|
||||
|
||||
const start = Math.max(0, (page - 1) * settings.topicsPerPage);
|
||||
const stop = start + settings.topicsPerPage - 1;
|
||||
|
||||
const data = await topics.getSortedTopics({
|
||||
cids: cid,
|
||||
uid: req.uid,
|
||||
start: start,
|
||||
stop: stop,
|
||||
filter: filter,
|
||||
term: term,
|
||||
sort: sort,
|
||||
query: req.query,
|
||||
});
|
||||
|
||||
data.canPost = canPost;
|
||||
data.categories = categoryData.categories;
|
||||
data.allCategoriesUrl = url + helpers.buildQueryString('', filter, '');
|
||||
data.selectedCategory = categoryData.selectedCategory;
|
||||
data.selectedCids = categoryData.selectedCids;
|
||||
data['feeds:disableRSS'] = meta.config['feeds:disableRSS'];
|
||||
data.rssFeedUrl = nconf.get('relative_path') + '/' + url + '.rss';
|
||||
if (req.loggedIn) {
|
||||
data.rssFeedUrl += '?uid=' + req.uid + '&token=' + rssToken;
|
||||
}
|
||||
data.title = meta.config.homePageTitle || '[[pages:home]]';
|
||||
|
||||
data.filters = helpers.buildFilters(url, filter, req.query);
|
||||
data.selectedFilter = data.filters.find(filter => filter && filter.selected);
|
||||
data.terms = helpers.buildTerms(url, term, req.query);
|
||||
data.selectedTerm = data.terms.find(term => term && term.selected);
|
||||
|
||||
var pageCount = Math.max(1, Math.ceil(data.topicCount / settings.topicsPerPage));
|
||||
data.pagination = pagination.create(page, pageCount, req.query);
|
||||
|
||||
if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/' + url) || req.originalUrl.startsWith(nconf.get('relative_path') + '/' + url)) {
|
||||
data.title = '[[pages:' + url + ']]';
|
||||
data.breadcrumbs = helpers.buildBreadcrumbs([{ text: '[[' + url + ':title]]' }]);
|
||||
}
|
||||
|
||||
return data;
|
||||
};
|
||||
|
||||
function canPostTopic(uid, callback) {
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
categories.getAllCidsFromSet('categories:cid', next);
|
||||
},
|
||||
function (cids, next) {
|
||||
privileges.categories.filterCids('topics:create', cids, uid, next);
|
||||
},
|
||||
function (cids, next) {
|
||||
next(null, cids.length > 0);
|
||||
},
|
||||
], callback);
|
||||
async function canPostTopic(uid) {
|
||||
let cids = await categories.getAllCidsFromSet('categories:cid');
|
||||
cids = await privileges.categories.filterCids('topics:create', cids, uid);
|
||||
return cids.length > 0;
|
||||
}
|
||||
|
@ -1,35 +1,28 @@
|
||||
|
||||
'use strict';
|
||||
|
||||
var async = require('async');
|
||||
var nconf = require('nconf');
|
||||
var validator = require('validator');
|
||||
const nconf = require('nconf');
|
||||
const validator = require('validator');
|
||||
|
||||
var helpers = require('./helpers');
|
||||
var recentController = require('./recent');
|
||||
const helpers = require('./helpers');
|
||||
const recentController = require('./recent');
|
||||
|
||||
var topController = module.exports;
|
||||
const topController = module.exports;
|
||||
|
||||
topController.get = function (req, res, next) {
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
recentController.getData(req, 'top', 'votes', next);
|
||||
},
|
||||
function (data, next) {
|
||||
if (!data) {
|
||||
return next();
|
||||
}
|
||||
var term = helpers.terms[req.query.term] || 'alltime';
|
||||
if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/top') || req.originalUrl.startsWith(nconf.get('relative_path') + '/top')) {
|
||||
data.title = '[[pages:top-' + term + ']]';
|
||||
}
|
||||
topController.get = async function (req, res, next) {
|
||||
const data = await recentController.getData(req, 'top', 'votes');
|
||||
if (!data) {
|
||||
return next();
|
||||
}
|
||||
const term = helpers.terms[req.query.term] || 'alltime';
|
||||
if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/top') || req.originalUrl.startsWith(nconf.get('relative_path') + '/top')) {
|
||||
data.title = '[[pages:top-' + term + ']]';
|
||||
}
|
||||
|
||||
var feedQs = data.rssFeedUrl.split('?')[1];
|
||||
data.rssFeedUrl = nconf.get('relative_path') + '/top/' + (validator.escape(String(req.query.term)) || 'alltime') + '.rss';
|
||||
if (req.loggedIn) {
|
||||
data.rssFeedUrl += '?' + feedQs;
|
||||
}
|
||||
res.render('top', data);
|
||||
},
|
||||
], next);
|
||||
const feedQs = data.rssFeedUrl.split('?')[1];
|
||||
data.rssFeedUrl = nconf.get('relative_path') + '/top/' + (validator.escape(String(req.query.term)) || 'alltime') + '.rss';
|
||||
if (req.loggedIn) {
|
||||
data.rssFeedUrl += '?' + feedQs;
|
||||
}
|
||||
res.render('top', data);
|
||||
};
|
||||
|
Loading…
Reference in New Issue