2013-06-21 22:24:26 +00:00
|
|
|
var Server = require("./server");
|
|
|
|
var Auth = require("./auth");
|
|
|
|
var Database = require("./database");
|
2013-06-22 01:28:21 +00:00
|
|
|
var ActionLog = require("./actionlog");
|
2013-06-21 22:24:26 +00:00
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
init: function(user) {
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, "acp-init");
|
2013-06-21 22:24:26 +00:00
|
|
|
user.socket.on("acp-announce", function(data) {
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, ["acp-announce", data]);
|
2013-06-21 22:24:26 +00:00
|
|
|
Server.announcement = data;
|
|
|
|
Server.io.sockets.emit("announcement", data);
|
|
|
|
});
|
|
|
|
|
|
|
|
user.socket.on("acp-announce-clear", function() {
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, "acp-announce-clear");
|
2013-06-21 22:24:26 +00:00
|
|
|
Server.announcement = null;
|
|
|
|
});
|
|
|
|
|
|
|
|
user.socket.on("acp-global-ban", function(data) {
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, ["acp-global-ban", data.ip]);
|
2013-06-21 22:24:26 +00:00
|
|
|
Database.globalBanIP(data.ip, data.note);
|
|
|
|
user.socket.emit("acp-global-banlist", Database.refreshGlobalBans());
|
|
|
|
});
|
|
|
|
|
|
|
|
user.socket.on("acp-global-unban", function(ip) {
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, ["acp-global-unban", data.ip]);
|
2013-06-21 22:24:26 +00:00
|
|
|
Database.globalUnbanIP(ip);
|
|
|
|
user.socket.emit("acp-global-banlist", Database.refreshGlobalBans());
|
|
|
|
});
|
|
|
|
|
|
|
|
user.socket.emit("acp-global-banlist", Database.refreshGlobalBans());
|
|
|
|
|
|
|
|
user.socket.on("acp-lookup-user", function(name) {
|
|
|
|
var db = Database.getConnection();
|
|
|
|
if(!db) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var query = Database.createQuery(
|
|
|
|
"SELECT id,uname,global_rank,profile_image,profile_text,email FROM registrations WHERE uname LIKE ?",
|
|
|
|
["%"+name+"%"]
|
|
|
|
);
|
|
|
|
|
|
|
|
var res = db.querySync(query);
|
|
|
|
if(!res)
|
|
|
|
return;
|
|
|
|
|
|
|
|
var rows = res.fetchAllSync();
|
|
|
|
user.socket.emit("acp-userdata", rows);
|
|
|
|
});
|
|
|
|
|
|
|
|
user.socket.on("acp-reset-password", function(data) {
|
|
|
|
if(Auth.getGlobalRank(data.name) >= user.global_rank)
|
|
|
|
return;
|
|
|
|
try {
|
|
|
|
var hash = Database.generatePasswordReset(user.ip, data.name, data.email);
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, ["acp-reset-password", data.name]);
|
2013-06-21 22:24:26 +00:00
|
|
|
}
|
|
|
|
catch(e) {
|
|
|
|
user.socket.emit("acp-reset-password", {
|
|
|
|
success: false,
|
|
|
|
error: e
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if(hash) {
|
|
|
|
user.socket.emit("acp-reset-password", {
|
|
|
|
success: true,
|
|
|
|
hash: hash
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
user.socket.emit("acp-reset-password", {
|
|
|
|
success: false,
|
|
|
|
error: "Reset failed"
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
user.socket.on("acp-set-rank", function(data) {
|
|
|
|
if(data.rank < 1 || data.rank >= user.global_rank)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if(Auth.getGlobalRank(data.name) >= user.global_rank)
|
|
|
|
return;
|
|
|
|
|
|
|
|
var db = Database.getConnection();
|
|
|
|
if(!db)
|
|
|
|
return;
|
|
|
|
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, ["acp-set-rank", data]);
|
2013-06-21 22:24:26 +00:00
|
|
|
var query = Database.createQuery(
|
|
|
|
"UPDATE registrations SET global_rank=? WHERE uname=?",
|
|
|
|
[data.name, data.rank]
|
|
|
|
);
|
|
|
|
|
|
|
|
var res = db.querySync(query);
|
|
|
|
if(!res)
|
|
|
|
return;
|
|
|
|
|
|
|
|
user.socket.emit("acp-set-rank", data);
|
|
|
|
});
|
|
|
|
|
|
|
|
user.socket.on("acp-list-loaded", function() {
|
|
|
|
var chans = [];
|
|
|
|
for(var c in Server.channels) {
|
|
|
|
var chan = Server.channels[c];
|
|
|
|
if(!chan)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
chans.push({
|
|
|
|
name: c,
|
|
|
|
title: chan.opts.pagetitle,
|
|
|
|
usercount: chan.users.length,
|
|
|
|
mediatitle: chan.media ? chan.media.title : "-",
|
|
|
|
is_public: chan.opts.show_public,
|
|
|
|
registered: chan.registered
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
user.socket.emit("acp-list-loaded", chans);
|
|
|
|
});
|
|
|
|
|
|
|
|
user.socket.on("acp-channel-unload", function(data) {
|
|
|
|
if(data.name in Server.channels) {
|
|
|
|
var c = Server.channels[data.name];
|
|
|
|
if(!c)
|
|
|
|
return;
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, "acp-channel-unload");
|
2013-06-21 22:24:26 +00:00
|
|
|
c.initialized = data.save;
|
|
|
|
c.users.forEach(function(u) {
|
|
|
|
c.kick(u, "Channel shutting down");
|
|
|
|
});
|
|
|
|
Server.unload(c);
|
|
|
|
}
|
|
|
|
});
|
2013-06-22 01:28:21 +00:00
|
|
|
|
2013-06-22 22:54:08 +00:00
|
|
|
user.socket.on("acp-actionlog-clear", function(data) {
|
|
|
|
ActionLog.clear(data);
|
2013-06-22 01:28:21 +00:00
|
|
|
ActionLog.record(user.ip, user.name, "acp-actionlog-clear");
|
|
|
|
});
|
2013-06-21 22:24:26 +00:00
|
|
|
}
|
|
|
|
}
|