mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-11-03 20:45:58 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			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();
 | 
						|
		});
 | 
						|
	});
 | 
						|
});
 |