AWESOM-0
Hey there have you heard about my robot friend? He's metal and small and doesn't judge me at all.
Meet AWESOM-0, your friendly neighborhood IRC bot! Similar to Hubot, the commands AWESOM-0 responds to and phrases the bot can listen for are defined inside a scripts
folder.
Examples
L1fescape: AWESOM-0 hi
AWESOM-0: Hi L1fescape!
L1fescape: AWESOM-0 image me cats
AWESOM-0: http://www.rachelkasa.com/wp-content/uploads/2011/10/kitten.jpg
L1fescape: AWESOM-0 note Bjorn totally lame.
AWESOM-0: okie dokes!
... some time passes ...
Bjorn: AWESOM-0 notes
AWESOM-0: L1fescape @ about an hour ago: totally lame.
Install
npm install
Create a file called settings.js
(you can copy
from the existing settings.js.sample
).
Commands can be enabled and disabled by adding or removing them from the commands
array inside of setttings.js
.
Running
From the command line:
node awesom0.js
With forever (note you'll need to install forever globally):
forever start awesom0.js
Using AWESOM-0 inside another Nodejs file:
var a = require("./awesom0")
a.init({ commands: ["hi"], botname: "AWESOM0" });
Writing Scripts
On init, the array of commands we've chosen to enable in settings.js
is looped through by AWSOM-0 and each script is imported. The AWESOM-0 instance is also passed in to each script. This is so that each script can register what regular expression AWESOM-0 should listen to.
The way registration is done is via the respond
function, which takes three params: a regular expression, (optional) how to use the command, and a callback function to run when there is a match in an IRC message.
AWESOM-0 passes an object into the callback of a matched script with the following properties:
match
: array of the results of running match
on the irc message (this is especially useful when a script needs to read in parameters).from
: the user sending the message.message
: the original message with the bot's name removed.channel
: the channel the message was sent to.
For a good example of all of this, check out the hi script.
Debugging
AWESOM-0 has a bundled debug script for testing commands and scripts locally without connecting to an IRC server. To use it, set debug = true
inside settings.js
and then run node debug.js
(setting debug mode to true will also define a function called testMsg(msg)
which is an alias for onmessage("TestUser", "#test", msg)
, making testing commands a little easier as you don't need to define the user and channel a message was sent from/to every time).
You should now see a repl which will allow you to interact with the bot and test commands. Here is an example of running the debug script, displaying help, unsuccessfully running the "it's a trap" script, successfully running it, then using onmessage
directly instead of the testMsg
alias:
$ node debug.js
> a.testMsg("AWESOM-0 help")
> a.testMsg("its a trap")
> a.testMsg("AWESOM-0 its a trap")
> a.onmessage("AwesomeUser", "#AwesomeChannel", "AWESOM-0 its a trap")
Testing
./node_modules/mocha/bin/mocha
TODO
- Write more tests
- Document using redis
Issues or Questions
If there's a feature you'd like supported or a bug in the code, create an issue on GitHub. If you have any questions, join us on IRC. We're at #AWESOM-0
on Freenode.
Acknowledgements
- Hubot - A TON of inspiration. AWESOM-0 initially did things much differently. Just looking at the format of Hubot Scripts got me thinking of how to get something like that to work.
- Node IRC - Super simple, awesome npm package that made writing this bot a breeze. Thanks @martynsmith!
License
MIT License • © Andrew Kennedy