refactor: remove async.waterfall

This commit is contained in:
Barış Soner Uşaklı
2021-09-17 13:31:49 -04:00
parent 944a798552
commit f35a0f430a
5 changed files with 86 additions and 187 deletions

View File

@@ -1,32 +1,22 @@
'use strict'; 'use strict';
const async = require('async');
module.exports = { module.exports = {
name: 'Creating Global moderators group', name: 'Creating Global moderators group',
timestamp: Date.UTC(2016, 0, 23), timestamp: Date.UTC(2016, 0, 23),
method: function (callback) { method: async function () {
const groups = require('../../groups'); const groups = require('../../groups');
async.waterfall([ const exists = await groups.exists('Global Moderators');
function (next) { if (exists) {
groups.exists('Global Moderators', next); return;
}, }
function (exists, next) { await groups.create({
if (exists) { name: 'Global Moderators',
return next(null, null); userTitle: 'Global Moderator',
} description: 'Forum wide moderators',
groups.create({ hidden: 0,
name: 'Global Moderators', private: 1,
userTitle: 'Global Moderator', disableJoinRequests: 1,
description: 'Forum wide moderators', });
hidden: 0, await groups.show('Global Moderators');
private: 1,
disableJoinRequests: 1,
}, next);
},
function (groupData, next) {
groups.show('Global Moderators', next);
},
], callback);
}, },
}; };

View File

@@ -1,16 +1,13 @@
'use strict'; 'use strict';
const async = require('async');
const db = require('../../database'); const db = require('../../database');
module.exports = { module.exports = {
name: 'Adding theme to active plugins sorted set', name: 'Adding theme to active plugins sorted set',
timestamp: Date.UTC(2015, 11, 23), timestamp: Date.UTC(2015, 11, 23),
method: function (callback) { method: async function () {
async.waterfall([ const themeId = await db.getObjectField('config', 'theme:id');
async.apply(db.getObjectField, 'config', 'theme:id'), await db.sortedSetAdd('plugins:active', 0, themeId);
async.apply(db.sortedSetAdd, 'plugins:active', 0),
], callback);
}, },
}; };

View File

@@ -1,71 +1,35 @@
/* eslint-disable no-await-in-loop */
'use strict'; 'use strict';
const async = require('async');
const winston = require('winston'); const winston = require('winston');
const db = require('../../database'); const db = require('../../database');
module.exports = { module.exports = {
name: 'Giving topics:read privs to any group that was previously allowed to Find & Access Category', name: 'Giving topics:read privs to any group/user that was previously allowed to Find & Access Category',
timestamp: Date.UTC(2016, 4, 28), timestamp: Date.UTC(2016, 4, 28),
method: function (callback) { method: async function () {
const groupsAPI = require('../../groups'); const groupsAPI = require('../../groups');
const privilegesAPI = require('../../privileges'); const privilegesAPI = require('../../privileges');
db.getSortedSetRange('categories:cid', 0, -1, (err, cids) => { const cids = await db.getSortedSetRange('categories:cid', 0, -1);
if (err) { for (const cid of cids) {
return callback(err); const { groups, users } = await privilegesAPI.categories.list(cid);
for (const group of groups) {
if (group.privileges['groups:read']) {
await groupsAPI.join(`cid:${cid}:privileges:groups:topics:read`, group.name);
winston.verbose(`cid:${cid}:privileges:groups:topics:read granted to gid: ${group.name}`);
}
} }
async.eachSeries(cids, (cid, next) => { for (const user of users) {
privilegesAPI.categories.list(cid, (err, data) => { if (user.privileges.read) {
if (err) { await groupsAPI.join(`cid:${cid}:privileges:topics:read`, user.uid);
return next(err); winston.verbose(`cid:${cid}:privileges:topics:read granted to uid: ${user.uid}`);
} }
}
const { groups } = data; winston.verbose(`-- cid ${cid} upgraded`);
const { users } = data; }
async.waterfall([
function (next) {
async.eachSeries(groups, (group, next) => {
if (group.privileges['groups:read']) {
return groupsAPI.join(`cid:${cid}:privileges:groups:topics:read`, group.name, (err) => {
if (!err) {
winston.verbose(`cid:${cid}:privileges:groups:topics:read granted to gid: ${group.name}`);
}
return next(err);
});
}
next(null);
}, next);
},
function (next) {
async.eachSeries(users, (user, next) => {
if (user.privileges.read) {
return groupsAPI.join(`cid:${cid}:privileges:topics:read`, user.uid, (err) => {
if (!err) {
winston.verbose(`cid:${cid}:privileges:topics:read granted to uid: ${user.uid}`);
}
return next(err);
});
}
next(null);
}, next);
},
], (err) => {
if (!err) {
winston.verbose(`-- cid ${cid} upgraded`);
}
next(err);
});
});
}, callback);
});
}, },
}; };

