The easiest way to listen for BotMan commands is by "listening" for a specific keyword and a Closure, providing a very simple and expressive method of defining bot commands. Take a look at this example, where the chatbot listens for the exact match of "foo" and calls the method once it hears the message.
$botman->hears('foo', function ($bot) {
$bot->reply('Hello World');
});
// Process incoming message
$botman->listen();
In addition to the Closure you can also pass a class and method that will get called if the keyword matches.
$botman->hears('foo', 'Some\Namespace\MyBotCommands@handleFoo');
// Process incoming message
$botman->listen();
class MyBotCommands {
public function handleFoo($bot) {
$bot->reply('Hello World');
}
}
Listening to basic keywords is fine, but sometimes you will need to capture parts of the information your bot users are providing. For example, you may need to listen for a bot command that captures a user's name. You may do so by defining command parameters:
$botman->hears('call me {name}', function ($bot, $name) {
$bot->reply('Your name is: '.$name);
});
You may define as many command parameters as required by your command:
$botman->hears('call me {name} the {adjective}', function ($bot, $name, $adjective) {
//
});
Command parameters are always encased within {}
braces and should consist of alphabetic characters only.
If command parameters do not give you enough power and flexibility for your bot commands, you can also use more complex regular expressions in your bot commands. For example, you may want your bot to only listen for digits. You may do so by defining a regular expression in your command like this:
$botman->hears('I want ([0-9]+)', function ($bot, $number) {
$bot->reply('You will get: '.$number);
});
Just like the command parameters, each regular expression match group will be passed to the handling Closure.
Command groups allow you to share command attributes, such as middleware or channels, across a large number of commands without needing to define those attributes on each individual command. Shared attributes are specified in an array format as the first parameter to the $botman->group
method.
A common use-case for command groups is restricting the commands to a specific messaging service using the driver
parameter in the group array:
$botman->group(['driver' => SlackDriver::class], function($bot) {
$bot->hears('keyword', function($bot) {
// Only listens on Slack
});
});
You may also group your commands, to send them through custom middleware classes. These classes can either listen for different parts of the message or extend your message by sending it to a third party service. The most common use-case would be the use of a Natural Language Processor like wit.ai or api.ai.
$botman->group(['middleware' => new MyCustomMiddleware()], function($bot) {
$bot->hears('keyword', function($bot) {
// Will be sent through the custom middleware object.
});
});
Command groups may also be used to restrict the commands to specific recipients, meaning they get restricted to the user sending the message to your bot.
$botman->group(['recipient' => '1234567890'], function($bot) {
$bot->hears('keyword', function($bot) {
// Only listens when recipient '1234567890' is sending the message.
});
});
BotMan allows you to create a fallback method, that gets called if none of your "hears" patterns matches. You may use this feature to give your bot users guidance on how to use your bot.
$botman->fallback(function($bot) {
$bot->reply('Sorry, I did not understand these commands. Here is a list of commands I understand: ...');
});