Skip to content

Commit

Permalink
Merge pull request #213 from laravel-notification-channels/revert-212…
Browse files Browse the repository at this point in the history
…-events

Revert "Dispatch additional events"
  • Loading branch information
dwightwatson authored Nov 14, 2024
2 parents 2685d4f + 5bd56e3 commit 292c482
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 51 deletions.
43 changes: 19 additions & 24 deletions src/FcmChannel.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,6 @@

use Illuminate\Contracts\Events\Dispatcher;
use Illuminate\Notifications\Events\NotificationFailed;
use Illuminate\Notifications\Events\NotificationSending;
use Illuminate\Notifications\Events\NotificationSent;
use Illuminate\Notifications\Notification;
use Illuminate\Support\Arr;
use Illuminate\Support\Collection;
Expand Down Expand Up @@ -37,40 +35,37 @@ public function send(mixed $notifiable, Notification $notification): ?Collection
{
$tokens = Arr::wrap($notifiable->routeNotificationFor('fcm', $notification));

if (empty($tokens)) {
return null;
}

$fcmMessage = $notification->toFcm($notifiable);

return Collection::make($tokens)
->chunk(self::TOKENS_PER_REQUEST)
->map(fn ($tokens) => $this->sendNotifications($notifiable, $notification, $tokens))
->map(fn (MulticastSendReport $report) => $this->dispatchEvents($notifiable, $notification, $report));
->map(fn ($tokens) => ($fcmMessage->client ?? $this->client)->sendMulticast($fcmMessage, $tokens->all()))
->map(fn (MulticastSendReport $report) => $this->checkReportForFailures($notifiable, $notification, $report));
}

/**
* Send the notification with the provided tokens.
* Handle the report for the notification and dispatch any failed notifications.
*/
protected function sendNotifications(mixed $notifiable, Notification $notification, Collection $tokens): MulticastSendReport
protected function checkReportForFailures(mixed $notifiable, Notification $notification, MulticastSendReport $report): MulticastSendReport
{
$fcmMessage = $notification->toFcm($notifiable);

$this->events->dispatch(
new NotificationSending($notifiable, $notification, self::class)
);
Collection::make($report->getItems())
->filter(fn (SendReport $report) => $report->isFailure())
->each(fn (SendReport $report) => $this->dispatchFailedNotification($notifiable, $notification, $report));

return ($fcmMessage->client ?? $this->client)->sendMulticast($fcmMessage, $tokens->all());
return $report;
}

/**
* Handle the report for the notification and dispatch any failed notifications.
* Dispatch failed event.
*/
protected function dispatchEvents(mixed $notifiable, Notification $notification, MulticastSendReport $report): MulticastSendReport
protected function dispatchFailedNotification(mixed $notifiable, Notification $notification, SendReport $report): void
{
Collection::make($report->getItems())
->each(function (SendReport $report) use ($notifiable, $notification) {
$event = $report->isSuccess()
? new NotificationSent($notifiable, $notification, self::class, compact('report'))
: new NotificationFailed($notifiable, $notification, self::class, compact('report'));

$this->events->dispatch($event);
});

return $report;
$this->events->dispatch(new NotificationFailed($notifiable, $notification, self::class, [
'report' => $report,
]));
}
}
30 changes: 3 additions & 27 deletions tests/FcmChannelTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,6 @@

use Exception;
use Illuminate\Contracts\Events\Dispatcher;
use Illuminate\Notifications\Events\NotificationFailed;
use Illuminate\Notifications\Events\NotificationSending;
use Illuminate\Notifications\Events\NotificationSent;
use Illuminate\Notifications\Notifiable;
use Illuminate\Notifications\Notification;
use Illuminate\Support\Collection;
Expand Down Expand Up @@ -39,14 +36,7 @@ public function test_it_can_be_instantiated()
public function test_it_can_send_notifications()
{
$events = Mockery::mock(Dispatcher::class);
$events->shouldReceive('dispatch')
->once()
->with(Mockery::type(NotificationSending::class));
$events->shouldReceive('dispatch')
->once()
->with(Mockery::type(NotificationSent::class));
$events->shouldNotReceive('dispatch')
->with(Mockery::type(NotificationFailed::class));
$events->shouldNotReceive('dispatch');

$firebase = Mockery::mock(Messaging::class);
$firebase->shouldReceive('sendMulticast')
Expand All @@ -66,14 +56,7 @@ public function test_it_can_send_notifications()
public function test_it_can_send_notifications_with_custom_client()
{
$events = Mockery::mock(Dispatcher::class);
$events->shouldReceive('dispatch')
->once()
->with(Mockery::type(NotificationSending::class));
$events->shouldReceive('dispatch')
->once()
->with(Mockery::type(NotificationSent::class));
$events->shouldNotReceive('dispatch')
->with(Mockery::type(NotificationFailed::class));
$events->shouldNotReceive('dispatch');

$firebase = Mockery::mock(Messaging::class);
$events->shouldNotReceive('sendMulticast');
Expand All @@ -95,14 +78,7 @@ public function test_it_can_send_notifications_with_custom_client()
public function test_it_can_dispatch_events()
{
$events = Mockery::mock(Dispatcher::class);
$events->shouldReceive('dispatch')
->once()
->with(Mockery::type(NotificationSending::class));
$events->shouldNotReceive('dispatch')
->with(Mockery::type(NotificationSent::class));
$events->shouldReceive('dispatch')
->once()
->with(Mockery::type(NotificationFailed::class));
$events->shouldReceive('dispatch')->once();

$firebase = Mockery::mock(Messaging::class);
$firebase->shouldReceive('sendMulticast')
Expand Down

0 comments on commit 292c482

Please sign in to comment.