View File

@@ -1,101 +1,56 @@
'use strict'; 'use strict';
const async = require('async');
const winston = require('winston'); const winston = require('winston');
const db = require('../../database'); const db = require('../../database');
module.exports = { module.exports = {
name: 'Dismiss flags from deleted topics', name: 'Dismiss flags from deleted topics',
timestamp: Date.UTC(2016, 3, 29), timestamp: Date.UTC(2016, 3, 29),
method: function (callback) { method: async function () {
const posts = require('../../posts'); const posts = require('../../posts');
const topics = require('../../topics'); const topics = require('../../topics');
let pids; const pids = await db.getSortedSetRange('posts:flagged', 0, -1);
let tids; const postData = await posts.getPostsFields(pids, ['tid']);
const tids = postData.map(t => t.tid);
const topicData = await topics.getTopicsFields(tids, ['deleted']);
const toDismiss = topicData.map((t, idx) => (parseInt(t.deleted, 10) === 1 ? pids[idx] : null)).filter(Boolean);
async.waterfall([ winston.verbose(`[2016/04/29] ${toDismiss.length} dismissable flags found`);
async.apply(db.getSortedSetRange, 'posts:flagged', 0, -1), await Promise.all(toDismiss.map(dismissFlag));
function (_pids, next) {
pids = _pids;
posts.getPostsFields(pids, ['tid'], next);
},
function (_tids, next) {
tids = _tids.map(a => a.tid);
topics.getTopicsFields(tids, ['deleted'], next);
},
function (state, next) {
const toDismiss = state.map((a, idx) => (parseInt(a.deleted, 10) === 1 ? pids[idx] : null)).filter(Boolean);
winston.verbose(`[2016/04/29] ${toDismiss.length} dismissable flags found`);
async.each(toDismiss, dismissFlag, next);
},
], callback);
}, },
}; };
// copied from core since this function was removed // copied from core since this function was removed
// https://github.com/NodeBB/NodeBB/blob/v1.x.x/src/posts/flags.js // https://github.com/NodeBB/NodeBB/blob/v1.x.x/src/posts/flags.js
function dismissFlag(pid, callback) { async function dismissFlag(pid) {
async.waterfall([ const postData = await db.getObjectFields(`post:${pid}`, ['pid', 'uid', 'flags']);
function (next) { if (!postData.pid) {
db.getObjectFields(`post:${pid}`, ['pid', 'uid', 'flags'], next); return;
}, }
function (postData, next) { if (parseInt(postData.uid, 10) && parseInt(postData.flags, 10) > 0) {
if (!postData.pid) { await Promise.all([
return callback(); db.sortedSetIncrBy('users:flags', -postData.flags, postData.uid),
} db.incrObjectFieldBy(`user:${postData.uid}`, 'flags', -postData.flags),
async.parallel([ ]);
function (next) { }
if (parseInt(postData.uid, 10)) { const uids = await db.getSortedSetRange(`pid:${pid}:flag:uids`, 0, -1);
if (parseInt(postData.flags, 10) > 0) { const nids = uids.map(uid => `post_flag:${pid}:uid:${uid}`);
async.parallel([
async.apply(db.sortedSetIncrBy, 'users:flags', -postData.flags, postData.uid),
async.apply(db.incrObjectFieldBy, `user:${postData.uid}`, 'flags', -postData.flags),
], next);
} else {
next();
}
} else {
next();
}
},
function (next) {
db.sortedSetsRemove([
'posts:flagged',
'posts:flags:count',
`uid:${postData.uid}:flag:pids`,
], pid, next);
},
function (next) {
async.series([
function (next) {
db.getSortedSetRange(`pid:${pid}:flag:uids`, 0, -1, (err, uids) => {
if (err) {
return next(err);
}
async.each(uids, (uid, next) => { await Promise.all([
const nid = `post_flag:${pid}:uid:${uid}`; db.deleteAll(nids.map(nid => `notifications:${nid}`)),
async.parallel([ db.sortedSetRemove('notifications', nids),
async.apply(db.delete, `notifications:${nid}`), db.delete(`pid:${pid}:flag:uids`),
async.apply(db.sortedSetRemove, 'notifications', `post_flag:${pid}:uid:${uid}`), db.sortedSetsRemove([
], next); 'posts:flagged',
}, next); 'posts:flags:count',
}); `uid:${postData.uid}:flag:pids`,
}, ], pid),
async.apply(db.delete, `pid:${pid}:flag:uids`), db.deleteObjectField(`post:${pid}`, 'flags'),
], next); db.delete(`pid:${pid}:flag:uid:reason`),
}, db.deleteObjectFields(`post:${pid}`, ['flag:state', 'flag:assignee', 'flag:notes', 'flag:history']),
async.apply(db.deleteObjectField, `post:${pid}`, 'flags'), ]);
async.apply(db.delete, `pid:${pid}:flag:uid:reason`),
async.apply(db.deleteObjectFields, `post:${pid}`, ['flag:state', 'flag:assignee', 'flag:notes', 'flag:history']), await db.sortedSetsRemoveRangeByScore(['users:flags'], '-inf', 0);
], next);
},
function (results, next) {
db.sortedSetsRemoveRangeByScore(['users:flags'], '-inf', 0, next);
},
], callback);
} }

