'use strict'; var async = require('async'); var db = require('../database'); var batch = require('../batch'); var plugins = require('../plugins'); var topics = require('../topics'); var groups = require('../groups'); var privileges = require('../privileges'); module.exports = function (Categories) { Categories.purge = function (cid, uid, callback) { async.waterfall([ function (next) { batch.processSortedSet('cid:' + cid + ':tids', function (tids, next) { async.eachLimit(tids, 10, function (tid, next) { topics.purgePostsAndTopic(tid, uid, next); }, next); }, {alwaysStartAt: 0}, next); }, function (next) { Categories.getPinnedTids('cid:' + cid + ':tids:pinned', 0, -1, next); }, function (pinnedTids, next) { async.eachLimit(pinnedTids, 10, function (tid, next) { topics.purgePostsAndTopic(tid, uid, next); }, next); }, function (next) { purgeCategory(cid, next); }, function (next) { plugins.fireHook('action:category.delete', cid); next(); } ], callback); }; function purgeCategory(cid, callback) { async.series([ function (next) { db.sortedSetRemove('categories:cid', cid, next); }, function (next) { removeFromParent(cid, next); }, function (next) { db.deleteAll([ 'cid:' + cid + ':tids', 'cid:' + cid + ':tids:pinned', 'cid:' + cid + ':tids:posts', 'cid:' + cid + ':pids', 'cid:' + cid + ':read_by_uid', 'cid:' + cid + ':ignorers', 'cid:' + cid + ':children', 'category:' + cid ], next); }, function (next) { async.each(privileges.privilegeList, function (privilege, next) { groups.destroy('cid:' + cid + ':privileges:' + privilege, next); }, next); } ], function (err) { callback(err); }); } function removeFromParent(cid, callback) { async.waterfall([ function (next) { async.parallel({ parentCid: function (next) { Categories.getCategoryField(cid, 'parentCid', next); }, children: function (next) { db.getSortedSetRange('cid:' + cid + ':children', 0, -1, next); } }, next); }, function (results, next) { async.parallel([ function (next) { results.parentCid = parseInt(results.parentCid, 10) || 0; db.sortedSetRemove('cid:' + results.parentCid + ':children', cid, next); }, function (next) { async.each(results.children, function (cid, next) { async.parallel([ function (next) { db.setObjectField('category:' + cid, 'parentCid', 0, next); }, function (next) { db.sortedSetAdd('cid:0:children', cid, cid, next); } ], next); }, next); } ], next); } ], function (err) { callback(err); }); } };