1POE::Component::IRC::PlUusgeirn:C:oBnottrCiobmumtaePndOdE(P:3e:)rClomDpoocnuemnetn:t:aItRiCo:n:Plugin::BotCommand(3)
2
3
4
6 POE::Component::IRC::Plugin::BotCommand - A PoCo-IRC plugin which
7 handles commands issued to your bot
8
10 use POE;
11 use POE::Component::Client::DNS;
12 use POE::Component::IRC;
13 use POE::Component::IRC::Plugin::BotCommand;
14
15 my @channels = ('#channel1', '#channel2');
16 my $dns = POE::Component::Client::DNS->spawn();
17 my $irc = POE::Component::IRC->spawn(
18 nick => 'YourBot',
19 server => 'some.irc.server',
20 );
21
22 POE::Session->create(
23 package_states => [
24 main => [ qw(_start irc_001 irc_botcmd_slap irc_botcmd_lookup dns_response) ],
25 ],
26 );
27
28 $poe_kernel->run();
29
30 sub _start {
31 $irc->plugin_add('BotCommand', POE::Component::IRC::Plugin::BotCommand->new(
32 Commands => {
33 slap => 'Takes one argument: a nickname to slap.',
34 lookup => 'Takes two arguments: a record type (optional), and a host.',
35 }
36 ));
37 $irc->yield(register => qw(001 botcmd_slap botcmd_lookup));
38 $irc->yield(connect => { });
39 }
40
41 # join some channels
42 sub irc_001 {
43 $irc->yield(join => $_) for @channels;
44 return;
45 }
46
47 # the good old slap
48 sub irc_botcmd_slap {
49 my $nick = (split /!/, $_[ARG0])[0];
50 my ($where, $arg) = @_[ARG1, ARG2];
51 $irc->yield(ctcp => $where, "ACTION slaps $arg");
52 return;
53 }
54
55 # non-blocking dns lookup
56 sub irc_botcmd_lookup {
57 my $nick = (split /!/, $_[ARG0])[0];
58 my ($where, $arg) = @_[ARG1, ARG2];
59 my ($type, $host) = $arg =~ /^(?:(\w+) )?(\S+)/;
60
61 my $res = $dns->resolve(
62 event => 'dns_response',
63 host => $host,
64 type => $type,
65 context => {
66 where => $where,
67 nick => $nick,
68 },
69 );
70 $poe_kernel->yield(dns_response => $res) if $res;
71 return;
72 }
73
74 sub dns_response {
75 my $res = $_[ARG0];
76 my @answers = map { $_->rdatastr } $res->{response}->answer() if $res->{response};
77
78 $irc->yield(
79 'notice',
80 $res->{context}->{where},
81 $res->{context}->{nick} . (@answers
82 ? ": @answers"
83 : ': no answers for "' . $res->{host} . '"')
84 );
85
86 return;
87 }
88
90 POE::Component::IRC::Plugin::BotCommand is a POE::Component::IRC
91 plugin. It provides you with a standard interface to define bot
92 commands and lets you know when they are issued. Commands are accepted
93 as channel or private messages.
94
95 The plugin will respond to the 'help' command by default, listing
96 available commands and information on how to use them. However, if you
97 add a help command yourself, that one will be used instead.
98
100 "new"
101 'Commands', a hash reference, with your commands as keys, and usage
102 information as values. If the usage string contains newlines, the
103 plugin will send one message for each line.
104
105 If a command's value is a HASH ref like this:
106
107 $irc->plugin_add('BotCommand', POE::Component::IRC::Plugin::BotCommand->new(
108 Commands => {
109 slap => {
110 info => 'Slap someone',
111 args => [qw(nickname)],
112 nickname => 'nickname to slap'
113 }
114 }
115 ));
116
117 The args array reference is than used to validate number of arguments
118 required and to name arguments passed to event handler. Help is than
119 generated from "info" and other hash keys which represent arguments
120 (they are optional).
121
122 An optional "handler" key can be specified inside the HASH ref to
123 override the event handler. The irc_botcmd_ prefix is not
124 automatically prepended to the handler name when overriding it.
125
126 An optional "aliases" key can be specified inside the HASH ref
127 containing a array ref with alias names. The aliases can be specified
128 for help and to run the command.
129
130 Accepting commands
131
132 'In_channels', a boolean value indicating whether to accept commands in
133 channels. Default is true.
134
135 'In_private', a boolean value indicating whether to accept commands in
136 private. Default is true.
137
138 'Addressed', requires users to address the bot by name in order to
139 issue commands. Default is true.
140
141 'Prefix', a string which all commands must be prefixed with (except in
142 channels when 'Addressed' is true). Default is '!'. You can set it to
143 '' to allow bare commands.
144
145 'Bare_private', a boolean value indicating whether bare commands
146 (without the prefix) are allowed in private messages. Default is false.
147
148 Authorization
149
150 'Auth_sub', a subroutine reference which, if provided, will be called
151 for every command. The subroutine will be called in list context. If
152 the first value returned is true, the command will be processed as
153 normal. If the value is false, then no events will be generated, and an
154 error message will possibly be sent back to the user.
155
156 You can override the default error message by returning a second value,
157 an array reference of (zero or more) strings. Each string will be sent
158 as a message to the user.
159
160 Your subroutine will be called with the following arguments:
161
162 1. The IRC component object
163 2. The nick!user@host of the user
164 3. The place where the command was issued (the nickname of the user if
165 it was in private)
166 4. The name of the command
167 5. The command argument string
168
169 'Ignore_unauthorized', if true, the plugin will ignore unauthorized
170 commands, rather than printing an error message upon receiving them.
171 This is only relevant if 'Auth_sub' is also supplied. Default is false.
172
173 Help Command
174
175 'Help_sub', a subroutine reference which, if provided, will be called
176 upon the end of the predefined help command. The subroutine will be
177 called in list context.
178
179 Your subroutine will be called with the following arguments:
180
181 1. The IRC component object
182 2. The command.
183 3. The resolved command(after alias processing).
184 4. The arguments.
185 5. The generated help text as array.
186
187 Miscellaneous
188
189 'Ignore_unknown', if true, the plugin will ignore undefined commands,
190 rather than printing a help message upon receiving them. Default is
191 false.
192
193 'Method', how you want help messages to be delivered. Valid options are
194 'notice' (the default) and 'privmsg'.
195
196 'Eat', set to true to make the plugin hide "irc_public" events from
197 other plugins when they look like commands. Probably only useful when a
198 'Prefix' is defined. Default is false.
199
200 Returns a plugin object suitable for feeding to POE::Component::IRC's
201 "plugin_add" method.
202
203 "add"
204 Adds a new command. Takes two arguments, the name of the command, and a
205 string or hash reference containing its usage information (see "new").
206 Returns false if the command has already been defined or no info or
207 arguments are provided, true otherwise.
208
209 "remove"
210 Removes a command. Takes one argument, the name of the command. Returns
211 false if the command wasn't defined to begin with, true otherwise.
212
213 "list"
214 Takes no arguments. Returns a list of key/value pairs, the keys being
215 the command names and the values being the usage strings or hash
216 references.
217
218 "resolve_alias"
219 Takes one argument, a string to match against command aliases, if no
220 matching command can be found undef is returned.
221
223 "irc_botcmd_*"
224 You will receive an event like this for every valid command issued.
225 E.g. if 'slap' were a valid command, you would receive an
226 "irc_botcmd_slap" event every time someone issued that command. It
227 receives the following arguments:
228
229 · "ARG0": the nick!hostmask of the user who issued the command.
230
231 · "ARG1" is the name of the channel in which the command was issued,
232 or the sender's nickname if this was a private message.
233
234 · "ARG2": a string of arguments to the command, or hash reference
235 with arguments in case you defined command along with arguments, or
236 undef if there were no arguments
237
239 Hinrik Örn Sigurðsson, hinrik.sig@gmail.com
240
241
242
243perl v5.30.0 201P9O-E0:7:-C2o6mponent::IRC::Plugin::BotCommand(3)