View File

@@ -1,30 +1,23 @@
'use strict'; 'use strict';
const async = require('async');
module.exports = { module.exports = {
name: 'Give global search privileges', name: 'Give global search privileges',
timestamp: Date.UTC(2018, 4, 28), timestamp: Date.UTC(2018, 4, 28),
method: function (callback) { method: async function () {
const meta = require('../../meta'); const meta = require('../../meta');
const privileges = require('../../privileges'); const privileges = require('../../privileges');
const allowGuestSearching = parseInt(meta.config.allowGuestSearching, 10) === 1; const allowGuestSearching = parseInt(meta.config.allowGuestSearching, 10) === 1;
const allowGuestUserSearching = parseInt(meta.config.allowGuestUserSearching, 10) === 1; const allowGuestUserSearching = parseInt(meta.config.allowGuestUserSearching, 10) === 1;
async.waterfall([
function (next) { await privileges.global.give(['groups:search:content', 'groups:search:users', 'groups:search:tags'], 'registered-users');
privileges.global.give(['groups:search:content', 'groups:search:users', 'groups:search:tags'], 'registered-users', next); const guestPrivs = [];
}, if (allowGuestSearching) {
function (next) { guestPrivs.push('groups:search:content');
const guestPrivs = []; }
if (allowGuestSearching) { if (allowGuestUserSearching) {
guestPrivs.push('groups:search:content'); guestPrivs.push('groups:search:users');
} }
if (allowGuestUserSearching) { guestPrivs.push('groups:search:tags');
guestPrivs.push('groups:search:users'); await privileges.global.give(guestPrivs, 'guests');
}
guestPrivs.push('groups:search:tags');
privileges.global.give(guestPrivs, 'guests', next);
},
], callback);
}, },
}; };