feat: async refactor

v1.18.x
Baris Usakli 6 years ago
parent 47e30a67be
commit 3a9d83a44b

@ -1,46 +1,40 @@
'use strict'; 'use strict';
var async = require('async'); const nconf = require('nconf');
var nconf = require('nconf');
var user = require('../user'); const user = require('../user');
var plugins = require('../plugins'); const plugins = require('../plugins');
var topics = require('../topics'); const topics = require('../topics');
var posts = require('../posts'); const posts = require('../posts');
var helpers = require('./helpers'); const helpers = require('./helpers');
exports.get = function (req, res, callback) { exports.get = async function (req, res, callback) {
res.locals.metaTags = { res.locals.metaTags = {
...res.locals.metaTags, ...res.locals.metaTags,
name: 'robots', name: 'robots',
content: 'noindex', content: 'noindex',
}; };
async.waterfall([ const data = await plugins.fireHook('filter:composer.build', {
function (next) { req: req,
plugins.fireHook('filter:composer.build', { res: res,
req: req, next: callback,
res: res, templateData: {},
next: callback, });
templateData: {},
}, next); if (data.templateData.disabled) {
}, res.render('', {
function (data) { title: '[[modules:composer.compose]]',
if (data.templateData.disabled) { });
res.render('', { } else {
title: '[[modules:composer.compose]]', data.templateData.title = '[[modules:composer.compose]]';
}); res.render('compose', data.templateData);
} else { }
data.templateData.title = '[[modules:composer.compose]]';
res.render('compose', data.templateData);
}
},
], callback);
}; };
exports.post = function (req, res) { exports.post = async function (req, res) {
var body = req.body; const body = req.body;
var data = { const data = {
uid: req.uid, uid: req.uid,
req: req, req: req,
timestamp: Date.now(), timestamp: Date.now(),
@ -52,49 +46,37 @@ exports.post = function (req, res) {
if (!data.content) { if (!data.content) {
return helpers.noScriptErrors(req, res, '[[error:invalid-data]]', 400); return helpers.noScriptErrors(req, res, '[[error:invalid-data]]', 400);
} }
async function queueOrPost(postFn, data) {
const shouldQueue = await posts.shouldQueue(req.uid, data);
if (shouldQueue) {
delete data.req;
return await posts.addToQueue(data);
}
return await postFn(data);
}
async.waterfall([ try {
function (next) { let result;
function queueOrPost(postFn, data, next) { if (body.tid) {
async.waterfall([ data.tid = body.tid;
function (next) { result = await queueOrPost(topics.reply, data);
posts.shouldQueue(req.uid, data, next); } else if (body.cid) {
}, data.cid = body.cid;
function (shouldQueue, next) { data.title = body.title;
if (shouldQueue) { data.tags = [];
delete data.req; data.thumb = '';
posts.addToQueue(data, next); result = await queueOrPost(topics.post, data);
} else { } else {
postFn(data, next); throw new Error('[[error:invalid-data]]');
} }
}, if (result.queued) {
], next); return res.redirect((nconf.get('relative_path') || '/'));
}
if (body.tid) {
data.tid = body.tid;
queueOrPost(topics.reply, data, next);
} else if (body.cid) {
data.cid = body.cid;
data.title = body.title;
data.tags = [];
data.thumb = '';
queueOrPost(topics.post, data, next);
} else {
next(new Error('[[error:invalid-data]]'));
}
},
function (result, next) {
if (result.queued) {
return res.redirect((nconf.get('relative_path') || '/'));
}
var uid = result.uid ? result.uid : result.topicData.uid;
user.updateOnlineUsers(uid);
next(null, result.pid ? '/post/' + result.pid : '/topic/' + result.topicData.slug);
},
], function (err, path) {
if (err) {
return helpers.noScriptErrors(req, res, err.message, 400);
} }
const uid = result.uid ? result.uid : result.topicData.uid;
user.updateOnlineUsers(uid);
const path = result.pid ? '/post/' + result.pid : '/topic/' + result.topicData.slug;
res.redirect(nconf.get('relative_path') + path); res.redirect(nconf.get('relative_path') + path);
}); } catch (err) {
helpers.noScriptErrors(req, res, err.message, 400);
}
}; };

@ -1,66 +1,52 @@
'use strict'; 'use strict';
var async = require('async'); const url = require('url');
var url = require('url');
var plugins = require('../plugins'); const plugins = require('../plugins');
var meta = require('../meta'); const meta = require('../meta');
var user = require('../user'); const user = require('../user');
function adminHomePageRoute() { function adminHomePageRoute() {
return (meta.config.homePageRoute || meta.config.homePageCustom || '').replace(/^\/+/, '') || 'categories'; return (meta.config.homePageRoute || meta.config.homePageCustom || '').replace(/^\/+/, '') || 'categories';
} }
function getUserHomeRoute(uid, callback) { async function getUserHomeRoute(uid) {
async.waterfall([ const settings = await user.getSettings(uid);
function (next) { let route = adminHomePageRoute();
user.getSettings(uid, next);
},
function (settings, next) {
var route = adminHomePageRoute();
if (settings.homePageRoute !== 'undefined' && settings.homePageRoute !== 'none') { if (settings.homePageRoute !== 'undefined' && settings.homePageRoute !== 'none') {
route = (settings.homePageRoute || route).replace(/^\/+/, ''); route = (settings.homePageRoute || route).replace(/^\/+/, '');
} }
next(null, route); return route;
},
], callback);
} }
function rewrite(req, res, next) { async function rewrite(req, res, next) {
if (req.path !== '/' && req.path !== '/api/' && req.path !== '/api') { if (req.path !== '/' && req.path !== '/api/' && req.path !== '/api') {
return next(); return next();
} }
let route = adminHomePageRoute();
if (meta.config.allowUserHomePage) {
route = await getUserHomeRoute(req.uid, next);
}
async.waterfall([ let parsedUrl;
function (next) { try {
if (meta.config.allowUserHomePage) { parsedUrl = url.parse(route, true);
getUserHomeRoute(req.uid, next); } catch (err) {
} else { return next(err);
next(null, adminHomePageRoute()); }
}
},
function (route, next) {
var parsedUrl;
try {
parsedUrl = url.parse(route, true);
} catch (err) {
return next(err);
}
var pathname = parsedUrl.pathname; const pathname = parsedUrl.pathname;
var hook = 'action:homepage.get:' + pathname; const hook = 'action:homepage.get:' + pathname;
if (!plugins.hasListeners(hook)) { if (!plugins.hasListeners(hook)) {
req.url = req.path + (!req.path.endsWith('/') ? '/' : '') + pathname; req.url = req.path + (!req.path.endsWith('/') ? '/' : '') + pathname;
} else { } else {
res.locals.homePageRoute = pathname; res.locals.homePageRoute = pathname;
} }
req.query = Object.assign(parsedUrl.query, req.query); req.query = Object.assign(parsedUrl.query, req.query);
next(); next();
},
], next);
} }
exports.rewrite = rewrite; exports.rewrite = rewrite;

@ -1,36 +1,30 @@
'use strict'; 'use strict';
var async = require('async'); const nconf = require('nconf');
var nconf = require('nconf'); const validator = require('validator');
var validator = require('validator');
var helpers = require('./helpers'); const helpers = require('./helpers');
var recentController = require('./recent'); const recentController = require('./recent');
var popularController = module.exports; const popularController = module.exports;
popularController.get = function (req, res, next) { popularController.get = async function (req, res, next) {
async.waterfall([ const data = await recentController.getData(req, 'popular', 'posts');
function (next) { if (!data) {
recentController.getData(req, 'popular', 'posts', next); return next();
}, }
function (data, next) { const term = helpers.terms[req.query.term] || 'alltime';
if (!data) { if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/popular') || req.originalUrl.startsWith(nconf.get('relative_path') + '/popular')) {
return next(); data.title = '[[pages:popular-' + term + ']]';
} const breadcrumbs = [{ text: '[[global:header.popular]]' }];
var term = helpers.terms[req.query.term] || 'alltime'; data.breadcrumbs = helpers.buildBreadcrumbs(breadcrumbs);
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]]' }]; const feedQs = data.rssFeedUrl.split('?')[1];
data.breadcrumbs = helpers.buildBreadcrumbs(breadcrumbs); data.rssFeedUrl = nconf.get('relative_path') + '/popular/' + (validator.escape(String(req.query.term)) || 'alltime') + '.rss';
} if (req.loggedIn) {
var feedQs = data.rssFeedUrl.split('?')[1]; data.rssFeedUrl += '?' + feedQs;
data.rssFeedUrl = nconf.get('relative_path') + '/popular/' + (validator.escape(String(req.query.term)) || 'alltime') + '.rss'; }
if (req.loggedIn) { res.render('popular', data);
data.rssFeedUrl += '?' + feedQs;
}
res.render('popular', data);
},
], next);
}; };

