Refactoring
This commit is contained in:
parent
e587a46242
commit
defffe5e9b
|
@ -1,3 +1,7 @@
|
||||||
module.exports = {
|
module.exports = {
|
||||||
host: "irc.freenode.org"
|
host: "irc.freenode.org",
|
||||||
|
nick: "temp_user",
|
||||||
|
channels: [
|
||||||
|
"#temp_chan"
|
||||||
|
]
|
||||||
};
|
};
|
|
@ -2,6 +2,9 @@ var irc = require("irc");
|
||||||
var Backbone = require("backbone");
|
var Backbone = require("backbone");
|
||||||
var moment = require("moment");
|
var moment = require("moment");
|
||||||
|
|
||||||
|
// Local library
|
||||||
|
var config = require("./../config.js");
|
||||||
|
|
||||||
var models =
|
var models =
|
||||||
module.exports =
|
module.exports =
|
||||||
{};
|
{};
|
||||||
|
@ -11,7 +14,7 @@ var id = 1;
|
||||||
models.User = Backbone.Model.extend({
|
models.User = Backbone.Model.extend({
|
||||||
defaults: {
|
defaults: {
|
||||||
mode: "",
|
mode: "",
|
||||||
name: "user"
|
name: ""
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -73,12 +76,12 @@ models.ChannelCollection = Backbone.Collection.extend({
|
||||||
models.Network = Backbone.Model.extend({
|
models.Network = Backbone.Model.extend({
|
||||||
defaults: {
|
defaults: {
|
||||||
host: "",
|
host: "",
|
||||||
nick: "default_username",
|
nick: config.nick,
|
||||||
connect: true
|
connect: true
|
||||||
},
|
},
|
||||||
initialize: function() {
|
initialize: function() {
|
||||||
this.set({
|
this.set({
|
||||||
id: id++,
|
id: id++
|
||||||
});
|
});
|
||||||
|
|
||||||
this.set("channels", new models.ChannelCollection());
|
this.set("channels", new models.ChannelCollection());
|
||||||
|
@ -98,7 +101,7 @@ models.Network = Backbone.Model.extend({
|
||||||
this.irc = new irc.Client(
|
this.irc = new irc.Client(
|
||||||
this.get("host"),
|
this.get("host"),
|
||||||
this.get("nick"), {
|
this.get("nick"), {
|
||||||
channels: ["#test_channel"]
|
channels: config.channels
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
this.irc.addListener(
|
this.irc.addListener(
|
||||||
|
|
167
lib/server.js
167
lib/server.js
|
@ -13,26 +13,27 @@ function Server() {
|
||||||
}
|
}
|
||||||
|
|
||||||
Server.prototype.listen = function(port) {
|
Server.prototype.listen = function(port) {
|
||||||
var self = this;
|
|
||||||
var http = connect()
|
var http = connect()
|
||||||
.use(connect.static("client"))
|
.use(connect.static("client"))
|
||||||
.listen(port);
|
.listen(port);
|
||||||
|
|
||||||
this.networks.on("all", function(type, data) {
|
this.networks.on("all", function(type, data) {
|
||||||
if (type == "users" || type == "messages") {
|
if (type == "users" || type == "messages") {
|
||||||
self.sockets.emit(type, data);
|
this.sockets.emit(type, data);
|
||||||
} else {
|
} else {
|
||||||
// Network and channel events will force
|
// Network and channel events will force
|
||||||
// a full refresh.
|
// a full refresh.
|
||||||
self.sockets.emit(
|
this.sockets.emit(
|
||||||
"networks", self.networks
|
"networks", self.networks
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
});
|
}, this);
|
||||||
|
|
||||||
this.sockets = io
|
this.sockets = io
|
||||||
.listen(http, {log: false})
|
.listen(http, {log: false})
|
||||||
.sockets;
|
.sockets;
|
||||||
|
|
||||||
|
var self = this;
|
||||||
this.sockets.on("connection", function(socket) {
|
this.sockets.on("connection", function(socket) {
|
||||||
socket.emit(
|
socket.emit(
|
||||||
"networks", self.networks
|
"networks", self.networks
|
||||||
|
@ -54,19 +55,34 @@ function handleInput(input) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var network = target.network;
|
||||||
|
var channel = target.channel;
|
||||||
|
|
||||||
var argv = input.text.substr(1).split(" ");
|
var argv = input.text.substr(1).split(" ");
|
||||||
var cmd = input.text.charAt(0) == "/" ? argv[0].toUpperCase()
|
var cmd = input.text.charAt(0) == "/" ? argv[0].toUpperCase()
|
||||||
: "";
|
: "MESSAGE";
|
||||||
|
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
|
|
||||||
case "SERVER":
|
case "MESSAGE":
|
||||||
case "CONNECT":
|
var irc = network.irc;
|
||||||
var network = this.networks.add(
|
if (typeof irc !== "undefined") {
|
||||||
new models.Network({
|
irc.say(target.channel.get("name"), input.text);
|
||||||
host: argv[1] || config.host
|
}
|
||||||
|
channel.get("messages").add(
|
||||||
|
new models.Message({
|
||||||
|
user: network.get("nick"),
|
||||||
|
text: input.text
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "SERVER":
|
||||||
|
case "CONNECT":
|
||||||
|
var network = new models.Network({
|
||||||
|
host: argv[1] || config.host
|
||||||
|
});
|
||||||
|
this.networks.add(network);
|
||||||
network.irc.addListener("raw", function() {
|
network.irc.addListener("raw", function() {
|
||||||
handleEvent.apply(network, arguments);
|
handleEvent.apply(network, arguments);
|
||||||
}
|
}
|
||||||
|
@ -75,104 +91,85 @@ function handleInput(input) {
|
||||||
|
|
||||||
case "QUIT":
|
case "QUIT":
|
||||||
case "DISCONNECT":
|
case "DISCONNECT":
|
||||||
this.networks.remove(target.network);
|
this.networks.remove(network);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "":
|
case "JOIN":
|
||||||
var irc = target.network.irc;
|
case "PART":
|
||||||
|
var irc = network.irc;
|
||||||
if (typeof irc !== "undefined") {
|
if (typeof irc !== "undefined") {
|
||||||
var chan = target.channel.get("name");
|
irc.send(cmd, argv[1] || target.channel.get("name"));
|
||||||
irc.say(chan, input.text);
|
|
||||||
}
|
}
|
||||||
target.channel.get("messages").add(
|
break;
|
||||||
|
|
||||||
|
case "NOTICE":
|
||||||
|
var irc = network.irc;
|
||||||
|
if (!argv[2] || typeof irc === "undefined") {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
var user = argv[1];
|
||||||
|
var text = argv.slice(2).join(" ");
|
||||||
|
|
||||||
|
irc.notice(user, text);
|
||||||
|
channel.get("messages").add(
|
||||||
new models.Message({
|
new models.Message({
|
||||||
user: target.network.get("nick"),
|
type: "notice",
|
||||||
text: input.text
|
text: "Notice to " + user + ": " + text
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "NOTICE":
|
case "QUERY":
|
||||||
var irc = target.network.irc;
|
var irc = network.irc;
|
||||||
if (argv[2] && typeof irc !== "undefined") {
|
if (!argv[1] || typeof irc === "undefined") {
|
||||||
var user = argv[1];
|
break;
|
||||||
var text = argv
|
}
|
||||||
.slice(2)
|
|
||||||
.join(" ");
|
|
||||||
|
|
||||||
irc.notice(user, text);
|
var channels = network.get("channels");
|
||||||
target.channel.get("messages").add(
|
if (argv[1].charAt(0) != "#" && !channels.findWhere({name: argv[1]})) {
|
||||||
new models.Message({
|
channels.add(
|
||||||
user: target.network.get("nick"),
|
new models.Channel({
|
||||||
text: "to " + user + ": " + text
|
name: argv[1]
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "QUERY":
|
case "TOPIC":
|
||||||
var irc = target.network.irc;
|
var irc = network.irc;
|
||||||
if (argv[1] && typeof irc !== "undefined") {
|
if (typeof irc === "undefined") {
|
||||||
var channels = target.network.get("channels");
|
break;
|
||||||
if (argv[1].charAt(0) != "#" && !channels.findWhere({name: argv[1]})) {
|
|
||||||
channels.add(
|
|
||||||
new models.Channel({
|
|
||||||
name: argv[1]
|
|
||||||
})
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
|
|
||||||
case "JOIN":
|
var params = [
|
||||||
var irc = target.network.irc;
|
"topic",
|
||||||
if (argv[1] && typeof irc !== "undefined") {
|
channel.get("name")
|
||||||
irc.join(argv[1]);
|
];
|
||||||
}
|
if (argv[1]) {
|
||||||
break;
|
var text = argv.slice(1).join(" ");
|
||||||
|
params.push(text);
|
||||||
case "PART":
|
|
||||||
var irc = target.network.irc;
|
|
||||||
if (typeof irc !== "undefined") {
|
|
||||||
irc.part(argv[1] ? argv[1] : target.channel.get("name"));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case "NAMES":
|
|
||||||
var irc = target.network.irc;
|
|
||||||
if (typeof irc !== "undefined") {
|
|
||||||
var channel = argv[1] ? argv[1] : target.channel.get("name");
|
|
||||||
irc.send("NAMES", channel);
|
|
||||||
}
|
}
|
||||||
|
irc.send.apply(
|
||||||
|
irc,
|
||||||
|
params
|
||||||
|
);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "NICK":
|
case "NICK":
|
||||||
var irc = target.network.irc;
|
var irc = network.irc;
|
||||||
if (argv[1] && typeof irc !== "undefined") {
|
|
||||||
irc.send("NICK", argv[1]);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case "TOPIC":
|
|
||||||
var irc = target.network.irc;
|
|
||||||
if (typeof irc !== "undefined") {
|
if (typeof irc !== "undefined") {
|
||||||
if (!argv[1] || argv[1].charAt(0) != "#") {
|
irc.send(cmd, argv[1] || config.nick);
|
||||||
argv.splice(1, 0, target.channel.get("name"));
|
|
||||||
}
|
|
||||||
var topic = argv.slice(2).join(" ");
|
|
||||||
irc.send.apply(
|
|
||||||
irc,
|
|
||||||
argv.length == 2 ? argv
|
|
||||||
: argv.slice(0, 2).concat(topic)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
target.channel.get("messages").add(
|
channel.get("messages").add(
|
||||||
new models.Message({text: "Command `/" + cmd + "` does not exist."})
|
new models.Message({
|
||||||
|
text: "Unknown command: `/" + cmd + "`"
|
||||||
|
})
|
||||||
);
|
);
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -343,14 +340,6 @@ function handleEvent(argv) {
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
//default:
|
|
||||||
// channels.first().get("messages").add(
|
|
||||||
// new models.Message({
|
|
||||||
// user: "-!-",
|
|
||||||
// text: argv.args.slice(1).join(" ")
|
|
||||||
// })
|
|
||||||
// );
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Debug
|
// Debug
|
||||||
|
|
Loading…
Reference in New Issue