mirror of
https://github.com/reality/dbot.git
synced 2025-01-23 18:44:14 +01:00
Quotes moved to a seperate file. Made a depressionbot module.
This commit is contained in:
parent
9d794d0656
commit
cbc526f21b
47
quotes.js
Normal file
47
quotes.js
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
var quotes = function(quotes) {
|
||||||
|
var qArrs = quotes;
|
||||||
|
|
||||||
|
return {
|
||||||
|
get: function(key) {
|
||||||
|
if(quotes.hasOwnProperty(key)) {
|
||||||
|
return key + ': ' + qArrs[key].random();
|
||||||
|
} else {
|
||||||
|
return 'No quotes under ' + key;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
count: function(key) {
|
||||||
|
if(quotes.hasOwnProperty(key)) {
|
||||||
|
return key + ' has ' + quotes[key].length + ' quotes.';
|
||||||
|
} else {
|
||||||
|
return 'No quotes under ' + key;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
add: function(key) {
|
||||||
|
if(!Object.isArray(quotes[key[1]])) {
|
||||||
|
quotes[key[1]] = [];
|
||||||
|
}
|
||||||
|
quotes[key[1]].push(key[2]);
|
||||||
|
return 'Quote saved in \'' + key[1] + '\' (' + quotes[key[1]].length + ')';
|
||||||
|
},
|
||||||
|
|
||||||
|
set: function(key) {
|
||||||
|
if(!quotes.hasOwnProperty(key[1]) || (quotes.hasOwnProperty(key[1]) && quotes[key[1]].length == 1)) {
|
||||||
|
quotes[key[1]] = [key[2]];
|
||||||
|
return 'Quote saved as ' + key[1];
|
||||||
|
} else {
|
||||||
|
return 'No replacing arrays, you whore.';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
random: function() {
|
||||||
|
var rQuote = Object.keys(quotes).random();
|
||||||
|
return rQuote + ': ' + quotes[rQuote].random();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
exports.fetch = function() {
|
||||||
|
return quotes;
|
||||||
|
};
|
78
run.js
78
run.js
@ -1,5 +1,6 @@
|
|||||||
var fs = require('fs');
|
var fs = require('fs');
|
||||||
var jsbot = require('./jsbot');
|
var jsbot = require('./jsbot');
|
||||||
|
var quote = require('./quotes');
|
||||||
|
|
||||||
///////////////////////////
|
///////////////////////////
|
||||||
|
|
||||||
@ -9,6 +10,17 @@ Array.prototype.random = function() {
|
|||||||
|
|
||||||
///////////////////////////
|
///////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
///////////////////////////
|
||||||
|
|
||||||
|
var dbot = function(quotes) {
|
||||||
|
var admin = 'reality';
|
||||||
|
var waitingForKarma = false;
|
||||||
|
var name = 'depressionbot';
|
||||||
|
var db = JSON.parse(fs.readFileSync('db.json', 'utf-8'));
|
||||||
|
var quotes = quotes(db.quoteArrs);
|
||||||
|
|
||||||
var adminCommands = {
|
var adminCommands = {
|
||||||
'join': function(data, params) {
|
'join': function(data, params) {
|
||||||
instance.join(params[1]);
|
instance.join(params[1]);
|
||||||
@ -96,61 +108,12 @@ var userCommands = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
///////////////////////////
|
|
||||||
|
|
||||||
var admin = 'reality';
|
|
||||||
var waitingForKarma = false;
|
|
||||||
var name = 'depressionbot';
|
|
||||||
var db = JSON.parse(fs.readFileSync('db.json', 'utf-8'));
|
|
||||||
|
|
||||||
var instance = jsbot.createJSBot(name, 'elara.ivixor.net', 6667, function() {
|
var instance = jsbot.createJSBot(name, 'elara.ivixor.net', 6667, function() {
|
||||||
instance.join('#realitest');
|
instance.join('#realitest');
|
||||||
|
instance.join('#42');
|
||||||
|
instance.join('#itonlygetsworse');
|
||||||
}.bind(this));
|
}.bind(this));
|
||||||
|
|
||||||
var quotes = function(quotes) {
|
|
||||||
var qArrs = quotes;
|
|
||||||
|
|
||||||
return {
|
|
||||||
get: function(key) {
|
|
||||||
if(quotes.hasOwnProperty(key)) {
|
|
||||||
return key + ': ' + qArrs[key].random();
|
|
||||||
} else {
|
|
||||||
return 'No quotes under ' + key;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
count: function(key) {
|
|
||||||
if(quotes.hasOwnProperty(key)) {
|
|
||||||
return key + ' has ' + quotes[key].length + ' quotes.';
|
|
||||||
} else {
|
|
||||||
return 'No quotes under ' + key;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
add: function(key) {
|
|
||||||
if(!Object.isArray(quotes[key[1]])) {
|
|
||||||
quotes[key[1]] = [];
|
|
||||||
}
|
|
||||||
quotes[key[1]].push(key[2]);
|
|
||||||
return 'Quote saved in \'' + key[1] + '\' (' + db.quoteArrs[key[1]].length + ')';
|
|
||||||
},
|
|
||||||
|
|
||||||
set: function(key) {
|
|
||||||
if(!quotes.hasOwnProperty(key[1]) || (quotes.hasOwnProperty(key[1]) && quotes[key[1]].length == 1)) {
|
|
||||||
quotes[key[1]] = [key[2]];
|
|
||||||
return 'Quote saved as ' + key[1];
|
|
||||||
} else {
|
|
||||||
return 'No replacing arrays, you whore.';
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
random: function() {
|
|
||||||
var rQuote = Object.keys(quotes).random();
|
|
||||||
return rQuote + ': ' + quotes[rQuote].random();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}(db.quoteArrs);
|
|
||||||
|
|
||||||
instance.addListener('JOIN', function(data) {
|
instance.addListener('JOIN', function(data) {
|
||||||
if(data.user == 'Lamp') {
|
if(data.user == 'Lamp') {
|
||||||
instance.say(data.channel, db.quoteArrs.lamp.random());
|
instance.say(data.channel, db.quoteArrs.lamp.random());
|
||||||
@ -206,15 +169,11 @@ instance.addListener('PRIVMSG', function(data) {
|
|||||||
if(userCommands[params[0]] != undefined) {
|
if(userCommands[params[0]] != undefined) {
|
||||||
userCommands[params[0]](data, params);
|
userCommands[params[0]](data, params);
|
||||||
} else {
|
} else {
|
||||||
var q = data.message.match(/~([\d\w\s]*)/)
|
var q = data.message.match(/^~([\d\w\s]*)/)
|
||||||
if(q != undefined) {
|
if(q != undefined) {
|
||||||
q = q[1].trim();
|
instance.say(data.channel, quotes.get(q[1].trim()));
|
||||||
if(db.quoteArrs[q] != undefined) {
|
|
||||||
instance.say(data.channel, q + ': ' + db.quoteArrs[q].random());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -228,3 +187,8 @@ instance.addListener('PRIVMSG', function(data) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}(quote.fetch());
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user