@ -1,131 +1,93 @@
'use strict'; 'use strict';
var async = require('async'); const nconf = require('nconf');
var nconf = require('nconf');
const user = require('../user');
var user = require('../user'); const categories = require('../categories');
var categories = require('../categories'); const topics = require('../topics');
var topics = require('../topics'); const meta = require('../meta');
var meta = require('../meta'); const helpers = require('./helpers');
var helpers = require('./helpers'); const pagination = require('../pagination');
var pagination = require('../pagination'); const privileges = require('../privileges');
var privileges = require('../privileges');
const recentController = module.exports;
var recentController = module.exports;
recentController.get = async function (req, res, next) {
recentController.get = function (req, res, next) { const data = await recentController.getData(req, 'recent', 'recent');
async.waterfall([ if (!data) {
function (next) { return next();
recentController.getData(req, 'recent', 'recent', next); }
}, res.render('recent', data);
function (data, next) {
if (!data) {
return next();
}
res.render('recent', data);
},
], next);
}; };
recentController.getData = function (req, url, sort, callback) { recentController.getData = async function (req, url, sort) {
var page = parseInt(req.query.page, 10) || 1; const page = parseInt(req.query.page, 10) || 1;
var stop = 0; let term = helpers.terms[req.query.term];
var term = helpers.terms[req.query.term]; const cid = req.query.cid;
var settings; const filter = req.query.filter || '';
var cid = req.query.cid;
var filter = req.query.filter || '';
var categoryData;
var rssToken;
var canPost;
if (!helpers.validFilters[filter] || (!term && req.query.term)) { if (!helpers.validFilters[filter] || (!term && req.query.term)) {
return callback(null, null); return null;
} }
term = term || 'alltime'; term = term || 'alltime';
async.waterfall([ const states = [categories.watchStates.watching, categories.watchStates.notwatching];
function (next) { if (filter === 'watched') {
async.parallel({ states.push(categories.watchStates.ignoring);
settings: function (next) { }
user.getSettings(req.uid, next);
}, const [settings, categoryData, rssToken, canPost] = await Promise.all([
categories: function (next) { user.getSettings(req.uid),
const states = [categories.watchStates.watching, categories.watchStates.notwatching]; helpers.getCategoriesByStates(req.uid, cid, states),
if (filter === 'watched') { user.auth.getFeedToken(req.uid),
states.push(categories.watchStates.ignoring); canPostTopic(req.uid),
} ]);
helpers.getCategoriesByStates(req.uid, cid, states, next);
}, const start = Math.max(0, (page - 1) * settings.topicsPerPage);
rssToken: function (next) { const stop = start + settings.topicsPerPage - 1;
user.auth.getFeedToken(req.uid, next);
}, const data = await topics.getSortedTopics({
canPost: function (next) { cids: cid,
canPostTopic(req.uid, next); uid: req.uid,
}, start: start,
}, next); stop: stop,
}, filter: filter,
function (results, next) { term: term,
rssToken = results.rssToken; sort: sort,
settings = results.settings; query: req.query,
categoryData = results.categories; });
canPost = results.canPost;
data.canPost = canPost;
var start = Math.max(0, (page - 1) * settings.topicsPerPage); data.categories = categoryData.categories;
stop = start + settings.topicsPerPage - 1; data.allCategoriesUrl = url + helpers.buildQueryString('', filter, '');
data.selectedCategory = categoryData.selectedCategory;
topics.getSortedTopics({ data.selectedCids = categoryData.selectedCids;
cids: cid, data['feeds:disableRSS'] = meta.config['feeds:disableRSS'];
uid: req.uid, data.rssFeedUrl = nconf.get('relative_path') + '/' + url + '.rss';
start: start, if (req.loggedIn) {
stop: stop, data.rssFeedUrl += '?uid=' + req.uid + '&token=' + rssToken;
filter: filter, }
term: term, data.title = meta.config.homePageTitle || '[[pages:home]]';
sort: sort,
query: req.query, data.filters = helpers.buildFilters(url, filter, req.query);
}, next); data.selectedFilter = data.filters.find(filter => filter && filter.selected);
}, data.terms = helpers.buildTerms(url, term, req.query);
function (data, next) { data.selectedTerm = data.terms.find(term => term && term.selected);
data.canPost = canPost;
data.categories = categoryData.categories; var pageCount = Math.max(1, Math.ceil(data.topicCount / settings.topicsPerPage));
data.allCategoriesUrl = url + helpers.buildQueryString('', filter, ''); data.pagination = pagination.create(page, pageCount, req.query);
data.selectedCategory = categoryData.selectedCategory;
data.selectedCids = categoryData.selectedCids; if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/' + url) || req.originalUrl.startsWith(nconf.get('relative_path') + '/' + url)) {
data['feeds:disableRSS'] = meta.config['feeds:disableRSS']; data.title = '[[pages:' + url + ']]';
data.rssFeedUrl = nconf.get('relative_path') + '/' + url + '.rss'; data.breadcrumbs = helpers.buildBreadcrumbs([{ text: '[[' + url + ':title]]' }]);
if (req.loggedIn) { }
data.rssFeedUrl += '?uid=' + req.uid + '&token=' + rssToken;
} return data;
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);
}; };
function canPostTopic(uid, callback) { async function canPostTopic(uid) {
async.waterfall([ let cids = await categories.getAllCidsFromSet('categories:cid');
function (next) { cids = await privileges.categories.filterCids('topics:create', cids, uid);
categories.getAllCidsFromSet('categories:cid', next); return cids.length > 0;
},
function (cids, next) {
privileges.categories.filterCids('topics:create', cids, uid, next);
},
function (cids, next) {
next(null, cids.length > 0);
},
], callback);
} }

@ -1,35 +1,28 @@
'use strict'; 'use strict';
var async = require('async'); const nconf = require('nconf');
var nconf = require('nconf'); const validator = require('validator');
var validator = require('validator');
var helpers = require('./helpers'); const helpers = require('./helpers');
var recentController = require('./recent'); const recentController = require('./recent');
var topController = module.exports; const topController = module.exports;
topController.get = function (req, res, next) { topController.get = async function (req, res, next) {
async.waterfall([ const data = await recentController.getData(req, 'top', 'votes');
function (next) { if (!data) {
recentController.getData(req, 'top', 'votes', next); return next();
}, }
function (data, next) { const term = helpers.terms[req.query.term] || 'alltime';
if (!data) { if (req.originalUrl.startsWith(nconf.get('relative_path') + '/api/top') || req.originalUrl.startsWith(nconf.get('relative_path') + '/top')) {
return next(); data.title = '[[pages:top-' + term + ']]';
} }
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 + ']]';
}
var feedQs = data.rssFeedUrl.split('?')[1]; const feedQs = data.rssFeedUrl.split('?')[1];
data.rssFeedUrl = nconf.get('relative_path') + '/top/' + (validator.escape(String(req.query.term)) || 'alltime') + '.rss'; data.rssFeedUrl = nconf.get('relative_path') + '/top/' + (validator.escape(String(req.query.term)) || 'alltime') + '.rss';
if (req.loggedIn) { if (req.loggedIn) {
data.rssFeedUrl += '?' + feedQs; data.rssFeedUrl += '?' + feedQs;
} }
res.render('top', data); res.render('top', data);
},
], next);
}; };

Loading…
Cancel
Save