v1.18.x
Barış Soner Uşaklı 6 years ago
parent b58ab48485
commit 8df6838561

@ -36,6 +36,8 @@ events.types = [
'password-change',
'email-change',
'username-change',
'ip-blacklist-save',
'ip-blacklist-addRule',
'registration-approved',
'registration-rejected',
'accept-membership',

@ -5,6 +5,7 @@ var async = require('async');
var user = require('../user');
var meta = require('../meta');
var events = require('../events');
var SocketBlacklist = module.exports;
@ -13,21 +14,14 @@ SocketBlacklist.validate = function (socket, data, callback) {
};
SocketBlacklist.save = function (socket, rules, callback) {
async.waterfall([
function (next) {
user.isAdminOrGlobalMod(socket.uid, next);
},
function (isAdminOrGlobalMod, next) {
if (!isAdminOrGlobalMod) {
return callback(new Error('[[error:no-privileges]]'));
}
meta.blacklist.save(rules, next);
},
], callback);
blacklist(socket, 'save', rules, callback);
};
SocketBlacklist.addRule = function (socket, rule, callback) {
blacklist(socket, 'addRule', rule, callback);
};
function blacklist(socket, method, rule, callback) {
async.waterfall([
function (next) {
user.isAdminOrGlobalMod(socket.uid, next);
@ -37,7 +31,15 @@ SocketBlacklist.addRule = function (socket, rule, callback) {
return callback(new Error('[[error:no-privileges]]'));
}
meta.blacklist.addRule(rule, next);
meta.blacklist[method](rule, next);
},
function (next) {
events.log({
type: 'ip-blacklist-' + method,
uid: socket.uid,
ip: socket.ip,
rule: rule,
}, next);
},
], callback);
};
}
Loading…
Cancel
Save