rtippin / messenger-bots
Messenger Bots Addon
Fund package maintenance!
RTippin
Installs: 1 526
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 1
Forks: 6
Open Issues: 0
Requires
- php: ^8.2|^8.3
- ext-json: *
- guzzlehttp/guzzle: ^7.3
- rtippin/messenger: ^1.23
Requires (Dev)
- orchestra/testbench: ~7|^8.0|^9.0
- phpunit/phpunit: ~9.0|^10.0
- dev-master
- v1.15.0
- v1.14.2
- v1.14.1
- v1.14.0
- v1.13.0
- v1.12.0
- v1.11.0
- v1.10.0
- v1.9.0
- v1.8.0
- v1.7.0
- v1.6.0
- v1.5.1
- v1.5.0
- v1.4.0
- v1.3.1
- v1.3.0
- v1.2.2
- v1.2.1
- v1.2.0
- v1.1.0
- v1.0.0
- v0.5-alpha.1
- v0.5-alpha.0
- v0.4-alpha.5
- v0.4-alpha.4
- v0.4-alpha.3
- v0.4-alpha.2
- v0.4-alpha.1
- v0.4-alpha.0
- v0.3-alpha.0
- v0.2-alpha.0
- v0.1-alpha.6
- v0.1-alpha.5
- v0.1-alpha.4
- v0.1-alpha.3
- v0.1-alpha.2
- v0.1-alpha.1
- v0.1-alpha.0
- dev-dev
This package is auto-updated.
Last update: 2024-10-23 21:40:06 UTC
README
This package is an addon for rtippin/messenger
Notice
- This package is not required to use the bots feature built into
Messenger
. - For more documentation on creating custom bot handlers and packages, visit the official Chat Bots documentation.
Features:
- Ready-made bot action handlers and packages that will plug into the core messenger package.
- Register only the selected bots you wish to use, or let us auto-register all bots we provide.
- Included Bot Handlers:
- Chuck Norris Bot
- Coin Toss Bot
- Commands Bot
- Dad Joke Bot
- Document Finder Bot
- Giphy Bot
- Insult Bot
- Invite Bot
- Joke Bot
- Kanye West Bot
- Knock Bot
- Location Bot
- Nuke Bot
- Random Image Bot
- Reaction Bomb Bot
- Reaction Bot
- Reply Bot
- Rock Paper Scissors Bot
- Roll Bot
- Weather Bot
- Wikipedia Bot
- YoMomma Bot
- YouTube Bot
- Included Packaged Bots:
- Games Package
- Jokester Package
- Neo package
Prerequisites
- To use this package, you must already have the core Messenger package installed.
- You must have bots enabled from within the messenger.php config, or your
.env
. - The built-in bot subscriber should also be enabled, unless you wish to register your own event subscriber.
- If the subscriber is queued, be sure to have your queue worker process the defined channel,
messenger-bots
is the default.
MESSENGER_BOTS_ENABLED=true
'bots' => [ 'enabled' => env('MESSENGER_BOTS_ENABLED', false), 'subscriber' => [ 'enabled' => true, 'queued' => true, 'channel' => 'messenger-bots', ], ],
Installation
Via Composer
composer require rtippin/messenger-bots
Config
'weather_api_key' => env('BOT_WEATHER_API_KEY'), 'ip_api_key' => env('BOT_LOCATION_API_KEY'), 'youtube_api_key' => env('BOT_YOUTUBE_API_KEY'), 'giphy_api_key' => env('BOT_GIPHY_API_KEY'), 'random_image_url' => env('BOT_RANDOM_IMAGE_URL', 'https://source.unsplash.com/random'), 'auto_register_all' => env('BOT_AUTO_REGISTER_ALL', false),
Publish the config file
php artisan vendor:publish --tag=messenger-bots
- To use weather bot, you must get an API key from Weather API
- To use YouTube bot, you must get an API key from Google Developers Console
- To use Giphy bot, you must get an API key from Giphy
- You may use the location bot without an API key, but for commercial use, you must get an API key from IP API
- Random image bot will use unsplash as the default endpoint to grab a random image from. You may overwrite this endpoint.
Auto Registering Handlers and Packages
- If you plan to use all the bot handlers and packaged bots provided, you can skip registering them manually by enabling the
BOT_AUTO_REGISTER_ALL
flag.
Update your .env
BOT_AUTO_REGISTER_ALL=true
Manually Registering Handlers and Bot Packages
- Inside your
MessengerServiceProvider
(or any of your providers), you must register all bot handlers and bot packages you want enabled in your application. - You can use the
MessengerBots
facade to register the handlers and packages. Be sure you do it inside theboot
method.
Example:
<?php namespace App\Providers; use Illuminate\Support\ServiceProvider; use RTippin\Messenger\Facades\MessengerBots; use RTippin\MessengerBots\Bots\ChuckNorrisBot; use RTippin\MessengerBots\Bots\CoinTossBot; use RTippin\MessengerBots\Bots\CommandsBot; use RTippin\MessengerBots\Bots\DadJokeBot; use RTippin\MessengerBots\Bots\DocumentFinderBot; use RTippin\MessengerBots\Bots\GiphyBot; use RTippin\MessengerBots\Bots\InsultBot; use RTippin\MessengerBots\Bots\InviteBot; use RTippin\MessengerBots\Bots\JokeBot; use RTippin\MessengerBots\Bots\KanyeBot; use RTippin\MessengerBots\Bots\KnockBot; use RTippin\MessengerBots\Bots\LocationBot; use RTippin\MessengerBots\Bots\NukeBot; use RTippin\MessengerBots\Bots\RandomImageBot; use RTippin\MessengerBots\Bots\ReactionBombBot; use RTippin\MessengerBots\Bots\ReactionBot; use RTippin\MessengerBots\Bots\ReplyBot; use RTippin\MessengerBots\Bots\RockPaperScissorsBot; use RTippin\MessengerBots\Bots\RollBot; use RTippin\MessengerBots\Bots\WeatherBot; use RTippin\MessengerBots\Bots\WikiBot; use RTippin\MessengerBots\Bots\YoMommaBot; use RTippin\MessengerBots\Bots\YoutubeBot; use RTippin\MessengerBots\Packages\GamesPackage; use RTippin\MessengerBots\Packages\JokesterPackage; use RTippin\MessengerBots\Packages\NeoPackage; class MessengerServiceProvider extends ServiceProvider { /** * Bootstrap any application services. * * @return void */ public function boot(): void { MessengerBots::registerHandlers([ ChuckNorrisBot::class, CoinTossBot::class, CommandsBot::class, DadJokeBot::class, DocumentFinderBot::class, GiphyBot::class, InsultBot::class, InviteBot::class, JokeBot::class, KanyeBot::class, KnockBot::class, LocationBot::class, NukeBot::class, RandomImageBot::class, ReactionBombBot::class, ReactionBot::class, ReplyBot::class, RockPaperScissorsBot::class, RollBot::class, WeatherBot::class, WikiBot::class, YoMommaBot::class, YoutubeBot::class, ]); MessengerBots::registerPackagedBots([ GamesPackage::class, JokesterPackage::class, NeoPackage::class, ]); } }