Laravelのタスクスケジューラは、アプリケーションの定期的な処理を自動化するための強力なツールです。
しかし、タスクが実行された際の結果を迅速に把握することも重要です。
本記事では、Laravelの定期実行タスク(スケジュールタスク)の実行結果をSlackに通知する方法について解説します。
Slackを利用することで、タスクの成功や失敗をチーム全体に素早く伝えることができ、問題発生時の対応も迅速に行えます。
この記事を書いた人
data:image/s3,"s3://crabby-images/72c82/72c8267694e6f0f8f7b3f4b803278b338c9df3a3" alt="エンジニア起業家Yuki"
エンジニア起業家Yuki
- 2024年1月に起業し、自社サービスと受託開発で年収1億円を目指して奮闘中
- エンジニア歴4年目
- 文系芸術系大学出身→学生時代フリーランスとして2年半活動→23卒で自社開発ベンチャーに入社→起業
data:image/s3,"s3://crabby-images/71e95/71e957f77de2be73f26ac6dc2bd99c02f89e9cfb" alt=""
ポチップ
Slack Webhook URLの取得
https://api.slack.com/apps ←にアクセスします。
data:image/s3,"s3://crabby-images/da7ba/da7ba8d306c404b1afac28de756721eb7b90307d" alt=""
sign in to your Slack accountをクリック。
次の画面で、slackにサインインしましょう。
ログイン後、https://api.slack.com/apps にもう一度行く。
data:image/s3,"s3://crabby-images/50493/50493c44ef731baf53e328417c725b638a47fc27" alt=""
するとCreate an Appというボタンが表示されているのでクリック。
data:image/s3,"s3://crabby-images/9b4a3/9b4a3f9c9d7bd692d802b171d8f95fc40c44a1e4" alt=""
上記のモーダルが表示されるので、From scratch
を選択しましょう。
次に、App Name
とワークスペースを入力する画面になるので、通知を送りたいワークスペースを選択し、App Name
を入力します。
data:image/s3,"s3://crabby-images/d08e4/d08e484bc1cb52eb58710a415492e2d18bb84096" alt=""
App Name
には好きな名前をつけてください。
Create App
ボタンをクリックすると、以下のような画面になります。
data:image/s3,"s3://crabby-images/54892/5489232ed6d54fabdc873494116ca6f8b3ca8c27" alt=""
次にIncoming Webhooks
を選択します。
data:image/s3,"s3://crabby-images/52e58/52e58b30fd5e0fa04b6f05ce0f0f47d023cf8c2f" alt=""
On
に変更しましょう。
次に、同ページの下部に行き、Add New Webhook to Workspace
をクリック。
data:image/s3,"s3://crabby-images/b0217/b021782a6ed72355e7f9fd216272eb526b4d087c" alt=""
次に、チャンネルを選択する画面になりますので、通知を送りたいチャンネルを選択し許可する
をクリック。
data:image/s3,"s3://crabby-images/eb496/eb496278145bc5cf5d6404d010d4f018167dcba1" alt=""
これで設定完了です。
data:image/s3,"s3://crabby-images/d4820/d4820907a4707df01c43af9ba9a4e896f9095c24" alt=""
Copyを押してWebhook URLをコピーしておきましょう。
.env
に記述しておきましょう。
SLACK_WEBHOOK_URL=https://hooks.slack.com/services/....
SLACK_CHANNEL={チャンネル名を記述}
SLACK_SENDER_NAME={任意の名前を記述}
次にconfig/slack.php
を作成し、以下を記述します。
<?php
return [
'webhook_url' => env('SLACK_WEBHOOK_URL'),
'channel' => env('SLACK_CHANNEL'),
'sender_name' => env('SLACK_SENDER_NAME'),
];
これで準備OK。
パッケージのインストール(slack-notification-channel)
slack-notification-channelパッケージをインストールします。
composer require laravel/slack-notification-channel
Notificationクラスの作成
php artisan make:notification SendSlackNotification
実行するとapp/Notifications
の下にSendSlackNotification.php
ファイルが作成されました。
<?php
namespace App\Notifications;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Notifications\Messages\MailMessage;
use Illuminate\Notifications\Notification;
use Illuminate\Notifications\Messages\SlackMessage;
class SendSlackNotification extends Notification
{
use Queueable;
protected $message;
/**
* Create a new notification instance.
*/
public function __construct($message)
{
$this->message = $message;
}
/**
* Get the notification's delivery channels.
*
* @return array<int, string>
*/
public function via(object $notifiable): array
{
return ['slack'];
}
public function toSlack($notifiable)
{
return (new SlackMessage)
->content($this->message);
}
/**
* Get the array representation of the notification.
*
* @return array<string, mixed>
*/
public function toArray(object $notifiable): array
{
return [
//
];
}
}
軽くコード解説
via
メソッド
- このメソッドは、通知を送信するチャネルを指定します。
- ここでは
'slack'
を指定しており、Slackに通知を送信することを示しています。
toSlack
メソッド
- このメソッドは、Slackに送信するメッセージを構成します。
SlackMessage
クラスのインスタンスを作成し、メッセージ内容 (content
) を設定します。
Slack送信用のNotificationクラスを実際に使ってみる
コマンドの作成
Laravelの Artisan コマンドを使って、新しいコマンドを作成します。以下のコマンドをターミナルで実行します。
php artisan make:command TestCommand
ここでは、テスト用のTestCommand
という名前で作成します。
ご自身の環境に合わせて、ファイル名は変えてください。
コマンドファイルを編集する
<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
use App\Notifications\SendSlackNotification;
use Illuminate\Support\Facades\Notification;
class TestCommand extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'app:test-command';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Test sending slack notifications';
/**
* Execute the console command.
*/
public function handle()
{
$message = 'This is a test notification.';
Notification::route('slack', config('slack.webhook_url'))
->notify(new SendSlackNotification($message));
$this->info('Test notification sent to Slack: ' . $message);
}
}
このコードでは、app:test-command
コマンドを実行することで、Slackにテストメッセージを送信するようにしました。
実際はエラーが起きた時や、成功時に実行結果をSlackに送信するなどすると良いと思います。
コマンドの実行
ターミナルで次のコマンドを実行して、Slackにテストメッセージを送信します。
php artisan app:test-command
実行後、Slackにテストメッセージが送信されました🎉
data:image/s3,"s3://crabby-images/ef4c7/ef4c7c8f242443af245f616c418e97c66d3c7244" alt=""
参考URL
https://qiita.com/to3izo/items/c2d16f8b3e52b09e543e
data:image/s3,"s3://crabby-images/71e95/71e957f77de2be73f26ac6dc2bd99c02f89e9cfb" alt=""
ポチップ