Files
NodeBB/src/user/admin.js

62 lines
1.5 KiB
JavaScript
Raw Normal View History

'use strict';
2015-12-11 15:17:05 +02:00
var async = require('async');
var db = require('../database');
2016-07-04 17:49:02 +03:00
var posts = require('../posts');
2015-12-11 15:17:05 +02:00
var plugins = require('../plugins');
var winston = require('winston');
module.exports = function (User) {
User.logIP = function (uid, ip) {
2014-12-02 12:38:53 -05:00
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) {
2017-03-02 16:11:11 +03:00
db.getSortedSetRevRange('uid:' + uid + ':ip', 0, stop, callback);
};
User.getUsersCSV = function (callback) {
2016-11-23 17:15:31 +03:00
winston.verbose('[user/getUsersCSV] Compiling User CSV data');
var csvContent = '';
var uids;
async.waterfall([
2015-12-11 15:17:05 +02:00
function (next) {
2015-05-15 14:46:37 -04:00
db.getSortedSetRangeWithScores('username:uid', 0, -1, next);
},
2015-12-11 15:17:05 +02:00
function (users, next) {
uids = users.map(function (user) {
2015-05-15 14:46:37 -04:00
return user.score;
});
2017-02-18 12:30:49 -07:00
plugins.fireHook('filter:user.csvFields', { fields: ['uid', 'email', 'username'] }, next);
},
function (data, next) {
User.getUsersFields(uids, data.fields, next);
},
2015-12-11 15:17:05 +02:00
function (usersData, next) {
usersData.forEach(function (user) {
if (user) {
csvContent += user.email + ',' + user.username + ',' + user.uid + '\n';
}
});
next(null, csvContent);
2017-02-17 19:31:21 -07:00
},
], callback);
};
2014-03-12 21:57:25 -04:00
User.resetFlags = function (uids, callback) {
2014-12-21 16:29:32 -05:00
if (!Array.isArray(uids) || !uids.length) {
return callback();
}
2016-07-04 17:49:02 +03:00
async.eachSeries(uids, function (uid, next) {
2016-07-04 17:49:02 +03:00
posts.dismissUserFlags(uid, next);
}, callback);
2014-12-21 16:29:32 -05:00
};
};