tudor2004/google-bot-laravel

Google Chat Bot for Laravel

v0.1.0 2017-12-15 21:02 UTC

This package is not auto-updated.

Last update: 2025-06-08 08:52:55 UTC


README

This package allows you to handle Google Chat Bot commands triggered through the new Google Chat Web Client. You can register multiple bots, each with it's custom commands.

Requirements

Laravel 5

Installation

Install the package using Composer package manager. Run following command in your project root:

composer require tudor2004/google-bot-laravel

Afterwards create an outgoing webhook on the new Google Chat Web Client for each of the bots registered.

Laravel 5

If you are allowing package discovery, than you don't need to do anything. The package registers it's own service provider and the GoogleBot facade.

Otherwise, add firstly the service provider to the providers array in config/app.php:

'providers' => [
  Tudorica\GoogleBot\GoogleBotServiceProvider::class,
],

Then add the facade to your aliases array:

'aliases' => [
  ...
  'GoogleBot' => Tudorica\GoogleBot\Facades\GoogleBotFacade::class,
],

Usage

After you've successfully registered your outgoing webhooks create a controller that responds to the webhook calls. The Google Chat pushes there events that are then handled by the bots registered.

Note that if you're using the facade in a namespace (e.g. App\Http\Controllers in Laravel 5) you'll need to either use GoogleBot at the top of your class to import it, or append a backslash to access the root namespace directly when calling methods, e.g. \GoogleBot::run($botClass, $data).

// Handle commands for a custom 'audio' bot. We pass all the request data that the Google Chat event sends us.
namespace App\Http\Controllers;

class WebhookController extends Controller
{
    public function webhook(Request $request)
    {
        try {        
            
            return GoogleBot::run(AudioBot::class, $request->all());
            
        } catch(BotException $ex) {
            return [
                'text' => 'Something wrong happend';
            ];
        }             
    }
}

Registering bots

Each bot must implement the BotContract interface, available in this package. This interface demands that you define the name() and commands() methods.

namespace App\Bots;
 
use Tudorica\GoogleBot\Contracts\BotContract;
 
class AudioBot extends BotContract
{
     public function name(): string
     {
         return 'Radio';
     }
 
     public function commands(): array
     {
         return [             
             AudioVolume::class             
         ];
     }
}

Registering commands

As you can see in the previous example, each bot can register multiple commands. Each command has to implement the CommandContract interface which demands that you define the allowedUsers(), name(), description() and a handle() method.

namespace App\Commands;
 
use Tudorica\GoogleBot\Contracts\CommandContract;
 
class AudioVolume implements CommandContract
{
    /**
     * You can here define a list of users that can perform this command. Use [*] to allow everyone.
     */ 
    public function allowedUsers(): array
    {
        return ['*'];
    }

    /**
     * Define here the command name. You can also use here regular expressions.
     */
    public function name(): string
    {
        return '!audio volume (.+)';
    }

    /**
     * This description message will be used for the help.
     */
    public function description(): string
    {
        return 'Set volume.';
    }

    /**
     * The handler the executes the command. This has to respond with a string, that will be in the end be returned in the chat room.
     */
    public function handle(string $command): string
    {
        // Some logic for turning the volume of your speakers up or down...

        return 'Ok, volume is now ' . $volume . '.';
    }
}