2014-10-27 21:38:56 -06:00
|
|
|
// Functionality dealing with server-level things
|
|
|
|
|
|
|
|
var maxScrollback = 500;
|
|
|
|
var networks = {};
|
|
|
|
|
|
|
|
function networkConnect(network, baseURL, authtok) {
|
|
|
|
var eventSource;
|
|
|
|
var element = getTemplate("server-channels");
|
2014-10-27 22:57:07 -06:00
|
|
|
var channels = element.getElementsByClassName("channels")[0];
|
2014-10-27 21:38:56 -06:00
|
|
|
var roomElement = element.getElementsByClassName("server")[0];
|
2014-10-27 22:57:07 -06:00
|
|
|
var rooms = {".": roomElement};
|
2014-10-27 21:38:56 -06:00
|
|
|
newRoom(roomElement, element, network, maxScrollback);
|
|
|
|
|
2014-10-27 22:57:07 -06:00
|
|
|
function makeRoom(name) {
|
2014-10-27 21:38:56 -06:00
|
|
|
var rElement = getTemplate("channel");
|
|
|
|
newRoom(rElement, element, name, maxScrollback);
|
|
|
|
channels.appendChild(rElement);
|
|
|
|
rooms[name] = rElement;
|
2014-10-27 22:57:07 -06:00
|
|
|
return rElement;
|
2014-10-27 21:38:56 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
function handleEventSourceLine(line) {
|
2014-10-29 17:47:04 -06:00
|
|
|
var lhs = line.split(" :", 1)[0];
|
|
|
|
var parts = lhs.split(' ');
|
|
|
|
|
|
|
|
var timestamp = new Date(parts[0] * 1000);
|
2014-10-27 21:38:56 -06:00
|
|
|
var fullSender = parts[1];
|
2014-10-29 17:47:04 -06:00
|
|
|
var command = parts[2].toLowerCase();
|
|
|
|
var sender = parts[3];
|
|
|
|
var forum = parts[4];
|
|
|
|
var args = parts.slice(5);
|
|
|
|
var txt = line.substr(lhs.length + 2);
|
2014-10-27 21:38:56 -06:00
|
|
|
|
2014-10-29 20:59:35 -06:00
|
|
|
switch (command) {
|
|
|
|
case "prevlog":
|
|
|
|
// Just ignore this
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-10-27 21:38:56 -06:00
|
|
|
var room = rooms[forum];
|
|
|
|
if (! room) {
|
2014-10-27 22:57:07 -06:00
|
|
|
room = makeRoom(forum);
|
2014-10-27 21:38:56 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
// XXX: Handle differently based on command
|
2014-10-29 17:47:04 -06:00
|
|
|
room.addMessage(timestamp, fullSender, command, sender, args, txt);
|
2014-10-27 21:38:56 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
function handleEventSourceMessage(oEvent) {
|
|
|
|
msgs = oEvent.data.split("\n");
|
|
|
|
|
|
|
|
var first = Math.max(0, msgs.length - maxScrollback);
|
|
|
|
for (var i = first; i < msgs.length; i += 1) {
|
|
|
|
handleEventSourceLine(msgs[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleEventSourceError(oEvent) {
|
|
|
|
timestamp = new Date();
|
2014-10-29 17:47:04 -06:00
|
|
|
roomElement.addMessage(timestamp, ".", "fault", ".", [], "Unable to open events feed (permissions problem on server?)");
|
|
|
|
console.log(oEvent);
|
2014-10-27 21:38:56 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
element.send = function(target, text) {
|
|
|
|
function handleError(oEvent) {
|
|
|
|
console.log("XXX: That didn't work out.", target, text)
|
|
|
|
}
|
|
|
|
|
|
|
|
var form = new FormData();
|
|
|
|
form.append("type", "command");
|
|
|
|
form.append("auth", authtok);
|
|
|
|
form.append("network", network);
|
|
|
|
form.append("target", target);
|
|
|
|
form.append("text", text);
|
|
|
|
|
|
|
|
var oReq = new XMLHttpRequest();
|
|
|
|
oReq.addEventListener("error", handleError);
|
|
|
|
oReq.open("POST", baseURL, true);
|
|
|
|
oReq.send(form);
|
|
|
|
}
|
|
|
|
|
|
|
|
element.close = function() {
|
|
|
|
eventSource.close();
|
|
|
|
element.parentNode.removeChild(element);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (networks[network]) {
|
|
|
|
networks[network].close();
|
|
|
|
}
|
|
|
|
networks[network] = element;
|
|
|
|
|
|
|
|
var pullURL = baseURL + "?network=" + encodeURIComponent(network) + "&auth=" + encodeURIComponent(authtok);
|
|
|
|
eventSource = new EventSource(pullURL);
|
|
|
|
eventSource.addEventListener("message", handleEventSourceMessage);
|
|
|
|
eventSource.addEventListener("error", handleEventSourceError);
|
2014-10-27 22:57:07 -06:00
|
|
|
|
|
|
|
document.getElementsByClassName("rooms")[0].appendChild(element);
|
2014-10-27 21:38:56 -06:00
|
|
|
}
|