Merge remote-tracking branch 'origin/master' into flagging-refactor

v1.18.x
Julian Lam 8 years ago
commit e227f5842a

@ -366,7 +366,7 @@ $(document).ready(function () {
} }
// Default behaviour for rss feeds // Default behaviour for rss feeds
if (internalLink && $(this).attr('href').endsWith('.rss')) { if (internalLink && $(this).attr('href') && $(this).attr('href').endsWith('.rss')) {
return; return;
} }

@ -336,91 +336,85 @@ module.exports = function (Groups) {
return process.nextTick(callback, null, cache.get(cacheKey)); return process.nextTick(callback, null, cache.get(cacheKey));
} }
db.isSortedSetMember('group:' + groupName + ':members', uid, function (err, isMember) { async.waterfall([
if (err) { function (next) {
return callback(err); db.isSortedSetMember('group:' + groupName + ':members', uid, next);
} },
function (isMember, next) {
cache.set(cacheKey, isMember); cache.set(cacheKey, isMember);
callback(null, isMember); next(null, isMember);
}); }
], callback);
}; };
Groups.isMembers = function (uids, groupName, callback) { Groups.isMembers = function (uids, groupName, callback) {
function getFromCache(next) {
process.nextTick(next, null, uids.map(function (uid) {
return cache.get(uid + ':' + groupName);
}));
}
if (!groupName || !uids.length) { if (!groupName || !uids.length) {
return callback(null, uids.map(function () {return false;})); return callback(null, uids.map(function () {return false;}));
} }
var nonCachedUids = []; var nonCachedUids = uids.filter(function (uid) {
uids.forEach(function (uid) { return !cache.has(uid + ':' + groupName);
if (!cache.has(uid + ':' + groupName)) {
nonCachedUids.push(uid);
}
}); });
if (!nonCachedUids.length) { if (!nonCachedUids.length) {
var result = uids.map(function (uid) { return getFromCache(callback);
return cache.get(uid + ':' + groupName);
});
return process.nextTick(callback, null, result);
}
db.isSortedSetMembers('group:' + groupName + ':members', nonCachedUids, function (err, isMembers) {
if (err) {
return callback(err);
} }
async.waterfall([
function (next) {
db.isSortedSetMembers('group:' + groupName + ':members', nonCachedUids, next);
},
function (isMembers, next) {
nonCachedUids.forEach(function (uid, index) { nonCachedUids.forEach(function (uid, index) {
cache.set(uid + ':' + groupName, isMembers[index]); cache.set(uid + ':' + groupName, isMembers[index]);
}); });
var result = uids.map(function (uid) { getFromCache(next);
return cache.get(uid + ':' + groupName); }
}); ], callback);
callback(null, result);
});
}; };
Groups.isMemberOfGroups = function (uid, groups, callback) { Groups.isMemberOfGroups = function (uid, groups, callback) {
function getFromCache(next) {
process.nextTick(next, null, groups.map(function (groupName) {
return cache.get(uid + ':' + groupName);
}));
}
if (!uid || parseInt(uid, 10) <= 0 || !groups.length) { if (!uid || parseInt(uid, 10) <= 0 || !groups.length) {
return callback(null, groups.map(function () {return false;})); return callback(null, groups.map(function () {return false;}));
} }
var nonCachedGroups = []; var nonCachedGroups = groups.filter(function (groupName) {
return !cache.has(uid + ':' + groupName);
groups.forEach(function (groupName) {
if (!cache.has(uid + ':' + groupName)) {
nonCachedGroups.push(groupName);
}
}); });
// are they all cached?
if (!nonCachedGroups.length) { if (!nonCachedGroups.length) {
var result = groups.map(function (groupName) { return getFromCache(callback);
return cache.get(uid + ':' + groupName);
});
return process.nextTick(callback, null, result);
} }
var nonCachedGroupsMemberSets = nonCachedGroups.map(function (groupName) { var nonCachedGroupsMemberSets = nonCachedGroups.map(function (groupName) {
return 'group:' + groupName + ':members'; return 'group:' + groupName + ':members';
}); });
db.isMemberOfSortedSets(nonCachedGroupsMemberSets, uid, function (err, isMembers) { async.waterfall([
if (err) { function (next) {
return callback(err); db.isMemberOfSortedSets(nonCachedGroupsMemberSets, uid, next);
} },
function (isMembers, next) {
nonCachedGroups.forEach(function (groupName, index) { nonCachedGroups.forEach(function (groupName, index) {
cache.set(uid + ':' + groupName, isMembers[index]); cache.set(uid + ':' + groupName, isMembers[index]);
}); });
var result = groups.map(function (groupName) { getFromCache(next);
return cache.get(uid + ':' + groupName); }
}); ], callback);
callback(null, result);
});
}; };
Groups.getMemberCount = function (groupName, callback) { Groups.getMemberCount = function (groupName, callback) {

@ -1,5 +1,7 @@
'use strict'; 'use strict';
var async = require('async');
var db = require('../database'); var db = require('../database');
var plugins = require('../plugins'); var plugins = require('../plugins');
@ -18,20 +20,20 @@ module.exports = function (Meta) {
}; };
Meta.settings.set = function (hash, values, callback) { Meta.settings.set = function (hash, values, callback) {
var key = 'settings:' + hash; async.waterfall([
db.setObject(key, values, function (err) { function (next) {
if (err) { db.setObject('settings:' + hash, values, next);
return callback(err); },
} function (next) {
plugins.fireHook('action:settings.set', { plugins.fireHook('action:settings.set', {
plugin: hash, plugin: hash,
settings: values settings: values
}); });
Meta.reloadRequired = true; Meta.reloadRequired = true;
callback(); next();
}); }
], callback);
}; };
Meta.settings.setOne = function (hash, field, value, callback) { Meta.settings.setOne = function (hash, field, value, callback) {
@ -39,10 +41,11 @@ module.exports = function (Meta) {
}; };
Meta.settings.setOnEmpty = function (hash, values, callback) { Meta.settings.setOnEmpty = function (hash, values, callback) {
db.getObject('settings:' + hash, function (err, settings) { async.waterfall([
if (err) { function (next) {
return callback(err); db.getObject('settings:' + hash, next);
} },
function (settings, next) {
settings = settings || {}; settings = settings || {};
var empty = {}; var empty = {};
Object.keys(values).forEach(function (key) { Object.keys(values).forEach(function (key) {
@ -52,10 +55,11 @@ module.exports = function (Meta) {
}); });
if (Object.keys(empty).length) { if (Object.keys(empty).length) {
db.setObject('settings:' + hash, empty, callback); db.setObject('settings:' + hash, empty, next);
} else { } else {
callback(); next();
} }
}); }
], callback);
}; };
}; };

@ -14,7 +14,6 @@ var helpers = require('./helpers');
describe('Messaging Library', function () { describe('Messaging Library', function () {
//var testUids;
var fooUid; var fooUid;
var bazUid; var bazUid;
var herpUid; var herpUid;

@ -0,0 +1,104 @@
'use strict';
var assert = require('assert');
var async = require('async');
var db = require('./mocks/databasemock');
var meta = require('../src/meta');
var User = require('../src/user');
var Groups = require('../src/groups');
describe('Messaging Library', function () {
var fooUid;
var bazUid;
var herpUid;
before(function (done) {
Groups.resetCache();
// Create 3 users: 1 admin, 2 regular
async.series([
async.apply(User.create, { username: 'foo', password: 'barbar' }), // admin
async.apply(User.create, { username: 'baz', password: 'quuxquux' }), // restricted user
async.apply(User.create, { username: 'herp', password: 'derpderp' }) // regular user
], function (err, uids) {
if (err) {
return done(err);
}
fooUid = uids[0];
bazUid = uids[1];
herpUid = uids[2];
Groups.join('administrators', fooUid, done);
});
});
describe('settings', function () {
var socketAdmin = require('../src/socket.io/admin');
it('it should set setting', function (done) {
socketAdmin.settings.set({uid: fooUid}, {hash: 'some:hash', values: {foo: '1', derp: 'value'}}, function (err) {
assert.ifError(err);
db.getObject('settings:some:hash', function (err, data) {
assert.ifError(err);
assert.equal(data.foo, '1');
assert.equal(data.derp, 'value');
done();
});
});
});
it('it should get setting', function (done) {
socketAdmin.settings.get({uid: fooUid}, {hash: 'some:hash'}, function (err, data) {
assert.ifError(err);
assert.equal(data.foo, '1');
assert.equal(data.derp, 'value');
done();
});
});
it('should not set setting if not empty', function (done) {
meta.settings.setOnEmpty('some:hash', {foo: 2}, function (err) {
assert.ifError(err);
db.getObject('settings:some:hash', function (err, data) {
assert.ifError(err);
assert.equal(data.foo, '1');
assert.equal(data.derp, 'value');
done();
});
});
});
it('should set setting if empty', function (done) {
meta.settings.setOnEmpty('some:hash', {empty: '2'}, function (err) {
assert.ifError(err);
db.getObject('settings:some:hash', function (err, data) {
assert.ifError(err);
assert.equal(data.foo, '1');
assert.equal(data.derp, 'value');
assert.equal(data.empty, '2');
done();
});
});
});
it('should set one and get one', function (done) {
meta.settings.setOne('some:hash', 'myField', 'myValue', function (err) {
assert.ifError(err);
meta.settings.getOne('some:hash', 'myField', function (err, myValue) {
assert.ifError(err);
assert.equal(myValue, 'myValue');
done();
});
});
});
});
after(function (done) {
db.emptydb(done);
});
});
Loading…
Cancel
Save