all files / src/user/ admin.js

22.22% Statements 10/45
0% Branches 0/12
4.76% Functions 1/21
22.22% Lines 10/45
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96                                                                                                                                                                           
 
'use strict';
 
var async = require('async');
var db = require('../database');
var plugins = require('../plugins');
 
module.exports = function(User) {
 
	User.logIP = function(uid, ip) {
		var now = Date.now();
		db.sortedSetAdd('uid:' + uid + ':ip', now, ip || 'Unknown');
		if (ip) {
			db.sortedSetAdd('ip:' + ip + ':uid', now, uid);
		}
	};
 
	User.getIPs = function(uid, stop, callback) {
		db.getSortedSetRevRange('uid:' + uid + ':ip', 0, stop, function(err, ips) {
			if (err) {
				return callback(err);
			}
 
			callback(null, ips.map(function(ip) {
				return {ip:ip};
			}));
		});
	};
 
	User.getUsersCSV = function(callback) {
		var csvContent = '';
 
		async.waterfall([
			function (next) {
				db.getSortedSetRangeWithScores('username:uid', 0, -1, next);
			},
			function (users, next) {
				var uids = users.map(function(user) {
					return user.score;
				});
				User.getUsersFields(uids, ['uid', 'email', 'username'], next);
			},
			function (usersData, next) {
				usersData.forEach(function(user) {
					if (user) {
						csvContent += user.email + ',' + user.username + ',' + user.uid + '\n';
					}
				});
 
				next(null, csvContent);
			}
		], callback);
	};
 
	User.ban = function(uid, callback) {
		async.waterfall([
			function (next) {
				User.setUserField(uid, 'banned', 1, next);
			},
			function (next) {
				db.sortedSetAdd('users:banned', Date.now(), uid, next);
			},
			function (next) {
				plugins.fireHook('action:user.banned', {uid: uid});
				next();
			}
		], callback);
	};
 
	User.unban = function(uid, callback) {
		db.delete('uid:' + uid + ':flagged_by');
		async.waterfall([
			function (next) {
				User.setUserField(uid, 'banned', 0, next);
			},
			function (next) {
				db.sortedSetRemove('users:banned', uid, next);
			},
			function (next) {
				plugins.fireHook('action:user.unbanned', {uid: uid});
				next();
			}
		], callback);
	};
 
	User.resetFlags = function(uids, callback) {
		if (!Array.isArray(uids) || !uids.length) {
			return callback();
		}
		var keys = uids.map(function(uid) {
			return 'uid:' + uid + ':flagged_by';
		});
		db.deleteAll(keys, callback);
	};
};