You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
nodebb/test/blacklist.js

83 lines
2.0 KiB
JavaScript

'use strict';
const async = require('async');
const assert = require('assert');
const db = require('./mocks/databasemock');
const groups = require('../src/groups');
const user = require('../src/user');
const blacklist = require('../src/meta/blacklist');
describe('blacklist', () => {
let adminUid;
before((done) => {
user.create({ username: 'admin' }, (err, uid) => {
assert.ifError(err);
adminUid = uid;
groups.join('administrators', adminUid, done);
});
});
const socketBlacklist = require('../src/socket.io/blacklist');
const rules = '1.1.1.1\n2.2.2.2\n::ffff:0:2.2.2.2\n127.0.0.1\n192.168.100.0/22';
it('should validate blacklist', (done) => {
socketBlacklist.validate({ uid: adminUid }, {
rules: rules,
}, (err, data) => {
assert.ifError(err);
done();
});
});
it('should error if not admin', (done) => {
socketBlacklist.save({ uid: 0 }, rules, (err) => {
assert.equal(err.message, '[[error:no-privileges]]');
done();
});
});
it('should save blacklist', (done) => {
socketBlacklist.save({ uid: adminUid }, rules, (err) => {
assert.ifError(err);
done();
});
});
it('should pass ip test against blacklist', (done) => {
blacklist.test('3.3.3.3', (err) => {
assert.ifError(err);
done();
});
});
it('should fail ip test against blacklist', (done) => {
blacklist.test('1.1.1.1', (err) => {
assert.equal(err.message, '[[error:blacklisted-ip]]');
done();
});
});
it('should fail ip test against blacklist with port', (done) => {
blacklist.test('1.1.1.1:4567', (err) => {
assert.equal(err.message, '[[error:blacklisted-ip]]');
done();
});
});
it('should pass ip test and not crash with ipv6 address', (done) => {
blacklist.test('2001:db8:85a3:0:0:8a2e:370:7334', (err) => {
assert.ifError(err);
done();
});
});
it('should fail ip test due to cidr', (done) => {
blacklist.test('192.168.100.1', (err) => {
assert.equal(err.message, '[[error:blacklisted-ip]]');
done();
});
});
});