better command handlig
This commit is contained in:
parent
400a079e2b
commit
98b4e68285
@ -486,6 +486,10 @@ body {
|
|||||||
color: #f00;
|
color: #f00;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
|
.message.m_help .content {
|
||||||
|
color: #008000;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
.message .irc-bg00,
|
.message .irc-bg00,
|
||||||
.topicbar .irc-bg00,
|
.topicbar .irc-bg00,
|
||||||
.message .irc-bg0,
|
.message .irc-bg0,
|
||||||
|
@ -63,6 +63,10 @@ window.validators.nickname = function(str) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
window.validators.escapeHTML = function(str) {
|
||||||
|
return str.replace(/\</g, '<').replace(/\>/, '>');
|
||||||
|
}
|
||||||
|
|
||||||
Date.prototype.format = function (format, utc){
|
Date.prototype.format = function (format, utc){
|
||||||
var date = this;
|
var date = this;
|
||||||
var MMMM = ["\x00", "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
|
var MMMM = ["\x00", "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
|
||||||
@ -147,7 +151,7 @@ irc.whoisMessage = function(whoisData, buffer) {
|
|||||||
for(let key in whoisData) {
|
for(let key in whoisData) {
|
||||||
switch(key) {
|
switch(key) {
|
||||||
case "hostmask":
|
case "hostmask":
|
||||||
messages.push("<span class='hostmask'>"+whoisData[key]+"</span>: "+whoisData['realname']);
|
messages.push("<span class='hostmask'>"+whoisData[key]+"</span>: "+validators.escapeHTML(whoisData['realname']));
|
||||||
break;
|
break;
|
||||||
case "idleSeconds":
|
case "idleSeconds":
|
||||||
let msgs = "is idle for "+whoisData[key]+" seconds";
|
let msgs = "is idle for "+whoisData[key]+" seconds";
|
||||||
@ -160,7 +164,7 @@ irc.whoisMessage = function(whoisData, buffer) {
|
|||||||
case "connectingFrom":
|
case "connectingFrom":
|
||||||
case "usingModes":
|
case "usingModes":
|
||||||
case "title":
|
case "title":
|
||||||
messages.push(whoisData[key]);
|
messages.push(validators.escapeHTML(whoisData[key]));
|
||||||
break;
|
break;
|
||||||
case "channels":
|
case "channels":
|
||||||
messages.push(whoisData[key].join(" "));
|
messages.push(whoisData[key].join(" "));
|
||||||
@ -168,7 +172,7 @@ irc.whoisMessage = function(whoisData, buffer) {
|
|||||||
case "server":
|
case "server":
|
||||||
let adfd = "is on <span class='server nick'>"+whoisData[key]+"</span>";
|
let adfd = "is on <span class='server nick'>"+whoisData[key]+"</span>";
|
||||||
if(whoisData['server_name'])
|
if(whoisData['server_name'])
|
||||||
adfd += " <span class='hostmask'>"+whoisData['server_name']+"</span>";
|
adfd += " <span class='hostmask'>"+validators.escapeHTML(whoisData['server_name'])+"</span>";
|
||||||
messages.push(adfd);
|
messages.push(adfd);
|
||||||
break;
|
break;
|
||||||
case "secure":
|
case "secure":
|
||||||
@ -240,7 +244,7 @@ function linkify(text) {
|
|||||||
if (url.indexOf('http') !== 0) {
|
if (url.indexOf('http') !== 0) {
|
||||||
href = 'http://' + url;
|
href = 'http://' + url;
|
||||||
}
|
}
|
||||||
return '<a href="' + href + '" target="_blank">' + url + '</a>';
|
return '<a href="' + href + '" target="_blank" rel="nofollow">' + url + '</a>';
|
||||||
});
|
});
|
||||||
return parsed;
|
return parsed;
|
||||||
}
|
}
|
||||||
@ -337,6 +341,125 @@ let composer = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*****************************\
|
||||||
|
|** **|
|
||||||
|
|** CLIENT COMMANDS **|
|
||||||
|
|** **|
|
||||||
|
\*****************************/
|
||||||
|
|
||||||
|
// commandName: {execute: function(buffer, handler, command, message, listargs) {}, description: ""}
|
||||||
|
let commands = {
|
||||||
|
join: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
if (!listargs[1]) {
|
||||||
|
if(!buffer.alive) {
|
||||||
|
irc.socket.emit("userinput", {command: "join", server: buffer.server, message: "", arguments: [buffer.name]});
|
||||||
|
} else {
|
||||||
|
handler.commandError(buffer, listargs[0].toUpperCase()+': Missing parameters!');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
irc.socket.emit("userinput", {command: "join", server: buffer.server, message: "", arguments: [listargs[1]]});
|
||||||
|
}
|
||||||
|
}, description: "<channel> - Join a channel"},
|
||||||
|
|
||||||
|
part: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
if (!listargs[1] && buffer.type == "channel") {
|
||||||
|
irc.socket.emit("userinput", {command: "part", server: buffer.server, message: "", arguments: [buffer.name]});
|
||||||
|
} else if(buffer.type != "channel") {
|
||||||
|
handler.commandError(buffer, listargs[0].toUpperCase()+': Buffer is not a channel.');
|
||||||
|
} else if(listargs[1]) {
|
||||||
|
if(listargs[1].indexOf('#')) {
|
||||||
|
let msg = "";
|
||||||
|
if(listargs[2])
|
||||||
|
msg = listargs.slice(2).join(" ");
|
||||||
|
irc.socket.emit("userinput", {command: "part", server: buffer.server, message: msg, arguments: [listargs[1]]});
|
||||||
|
} else {
|
||||||
|
if(buffer.type == "channel") {
|
||||||
|
irc.socket.emit("userinput", {command: "part", server: buffer.server, message: listargs.slice(1).join(" "), arguments: [buffer.name]});
|
||||||
|
} else {
|
||||||
|
handler.commandError(buffer, listargs[0].toUpperCase()+': Buffer is not a channel.');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, description: "[<#channel>|<message>] [message] - Leave the channel. If no channel specified, leave the current buffer.", aliases: ['leave']},
|
||||||
|
|
||||||
|
quit: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
irc.socket.emit("userinput", {command: "quit", server: buffer.server, message: listargs.slice(1).join(" "), arguments: []});
|
||||||
|
}, description: "[<message>] - Quit the current server with message.", aliases: ['exit']},
|
||||||
|
|
||||||
|
privmsg: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
if(!listargs[1] || !listargs[2])
|
||||||
|
return handler.commandError(buffer, listargs[0].toUpperCase()+': Missing parameters!');
|
||||||
|
if(listargs[1] == '*')
|
||||||
|
listargs[1] = buffer.name;
|
||||||
|
irc.socket.emit("userinput", {command: "privmsg", server: buffer.server, message: listargs.slice(2).join(" "), arguments: [listargs[1]]});
|
||||||
|
}, description: "<target> <message> - Sends a message to target.", aliases: ['msg', 'q', 'query', 'say']},
|
||||||
|
|
||||||
|
notice: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
if(!listargs[1] || !listargs[2])
|
||||||
|
return handler.commandError(buffer, listargs[0].toUpperCase()+': Missing parameters!');
|
||||||
|
if(listargs[1] == '*')
|
||||||
|
listargs[1] = buffer.name;
|
||||||
|
irc.socket.emit("userinput", {command: "notice", server: buffer.server, message: listargs.slice(2).join(" "), arguments: [listargs[1]]});
|
||||||
|
}, description: "<target> <message> - Sends a NOTICE to target."},
|
||||||
|
|
||||||
|
action: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
irc.socket.emit("userinput", {command: "privmsg", server: buffer.server, message: "\x01ACTION "+message.substring(command.length+2)+"\x01", arguments: [buffer.name]});
|
||||||
|
}, description: "<message> - 'act' as yourself"},
|
||||||
|
|
||||||
|
list: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
irc.socket.emit("userinput", {command: "list", server: buffer.server, message: "", arguments: listargs.splice(1)});
|
||||||
|
}, description: "- List all channels on the current server."},
|
||||||
|
|
||||||
|
quote: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
irc.socket.emit("userinput", {command: listargs[1], server: buffer.server, message: listargs.slice(2).join(" "), arguments: listargs.splice(2)});
|
||||||
|
}, description: "<command> [args] - Send a raw command to the server.", aliases: ['raw']},
|
||||||
|
|
||||||
|
whois: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
if(!listargs[1])
|
||||||
|
return handler.commandError(buffer, listargs[0].toUpperCase()+': Missing parameters!');
|
||||||
|
|
||||||
|
irc.socket.emit("userinput", {command: "whois", server: buffer.server, message: "", arguments: [listargs[1]]});
|
||||||
|
}, description: "<nickname> - Display information about a user."},
|
||||||
|
|
||||||
|
connect: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
clientdom.connector.frame.style.display = "block";
|
||||||
|
irc.auther.authMessage("Create a new connection", false);
|
||||||
|
irc.auther.canClose = true;
|
||||||
|
}, description: "- Create a new connection."},
|
||||||
|
|
||||||
|
help: {execute: function(buffer, handler, command, message, listargs) {
|
||||||
|
if(!listargs[1])
|
||||||
|
return handler.commandError(buffer, listargs[0].toUpperCase()+': Missing parameters!');
|
||||||
|
|
||||||
|
let cmd = listargs[1].toLowerCase();
|
||||||
|
if(cmd.indexOf('/') === 0)
|
||||||
|
cmd = cmd.substring(1);
|
||||||
|
|
||||||
|
if(cmd in commands) {
|
||||||
|
if("description" in commands[cmd])
|
||||||
|
buffer.addMessage("<span class='command'>/"+cmd.toUpperCase()+"</span> "+
|
||||||
|
validators.escapeHTML(commands[cmd].description), null, "help");
|
||||||
|
else
|
||||||
|
buffer.addMessage("<span class='command'>/"+cmd.toUpperCase()+"</span> - No description provided", null, "help");
|
||||||
|
} else {
|
||||||
|
let foundAliased = null;
|
||||||
|
for(let cmd2 in commands) {
|
||||||
|
if(!commands[cmd2]['aliases']) continue;
|
||||||
|
if(commands[cmd2].aliases.indexOf(cmd) != -1) foundAliased = cmd2;
|
||||||
|
}
|
||||||
|
if(foundAliased) {
|
||||||
|
if("description" in commands[foundAliased])
|
||||||
|
buffer.addMessage("<span class='command'>/"+cmd.toUpperCase()+"</span> "+
|
||||||
|
validators.escapeHTML(commands[foundAliased].description), null, "help");
|
||||||
|
else
|
||||||
|
buffer.addMessage("<span class='command'>/"+cmd.toUpperCase()+"</span> - No description provided", null, "help");
|
||||||
|
} else {
|
||||||
|
handler.commandError(buffer, '/'+cmd.toUpperCase()+': Unknown command!');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, description: "<command> - Display help for command"}
|
||||||
|
}
|
||||||
|
|
||||||
/*********************\
|
/*********************\
|
||||||
|** **|
|
|** **|
|
||||||
|** CLASSES **|
|
|** CLASSES **|
|
||||||
@ -1123,98 +1246,37 @@ class InputHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
handleInput() {
|
handleInput() {
|
||||||
let inp = clientdom.input.value;
|
let message = clientdom.input.value;
|
||||||
let buf = irc.chat.getActiveBuffer();
|
let buffer = irc.chat.getActiveBuffer();
|
||||||
|
|
||||||
if(!buf) return;
|
if(!buffer) return;
|
||||||
if(inp.trim() == "") return;
|
if(message.trim() == "") return;
|
||||||
|
|
||||||
let listargs = inp.split(' ');
|
let listargs = message.split(' ');
|
||||||
|
|
||||||
if(listargs[0].indexOf('/') == 0) {
|
if(listargs[0].indexOf('/') == 0) {
|
||||||
let cmd = listargs[0].substring(1).toLowerCase();
|
let command = listargs[0].substring(1).toLowerCase();
|
||||||
switch(cmd) {
|
if(command.toLowerCase() in commands) {
|
||||||
case "join":
|
let cmd = commands[command];
|
||||||
if (!listargs[1]) {
|
if("execute" in cmd)
|
||||||
if(!buf.alive) {
|
cmd.execute(buffer, this, command, message, listargs);
|
||||||
irc.socket.emit("userinput", {command: "join", server: buf.server, message: "", arguments: [buf.name]});
|
|
||||||
} else {
|
} else {
|
||||||
this.commandError(buf, listargs[0].toUpperCase()+': Missing parameters!');
|
let foundAliased = null;
|
||||||
|
for(let cmd in commands) {
|
||||||
|
if(!commands[cmd]['aliases']) continue;
|
||||||
|
if(commands[cmd].aliases.indexOf(command) != -1) foundAliased = commands[cmd];
|
||||||
}
|
}
|
||||||
} else {
|
if(foundAliased)
|
||||||
irc.socket.emit("userinput", {command: "join", server: buf.server, message: "", arguments: [listargs[1]]});
|
foundAliased.execute(buffer, this, command, message, listargs);
|
||||||
}
|
else
|
||||||
break;
|
this.commandError(buffer, listargs[0].toUpperCase()+': Unknown command!');
|
||||||
case "part":
|
|
||||||
if (!listargs[1] && buf.type == "channel") {
|
|
||||||
irc.socket.emit("userinput", {command: "part", server: buf.server, message: "", arguments: [buf.name]});
|
|
||||||
} else if(buf.type != "channel") {
|
|
||||||
this.commandError(buf, listargs[0].toUpperCase()+': Buffer is not a channel.');
|
|
||||||
} else if(listargs[1]) {
|
|
||||||
if(listargs[1].indexOf('#')) {
|
|
||||||
let msg = "";
|
|
||||||
if(listargs[2])
|
|
||||||
msg = listargs.slice(2).join(" ");
|
|
||||||
irc.socket.emit("userinput", {command: "part", server: buf.server, message: msg, arguments: [listargs[1]]});
|
|
||||||
} else {
|
|
||||||
if(buf.type == "channel") {
|
|
||||||
irc.socket.emit("userinput", {command: "part", server: buf.server, message: listargs.slice(1).join(" "), arguments: [buf.name]});
|
|
||||||
} else {
|
|
||||||
this.commandError(buf, listargs[0].toUpperCase()+': Buffer is not a channel.');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case "quit":
|
|
||||||
irc.socket.emit("userinput", {command: "quit", server: buf.server, message: listargs.slice(1).join(" "), arguments: []});
|
|
||||||
break;
|
|
||||||
case "msg":
|
|
||||||
case "privmsg":
|
|
||||||
case "say":
|
|
||||||
if(!listargs[1] || !listargs[2])
|
|
||||||
return this.commandError(buf, listargs[0].toUpperCase()+': Missing parameters!');
|
|
||||||
if(listargs[1] == '*')
|
|
||||||
listargs[1] = buf.name;
|
|
||||||
irc.socket.emit("userinput", {command: "privmsg", server: buf.server, message: listargs.slice(2).join(" "), arguments: [listargs[1]]});
|
|
||||||
break;
|
|
||||||
case "notice":
|
|
||||||
if(!listargs[1] || !listargs[2])
|
|
||||||
return this.commandError(buf, listargs[0].toUpperCase()+': Missing parameters!');
|
|
||||||
if(listargs[1] == '*')
|
|
||||||
listargs[1] = buf.name;
|
|
||||||
irc.socket.emit("userinput", {command: "notice", server: buf.server, message: listargs.slice(2).join(" "), arguments: [listargs[1]]});
|
|
||||||
break;
|
|
||||||
case "me":
|
|
||||||
case "action":
|
|
||||||
irc.socket.emit("userinput", {command: "privmsg", server: buf.server, message: "\x01ACTION "+inp.substring(cmd.length+2)+"\x01", arguments: [buf.name]});
|
|
||||||
break;
|
|
||||||
case "nick":
|
|
||||||
case "list":
|
|
||||||
irc.socket.emit("userinput", {command: cmd, server: buf.server, message: "", arguments: listargs.splice(1)});
|
|
||||||
break;
|
|
||||||
case "quote":
|
|
||||||
case "raw":
|
|
||||||
irc.socket.emit("userinput", {command: listargs[1], server: buf.server, message: listargs.slice(2).join(" "), arguments: listargs.splice(2)});
|
|
||||||
break;
|
|
||||||
case "whois":
|
|
||||||
if(!listargs[1])
|
|
||||||
return this.commandError(buf, listargs[0].toUpperCase()+': Missing parameters!');
|
|
||||||
|
|
||||||
irc.socket.emit("userinput", {command: "whois", server: buf.server, message: "", arguments: [listargs[1]]});
|
|
||||||
break;
|
|
||||||
case "connect":
|
|
||||||
clientdom.connector.frame.style.display = "block";
|
|
||||||
irc.auther.authMessage("Create a new connection", false);
|
|
||||||
irc.auther.canClose = true;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
this.commandError(buf, listargs[0].toUpperCase()+': Unknown command!');
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
irc.socket.emit("userinput", {command: "privmsg", server: buf.server, message: inp, arguments: [buf.name]});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this.history.push(inp);
|
} else {
|
||||||
|
irc.socket.emit("userinput", {command: "privmsg", server: buffer.server, message: message, arguments: [buffer.name]});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.history.push(message);
|
||||||
this.historyCaret = this.history.length;
|
this.historyCaret = this.history.length;
|
||||||
clientdom.input.value = "";
|
clientdom.input.value = "";
|
||||||
}
|
}
|
||||||
@ -1654,6 +1716,11 @@ window.onload = function() {
|
|||||||
|
|
||||||
// Does everything
|
// Does everything
|
||||||
irc.socket.on('act_client', function (data) {
|
irc.socket.on('act_client', function (data) {
|
||||||
|
if(data['message'])
|
||||||
|
data.message = validators.escapeHTML(data.message);
|
||||||
|
if(data['reason'])
|
||||||
|
data.reason = validators.escapeHTML(data.reason);
|
||||||
|
|
||||||
switch(data.type) {
|
switch(data.type) {
|
||||||
case "event_connect":
|
case "event_connect":
|
||||||
irc.auther.authComplete();
|
irc.auther.authComplete();
|
||||||
|
@ -406,6 +406,9 @@ body
|
|||||||
&.m_error .content
|
&.m_error .content
|
||||||
color: red;
|
color: red;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
|
&.m_help .content
|
||||||
|
color: #008000;
|
||||||
|
font-weight: bold;
|
||||||
|
|
||||||
.message, .topicbar
|
.message, .topicbar
|
||||||
.irc-bg00,.irc-bg0
|
.irc-bg00,.irc-bg0
|
||||||
|
Reference in New Issue
Block a user