採用 laravel response 的方式來回應 LINEBOT 的訊息
composer require mesak/laravel-linebot
將設定檔複製到專案中
php artisan vendor:publish --tag=mesak-linebot.config --force
修改 config/linebot.php
中的設定
'listener' => 'App\Listeners\LineBotListener',
利用標準檔案 App\Listeners\LineBotListener
來建立 LINEBOT 的 Listener
php artisan vendor:publish --tag=mesak-linebot.listener
LineBotListener.php
LINEBOT 預設的事件:
- onMessage
- onUnsend
- onFollow
- onUnfollow
- onJoin
- onLeave
- onPostback
- onVideoPlayComplete
- onBeacon
- onAccountLink
- onMemberJoined
- onMemberLeft
- onThings
在 .env
中加入
LINE_CLIENT_ID=xxxxxxxx
LINE_CLIENT_SECRET=xxxxxxxx
在 route 中加入,對應 line webhook 的 post 事件
use Illuminate\Http\Request;
Route::post('/line', function (Request $request) {
return \Facades\Mesak\LineBot\Contracts\Bot::handle($request);
});
套件利用處理 Request 把內容塞入 Mesak\LineBot\Events\MessageEvent
中,利用 BotEventSubscribe 發起對話事件,最後回傳 Mesak\LineBot\Actions\BaseAction
的事件來處理需要的回應
如果需要擴充 LINEBOT 的功能,可以在 App\Providers\AppServiceProvider
中的 register 加入 \Mesak\LineBot\Contracts\Bot::class
合約綁定
$this->app->singleton(\Mesak\LineBot\Contracts\Bot::class, function ($app) {
return tap(new \App\Services\EntityBot(config('linebot') , $app['events']) ,function($bot){
$bot->boot();
});
});
自訂 EntityBot
類別
<?php
namespace App\Services\LineBot;
use Mesak\LineBot\EntityBot as BaseEntityBot;
use Mesak\LineBot\Contracts\Bot as BotContract;
class EntityBot extends BaseEntityBot implements BotContract
{
//do something...
}
如果要從外部呼叫 Bot,可以使用 Facades 靜態介面
舉例:
$response = \Facades\Mesak\LineBot\Contracts\Bot::getProfile($userId);