mirror of https://github.com/calzoneman/sync.git
Merge branch 'dev' of github.com:calzoneman/sync into dev
This commit is contained in:
commit
e47c1abff7
6
acp.js
6
acp.js
|
@ -150,6 +150,12 @@ module.exports = function (Server) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
user.socket.on("acp-actionlog-list", function () {
|
||||||
|
user.socket.emit("acp-actionlog-list",
|
||||||
|
ActionLog.getLogTypes()
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
user.socket.on("acp-actionlog-clear", function(data) {
|
user.socket.on("acp-actionlog-clear", function(data) {
|
||||||
ActionLog.clear(data);
|
ActionLog.clear(data);
|
||||||
ActionLog.record(user.ip, user.name, "acp-actionlog-clear", data);
|
ActionLog.record(user.ip, user.name, "acp-actionlog-clear", data);
|
||||||
|
|
32
actionlog.js
32
actionlog.js
|
@ -105,12 +105,42 @@ exports.tooManyRegistrations = function (ip) {
|
||||||
return rows.length > 4;
|
return rows.length > 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.readLog = function () {
|
exports.getLogTypes = function () {
|
||||||
|
var db = Database.getConnection();
|
||||||
|
if(!db)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
var query = "SELECT DISTINCT action FROM actionlog";
|
||||||
|
var result = db.querySync(query);
|
||||||
|
if(!result) {
|
||||||
|
Logger.errlog.log("! Failed to read action log");
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
result = result.fetchAllSync();
|
||||||
|
var actions = [];
|
||||||
|
for(var i in result)
|
||||||
|
actions.push(result[i].action);
|
||||||
|
|
||||||
|
return actions;
|
||||||
|
}
|
||||||
|
|
||||||
|
exports.readLog = function (actions) {
|
||||||
var db = Database.getConnection();
|
var db = Database.getConnection();
|
||||||
if(!db)
|
if(!db)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
var query = "SELECT * FROM actionlog";
|
var query = "SELECT * FROM actionlog";
|
||||||
|
if(actions !== undefined) {
|
||||||
|
var list = new Array(actions.length);
|
||||||
|
for(var i in actions)
|
||||||
|
list[i] = "?";
|
||||||
|
list = list.join(",");
|
||||||
|
query += Database.createQuery(
|
||||||
|
" WHERE action IN ("+list+")",
|
||||||
|
actions
|
||||||
|
);
|
||||||
|
}
|
||||||
var result = db.querySync(query);
|
var result = db.querySync(query);
|
||||||
if(!result) {
|
if(!result) {
|
||||||
Logger.errlog.log("! Failed to read action log");
|
Logger.errlog.log("! Failed to read action log");
|
||||||
|
|
5
api.js
5
api.js
|
@ -189,6 +189,7 @@ module.exports = function (Server) {
|
||||||
|
|
||||||
var row = Auth.login(name, pw, session);
|
var row = Auth.login(name, pw, session);
|
||||||
if(row) {
|
if(row) {
|
||||||
|
if(row.global_rank >= 255)
|
||||||
ActionLog.record(getIP(req), name, "login-success");
|
ActionLog.record(getIP(req), name, "login-success");
|
||||||
this.sendJSON(res, {
|
this.sendJSON(res, {
|
||||||
success: true,
|
success: true,
|
||||||
|
@ -510,13 +511,15 @@ module.exports = function (Server) {
|
||||||
var name = params.name || "";
|
var name = params.name || "";
|
||||||
var pw = params.pw || "";
|
var pw = params.pw || "";
|
||||||
var session = params.session || "";
|
var session = params.session || "";
|
||||||
|
var types = params.actions || "";
|
||||||
var row = Auth.login(name, pw, session);
|
var row = Auth.login(name, pw, session);
|
||||||
if(!row || row.global_rank < 255) {
|
if(!row || row.global_rank < 255) {
|
||||||
res.send(403);
|
res.send(403);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var actions = ActionLog.readLog();
|
var actiontypes = types.split(",");
|
||||||
|
var actions = ActionLog.readLog(actiontypes);
|
||||||
this.sendJSON(res, actions);
|
this.sendJSON(res, actions);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
1
user.js
1
user.js
|
@ -626,6 +626,7 @@ User.prototype.login = function(name, pw, session) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if(this.global_rank >= 255)
|
||||||
ActionLog.record(this.ip, name, "login-success");
|
ActionLog.record(this.ip, name, "login-success");
|
||||||
this.loggedIn = true;
|
this.loggedIn = true;
|
||||||
this.socket.emit("login", {
|
this.socket.emit("login", {
|
||||||
|
|
|
@ -154,7 +154,12 @@ html, body {
|
||||||
border-left: 0;
|
border-left: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#messagebuffer div, #messagebuffer code, #filteredit code {
|
#channeldata td {
|
||||||
|
max-width: 200px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#messagebuffer div, #messagebuffer code, #filteredit code,
|
||||||
|
#channeldata td {
|
||||||
white-space: pre-wrap; /* css-3 */
|
white-space: pre-wrap; /* css-3 */
|
||||||
white-space: -moz-pre-wrap; /* Mozilla, since 1999 */
|
white-space: -moz-pre-wrap; /* Mozilla, since 1999 */
|
||||||
white-space: -pre-wrap; /* Opera 4-6 */
|
white-space: -pre-wrap; /* Opera 4-6 */
|
||||||
|
|
|
@ -88,40 +88,10 @@ $("#listloaded_refresh").click(function() {
|
||||||
socket.emit("acp-list-loaded");
|
socket.emit("acp-list-loaded");
|
||||||
});
|
});
|
||||||
menuHandler("#show_actionlog", "#actionlog");
|
menuHandler("#show_actionlog", "#actionlog");
|
||||||
$("#show_actionlog").click(getActionLog);
|
$("#show_actionlog").click(function () {
|
||||||
$("#actionlog_filter").click(function() {
|
socket.emit("acp-actionlog-list");
|
||||||
var tbl = $("#actionlog table");
|
|
||||||
var actions = $(this).val();
|
|
||||||
$("#actionlog tbody").remove();
|
|
||||||
var entries = [];
|
|
||||||
tbl.data("allentries").forEach(function(e) {
|
|
||||||
if(actions.indexOf(e.action) == -1)
|
|
||||||
return;
|
|
||||||
entries.push(e);
|
|
||||||
});
|
|
||||||
$("#actionlog_pagination").remove();
|
|
||||||
if(entries.length > 20) {
|
|
||||||
var pag = $("<div/>").addClass("pagination")
|
|
||||||
.attr("id", "actionlog_pagination")
|
|
||||||
.insertAfter($("#actionlog table"));
|
|
||||||
var btns = $("<ul/>").appendTo(pag);
|
|
||||||
for(var i = 0; i < entries.length / 20; i++) {
|
|
||||||
var li = $("<li/>").appendTo(btns);
|
|
||||||
(function(i) {
|
|
||||||
$("<a/>").attr("href", "javascript:void(0)")
|
|
||||||
.text(i+1)
|
|
||||||
.click(function() {
|
|
||||||
loadPage(tbl, i);
|
|
||||||
})
|
|
||||||
.appendTo(li);
|
|
||||||
})(i);
|
|
||||||
}
|
|
||||||
tbl.data("pagination", pag);
|
|
||||||
}
|
|
||||||
|
|
||||||
$("#actionlog table").data("entries", entries);
|
|
||||||
loadPage($("#actionlog table"), 0);
|
|
||||||
});
|
});
|
||||||
|
$("#actionlog_filter").click(getActionLog);
|
||||||
$("#actionlog_searchbtn").click(function() {
|
$("#actionlog_searchbtn").click(function() {
|
||||||
var tbl = $("#actionlog table");
|
var tbl = $("#actionlog table");
|
||||||
$("#actionlog tbody").remove();
|
$("#actionlog tbody").remove();
|
||||||
|
@ -169,9 +139,11 @@ $("#actionlog_searchbtn").click(function() {
|
||||||
});
|
});
|
||||||
$("#actionlog_clear").click(function() {
|
$("#actionlog_clear").click(function() {
|
||||||
socket.emit("acp-actionlog-clear", $("#actionlog_filter").val());
|
socket.emit("acp-actionlog-clear", $("#actionlog_filter").val());
|
||||||
|
socket.emit("acp-actionlog-list");
|
||||||
getActionLog();
|
getActionLog();
|
||||||
});
|
});
|
||||||
$("#actionlog_refresh").click(function() {
|
$("#actionlog_refresh").click(function() {
|
||||||
|
socket.emit("acp-actionlog-list");
|
||||||
getActionLog();
|
getActionLog();
|
||||||
});
|
});
|
||||||
$("#actionlog_ip").click(function() {
|
$("#actionlog_ip").click(function() {
|
||||||
|
@ -211,12 +183,31 @@ function getErrlog() {
|
||||||
}
|
}
|
||||||
$("#errlog").click(getErrlog);
|
$("#errlog").click(getErrlog);
|
||||||
function getActionLog() {
|
function getActionLog() {
|
||||||
$.getJSON(WEB_URL+"/api/json/readactionlog?"+AUTH+"&callback=?").done(function(data) {
|
var types = "&actions=" + $("#actionlog_filter").val().join(",");
|
||||||
var entries = data;
|
$.getJSON(WEB_URL+"/api/json/readactionlog?"+AUTH+types+"&callback=?").done(function(entries) {
|
||||||
var actions = [];
|
var tbl = $("#actionlog table");
|
||||||
|
$("#actionlog tbody").remove();
|
||||||
|
$("#actionlog_pagination").remove();
|
||||||
|
if(entries.length > 20) {
|
||||||
|
var pag = $("<div/>").addClass("pagination")
|
||||||
|
.attr("id", "actionlog_pagination")
|
||||||
|
.insertAfter($("#actionlog table"));
|
||||||
|
var btns = $("<ul/>").appendTo(pag);
|
||||||
|
for(var i = 0; i < entries.length / 20; i++) {
|
||||||
|
var li = $("<li/>").appendTo(btns);
|
||||||
|
(function(i) {
|
||||||
|
$("<a/>").attr("href", "javascript:void(0)")
|
||||||
|
.text(i+1)
|
||||||
|
.click(function() {
|
||||||
|
loadPage(tbl, i);
|
||||||
|
})
|
||||||
|
.appendTo(li);
|
||||||
|
})(i);
|
||||||
|
}
|
||||||
|
tbl.data("pagination", pag);
|
||||||
|
}
|
||||||
|
|
||||||
entries.forEach(function (e) {
|
entries.forEach(function (e) {
|
||||||
if(actions.indexOf(e.action) == -1)
|
|
||||||
actions.push(e.action);
|
|
||||||
e.time = parseInt(e.time);
|
e.time = parseInt(e.time);
|
||||||
});
|
});
|
||||||
var tbl = $("#actionlog table");
|
var tbl = $("#actionlog table");
|
||||||
|
@ -243,15 +234,7 @@ function getActionLog() {
|
||||||
$("<td/>").text(e.args).appendTo(tr);
|
$("<td/>").text(e.args).appendTo(tr);
|
||||||
$("<td/>").text(new Date(e.time).toString()).appendTo(tr);
|
$("<td/>").text(new Date(e.time).toString()).appendTo(tr);
|
||||||
});
|
});
|
||||||
$("#actionlog table").data("entries", entries);
|
loadPage($("#actionlog table"), 0);
|
||||||
$("#actionlog_filter").html("");
|
|
||||||
actions.sort(function(a, b) {
|
|
||||||
return a == b ? 0 : (a < b ? -1 : 1);
|
|
||||||
});
|
|
||||||
actions.forEach(function(a) {
|
|
||||||
$("<option/>").text(a).val(a).appendTo($("#actionlog_filter"));
|
|
||||||
});
|
|
||||||
tbl.find("tbody").remove();
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
function getChanlog() {
|
function getChanlog() {
|
||||||
|
@ -572,6 +555,16 @@ function setupCallbacks() {
|
||||||
new Chart($("#stat_channels")[0].getContext("2d")).Line(chan_data);
|
new Chart($("#stat_channels")[0].getContext("2d")).Line(chan_data);
|
||||||
new Chart($("#stat_mem")[0].getContext("2d")).Line(mem_data);
|
new Chart($("#stat_mem")[0].getContext("2d")).Line(mem_data);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
socket.on("acp-actionlog-list", function (alist) {
|
||||||
|
$("#actionlog_filter").html("");
|
||||||
|
alist.sort(function(a, b) {
|
||||||
|
return a == b ? 0 : (a < b ? -1 : 1);
|
||||||
|
});
|
||||||
|
alist.forEach(function(a) {
|
||||||
|
$("<option/>").text(a).val(a).appendTo($("#actionlog_filter"));
|
||||||
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/* cookie util */
|
/* cookie util */
|
||||||
|
|
Loading…
Reference in New Issue