Files
NodeBB/src/socket.io/admin.js

307 lines
7.1 KiB
JavaScript
Raw Normal View History

2014-01-13 12:05:13 -05:00
"use strict";
2014-10-03 16:31:53 -04:00
var async = require('async'),
winston = require('winston'),
cluster = require('cluster'),
fs = require('fs'),
path = require('path'),
groups = require('../groups'),
2014-01-10 16:00:03 -05:00
meta = require('../meta'),
plugins = require('../plugins'),
widgets = require('../widgets'),
2014-01-10 16:00:03 -05:00
user = require('../user'),
topics = require('../topics'),
2014-10-07 16:21:12 -04:00
posts = require('../posts'),
2014-01-13 12:05:13 -05:00
categories = require('../categories'),
logger = require('../logger'),
events = require('../events'),
2014-07-30 17:12:07 -04:00
emailer = require('../emailer'),
db = require('../database'),
2014-01-16 17:32:33 -05:00
index = require('./index'),
2014-10-03 16:31:53 -04:00
2014-01-10 16:00:03 -05:00
SocketAdmin = {
2014-04-15 02:40:18 -04:00
user: require('./admin/user'),
categories: require('./admin/categories'),
groups: require('./admin/groups'),
2014-08-17 19:26:24 -04:00
tags: require('./admin/tags'),
themes: {},
plugins: {},
widgets: {},
config: {},
2014-07-30 17:12:07 -04:00
settings: {},
email: {},
analytics: {}
};
2014-01-10 16:00:03 -05:00
2014-06-03 16:10:24 -04:00
SocketAdmin.before = function(socket, method, next) {
2014-11-03 15:09:24 -05:00
if (!socket.uid) {
return;
}
2014-01-16 15:00:49 -05:00
user.isAdministrator(socket.uid, function(err, isAdmin) {
if (!err && isAdmin) {
2014-01-13 12:01:42 -05:00
next();
} else {
2014-06-03 16:10:24 -04:00
winston.warn('[socket.io] Call to admin method ( ' + method + ' ) blocked (accessed by uid ' + socket.uid + ')');
2014-01-13 12:01:42 -05:00
}
});
};
2014-08-25 10:46:48 -04:00
SocketAdmin.reload = function(socket, data, callback) {
2014-09-06 22:28:09 -04:00
events.logWithUser(socket.uid, ' is reloading NodeBB');
if (cluster.isWorker) {
process.send({
action: 'reload'
});
} else {
meta.reload(callback);
}
2014-08-25 10:46:48 -04:00
};
2014-02-22 03:11:13 -05:00
SocketAdmin.restart = function(socket, data, callback) {
2014-09-06 22:28:09 -04:00
events.logWithUser(socket.uid, ' is restarting NodeBB');
2014-02-22 03:11:13 -05:00
meta.restart();
};
SocketAdmin.fireEvent = function(socket, data, callback) {
index.server.sockets.emit(data.name, data.payload || {});
};
2014-01-16 15:13:22 -05:00
SocketAdmin.themes.getInstalled = function(socket, data, callback) {
2014-01-17 12:42:19 -05:00
meta.themes.get(callback);
2014-01-10 16:00:03 -05:00
};
2014-01-17 12:42:19 -05:00
SocketAdmin.themes.set = function(socket, data, callback) {
if(!data) {
2014-04-09 21:26:37 -04:00
return callback(new Error('[[error:invalid-data]]'));
2014-01-17 12:42:19 -05:00
}
2014-03-31 16:19:57 -04:00
2014-06-16 13:01:37 +07:00
var wrappedCallback = function(err) {
2014-03-31 16:19:57 -04:00
meta.themes.set(data, function() {
callback();
});
2014-06-16 13:01:37 +07:00
};
if (data.type === 'bootswatch') {
2014-06-16 13:01:37 +07:00
wrappedCallback();
} else {
widgets.reset(wrappedCallback);
}
};
2014-01-10 16:00:03 -05:00
2014-05-14 18:05:17 -04:00
SocketAdmin.themes.updateBranding = function(socket, data, callback) {
meta.css.updateBranding();
};
SocketAdmin.plugins.toggleActive = function(socket, plugin_id, callback) {
plugins.toggleActive(plugin_id, callback);
};
SocketAdmin.plugins.toggleInstall = function(socket, data, callback) {
plugins.toggleInstall(data.id, data.version, callback);
2014-01-10 16:00:03 -05:00
};
SocketAdmin.plugins.upgrade = function(socket, data, callback) {
plugins.upgrade(data.id, data.version, callback);
2014-10-09 18:42:05 -04:00
};
SocketAdmin.widgets.set = function(socket, data, callback) {
if(!data) {
2014-04-09 21:26:37 -04:00
return callback(new Error('[[error:invalid-data]]'));
}
widgets.setArea(data, callback);
};
2014-01-16 15:13:22 -05:00
SocketAdmin.config.get = function(socket, data, callback) {
2014-01-16 18:06:19 -05:00
meta.configs.list(callback);
2014-01-13 12:05:13 -05:00
};
2014-01-16 15:13:22 -05:00
SocketAdmin.config.set = function(socket, data, callback) {
2014-01-17 12:42:19 -05:00
if(!data) {
2014-04-09 21:26:37 -04:00
return callback(new Error('[[error:invalid-data]]'));
2014-01-17 12:42:19 -05:00
}
2014-01-13 12:05:13 -05:00
meta.configs.set(data.key, data.value, function(err) {
2014-01-16 18:06:19 -05:00
if(err) {
return callback(err);
2014-01-13 12:05:13 -05:00
}
2014-01-16 18:06:19 -05:00
callback(null);
plugins.fireHook('action:config.set', {
key: data.key,
value: data.value
});
2014-01-16 17:32:33 -05:00
logger.monitorConfig({io: index.server}, data);
2014-01-13 12:05:13 -05:00
});
};
SocketAdmin.config.setMultiple = function(socket, data, callback) {
if(!data) {
return callback(new Error('[[error:invalid-data]]'));
}
meta.configs.setMultiple(data, function(err) {
if(err) {
return callback(err);
}
callback();
var setting;
for(var field in data) {
if (data.hasOwnProperty(field)) {
setting = {
key: field,
value: data[field]
};
plugins.fireHook('action:config.set', setting);
logger.monitorConfig({io: index.server}, setting);
}
}
});
};
2014-01-16 15:13:22 -05:00
SocketAdmin.config.remove = function(socket, key) {
2014-01-13 12:05:13 -05:00
meta.configs.remove(key);
};
SocketAdmin.settings.get = function(socket, data, callback) {
meta.settings.get(data.hash, callback);
};
SocketAdmin.settings.set = function(socket, data, callback) {
meta.settings.set(data.hash, data.values, callback);
};
2014-07-30 17:12:07 -04:00
SocketAdmin.email.test = function(socket, data, callback) {
if (plugins.hasListeners('action:email.send')) {
emailer.send('test', socket.uid, {
subject: '[NodeBB] Test Email',
site_title: meta.config.title || 'NodeBB'
2014-07-30 17:12:07 -04:00
});
callback();
} else {
callback(new Error('[[error:no-emailers-configured]]'));
}
};
SocketAdmin.analytics.get = function(socket, data, callback) {
data.units = 'hours'; // temp
data.amount = 12;
if (data && data.graph && data.units && data.amount) {
if (data.graph === 'traffic') {
async.parallel({
uniqueVisitors: function(next) {
getHourlyStatsForSet('analytics:uniquevisitors', data.amount, next);
},
pageviews: function(next) {
getHourlyStatsForSet('analytics:pageviews', data.amount, next);
}
}, callback);
}
} else {
callback(new Error('Invalid analytics call'));
}
};
function getHourlyStatsForSet(set, hours, callback) {
var hour = new Date(),
terms = {},
hoursArr = [];
hour.setHours(hour.getHours(), 0, 0, 0);
for (var i = 0, ii = hours; i < ii; i++) {
hoursArr.push(hour.getTime());
hour.setHours(hour.getHours() - 1, 0, 0, 0);
}
async.each(hoursArr, function(term, next) {
if (set.indexOf('analytics') !== -1) {
db.sortedSetScore(set, term, function(err, count) {
terms[term] = count || 0;
next(err);
});
} else {
db.sortedSetCount(set, term, Date.now(), function(err, count) {
terms[term] = count || 0;
next(err);
});
}
}, function(err) {
var termsArr = [];
hoursArr.reverse();
hoursArr.forEach(function(hour, idx) {
termsArr.push(terms[hour]);
});
callback(err, termsArr);
});
}
2014-10-06 18:19:33 -04:00
SocketAdmin.getMoreEvents = function(socket, next, callback) {
if (parseInt(next, 10) < 0) {
return callback(null, {data: [], next: next});
}
events.getLog(next, 5000, callback);
};
2014-10-07 16:21:12 -04:00
SocketAdmin.dismissFlag = function(socket, pid, callback) {
if (!pid) {
return callback('[[error:invalid-data]]');
}
posts.dismissFlag(pid, callback);
};
SocketAdmin.getMoreFlags = function(socket, after, callback) {
if (!parseInt(after, 10)) {
return callback('[[error:invalid-data]]');
}
after = parseInt(after, 10);
posts.getFlags(socket.uid, after, after + 19, function(err, posts) {
callback(err, {posts: posts, next: after + 20});
});
};
2014-11-15 12:37:22 -05:00
SocketAdmin.getVoters = function(socket, pid, callback) {
async.parallel({
upvoteUids: function(next) {
db.getSetMembers('pid:' + pid + ':upvote', next);
},
downvoteUids: function(next) {
db.getSetMembers('pid:' + pid + ':downvote', next);
}
}, function(err, results) {
if (err) {
return callback(err);
}
async.parallel({
upvoters: function(next) {
user.getMultipleUserFields(results.upvoteUids, ['username', 'userslug', 'picture'], next);
},
upvoteCount: function(next) {
next(null, results.upvoteUids.length);
},
downvoters: function(next) {
user.getMultipleUserFields(results.downvoteUids, ['username', 'userslug', 'picture'], next);
},
downvoteCount: function(next) {
next(null, results.downvoteUids.length);
}
}, callback);
});
};
2014-11-15 19:09:44 -05:00
SocketAdmin.takeHeapSnapshot = function(socket, data, callback) {
require('heapdump').writeSnapshot(callback);
};
2014-02-28 12:58:05 -05:00
module.exports = SocketAdmin;