mesak / laravel-linebot
build a Laravel api response package
v0.0.5
2023-02-15 18:45 UTC
Requires
- php: ^8.0
- linecorp/line-bot-sdk: ^7
README
採用 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); });
Event 事件
套件利用處理 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);