mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-15 18:26:15 +01:00
closes #2491
This commit is contained in:
@@ -215,13 +215,14 @@ define('admin/manage/users', ['admin/modules/selectable'], function(selectable)
|
||||
}
|
||||
});
|
||||
|
||||
$('#search-user-name, #search-user-email').on('keyup', function() {
|
||||
$('#search-user-name, #search-user-email, #search-user-ip').on('keyup', function() {
|
||||
if (timeoutId !== 0) {
|
||||
clearTimeout(timeoutId);
|
||||
timeoutId = 0;
|
||||
}
|
||||
|
||||
var $this = $(this);
|
||||
var type = $this.attr('id') === 'search-user-name' ? 'username' : 'email';
|
||||
var type = $this.attr('data-search-type');
|
||||
|
||||
timeoutId = setTimeout(function() {
|
||||
$('.fa-spinner').removeClass('hidden');
|
||||
|
||||
@@ -8,7 +8,11 @@ var async = require('async'),
|
||||
module.exports = function(User) {
|
||||
|
||||
User.logIP = function(uid, ip) {
|
||||
db.sortedSetAdd('uid:' + uid + ':ip', Date.now(), ip || 'Unknown');
|
||||
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, end, callback) {
|
||||
|
||||
@@ -1,7 +1,8 @@
|
||||
|
||||
'use strict';
|
||||
|
||||
var db = require('../database');
|
||||
var async = require('async'),
|
||||
db = require('../database');
|
||||
|
||||
module.exports = function(User) {
|
||||
|
||||
@@ -9,14 +10,18 @@ module.exports = function(User) {
|
||||
if (!query || query.length === 0) {
|
||||
return callback(null, {timing:0, users:[]});
|
||||
}
|
||||
var start = process.hrtime();
|
||||
|
||||
var set = 'username:uid';
|
||||
if (type === 'email') {
|
||||
set = 'email:uid';
|
||||
if (type === 'ip') {
|
||||
return searchByIP(query, callback);
|
||||
}
|
||||
|
||||
db.getObject(set, function(err, hash) {
|
||||
var start = process.hrtime();
|
||||
var key = 'username:uid';
|
||||
if (type === 'email') {
|
||||
key = 'email:uid';
|
||||
}
|
||||
|
||||
db.getObject(key, function(err, hash) {
|
||||
if (err) {
|
||||
return callback(null, {timing: 0, users:[]});
|
||||
}
|
||||
@@ -51,4 +56,21 @@ module.exports = function(User) {
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
function searchByIP(ip, callback) {
|
||||
var start = process.hrtime();
|
||||
async.waterfall([
|
||||
function(next) {
|
||||
db.getSortedSetRevRange('ip:' + ip + ':uid', 0, -1, next);
|
||||
},
|
||||
function(uids, next) {
|
||||
User.getUsers(uids, next);
|
||||
},
|
||||
function(users, next) {
|
||||
var diff = process.hrtime(start);
|
||||
var timing = (diff[0] * 1e3 + diff[1] / 1e6).toFixed(1);
|
||||
next(null, {timing: timing, users: users});
|
||||
}
|
||||
], callback);
|
||||
}
|
||||
};
|
||||
|
||||
@@ -33,10 +33,13 @@
|
||||
|
||||
<div class="search {search_display} well">
|
||||
<label>By User Name</label>
|
||||
<input class="form-control" id="search-user-name" type="text" placeholder="Enter a username to search"/><br />
|
||||
<input class="form-control" id="search-user-name" data-search-type="username" type="text" placeholder="Enter a username to search"/><br />
|
||||
|
||||
<label>By Email </label>
|
||||
<input class="form-control" id="search-user-email" type="text" placeholder="Enter a email to search"/><br />
|
||||
<input class="form-control" id="search-user-email" data-search-type="email" type="text" placeholder="Enter a email to search"/><br />
|
||||
|
||||
<label>By IP Address </label>
|
||||
<input class="form-control" id="search-user-ip" data-search-type="ip" type="text" placeholder="Enter an IP Address to search"/><br />
|
||||
|
||||
<i class="fa fa-spinner fa-spin hidden"></i>
|
||||
<span id="user-notfound-notify" class="label label-danger hide">User not found!</span><br/>
|
||||
|
||||
Reference in New Issue
Block a user