Skip to content

macellan/onesignal

Folders and files

NameName
Last commit message
Last commit date

Latest commit

envercigalEnver Cigal
and
Enver Cigal
Aug 9, 2022
28f2d53 · Aug 9, 2022

History

26 Commits
Aug 9, 2022
May 30, 2022
Feb 24, 2022
May 30, 2022
May 30, 2022
May 30, 2022
Feb 24, 2022

Repository files navigation

OneSignal Notifications Channel for Laravel

Latest Version on Packagist StyleCI Scrutinizer Code Quality Total Downloads

This package makes it easy to send push notifications using OneSignal with Laravel 8.0+ and 9.0+

This plugin sends notifications only with OneSignal Player ID.

Installation

You can install this package via composer:

composer require macellan/onesignal

Settings

Add your OneSignal appId to your config/services.php:

// config/services.php
...
    'onesignal' => [
        'app_id' => env('ONESIGNAL_APP_ID', ''),
    ],
...

Usage

You can use the channel in your via() method inside the notification:

use Illuminate\Notifications\Notification;
use Macellan\OneSignal\OneSignalMessage;

class AccountApproved extends Notification
{
    public function via($notifiable)
    {
        return ['onesignal'];
    }

    public function toOneSignal($notifiable)
    {
        return OneSignalMessage::create()
            ->setSubject('Awesome App')
            ->setBody('Your account was approved!');  
    }
}

You can change appId of a specific notification, just add the setAppId() method

   public function toOneSignal($notifiable)
    {
        return OneSignalMessage::create()
            ->setAppId('Other AppId')
    }

In your notifiable model, make sure to include a routeNotificationForOneSignal() method.

public function routeNotificationForOneSignal()
{
    return $this->player_id;
}

On-Demand Notifications

Sometimes you may need to send a notification to someone who is not stored as a "user" of your application. Using the Notification::route method, you may specify ad-hoc notification routing information before sending the notification:

Notification::route('onesignal', 'player_id')  
            ->notify(new AccountApproved());

Credits