NAME
Evalbot
DESCRIPTION
This is a small IRC bot using Net::IRC
to eval()
commands.
ARCHITECTURE
evalbot.p6
is the main bot, written in Perl 6. To run a command, it spawns evalhelper.p5
, a Perl 5 program. This sets up the necessary environment (PUGS_SAFEMODE
, redirection of STDOUT
and STDERR
to a temporary file, resource limits, etc.). Finally, evalhelper.p5
runs pugs
.
INSTALLATION
There's no separate installation step needed, simply run evalbot.p6
and supply a nick and an IRC server to connect to:
$ pugs evalbot.p6 evalbot6 irc.freenode.net:6667
You don't have to restart evalbot.p6
when you install a new Pugs, as a new pugs
is spawned on each command to eval.
evalhelper.p5
needs the BSD::Resource
module to be able to set appropriate resource limits, so you can't run Evalbot under Win32.
REMOTE CONTROL
Once evalbot.p6
is connected to IRC, everybody can send it expressions to eval:
<you> ?eval 42
<evalbot> 42
Because of BSD::Resource
and Pugs's safemode, Evalbot should be able to withstand most attacks (infinite loops, huge memory consumption, unsafe I/O, etc. etc.):
<you> ?eval while 1 {}
<you> ?eval my $str = "42" x 1_000_000_000_000
<you> ?eval system "rm -rf /"
<you> ?eval say "\nPRIVMSG foo :bar"
<you> ?eval say "flood\n" x 1_000
# etc.
Note that the return value of an expression is not printed directly, but instead the .perl
method is called to prettyprint the result:
<you> ?eval "hi"
<evalbot> 'hi' # (note that quotes)
This behaviour may be confusing at first, especially if you intended to use &say
to output something:
<you> ?eval say "hi"
<evalbot> hi bool::true # (the bool::true is say("hi")'s return value)
There're other commands available, too:
<you> ?help
<evalbot> evalbot6 -- ?help | ?quit [reason] | ?raw ...
| ?join #chan | ?uptime | ?eval code
AUTHOR
Ingo Blechschmidt, <iblech@web.de>