Go to file
Maxime 3178fc309c fix composer.json 2025-01-20 14:28:12 +01:00
config init 2024-12-13 11:54:01 +01:00
src init 2024-12-13 11:54:01 +01:00
.gitignore init 2024-12-13 11:54:01 +01:00
README.md init 2024-12-13 11:54:01 +01:00
composer.json fix composer.json 2025-01-20 14:28:12 +01:00

README.md

laravel-push

The Bluesquare Push package allows you to send Push templates using Laravel notification system.

Installation

First prepare your composer.json:

composer config repositories.push vcs https://git.bluesquare.io/bluesquare/laravel-push.git -n

Then install the package:

composer require bluesquare/laravel-push

If you want to customize the config system:

php artisan vendor:publish

Finally, copy your API key from Bluesquare Push (senders section), and add it in your .env:

PUSH_API_KEY=your_api_key

You may also want to use your own API:

PUSH_API_URL=https://push.bluesquare.io/api/send

Usage

First, create a new notification or use an existing one:

php artisan make:notification MyAwesomeNotification

Add BluescaleMailChannel in the via() method:

return [PushChannel::class];

Then, create a 'toTemplate()' method, in which you specify your template fields :

public function toTemplate($notifiable)
{
    return (new PushTemplate("my-template-slug"))
        ->sender("john.doe@gmail.com", "John OPTIONAL") // OPTIONAL
        ->replyTo("jean.grey@gmail.com", "Jean OPTIONAL") // OPTIONAL
        ->recipients([
            [
                "email" => "elvis@gmail.com",
                "name": "Elvis", // OPTIONAL
                "parameters": ["key" => "value"] // OPTIONAL
                "unsubscribe_url": "https://my-unsubscribe-url.com" // OPTIONAL
            ],
            // ...
        ])
        ->addRecipient("edward@gmail.com") // OPTIONAL
        ->addRecipient(
            email: "edward@gmail.com",
            name: "Edward", // OPTIONAL
            parameters: ["key" => "value"], // OPTIONAL
            unsubscribe_url: "https://my-unsubscribe-url.com" // OPTIONAL
        )
        ->parameters(["key" => "value", "key" => "value"]) // OPTIONAL
        ->addParameter("key", "value") // OPTIONAL
        ->bulkMode() // OPTIONAL
        ->testMode() // OPTIONAL
        ->unsubscribeUrl("https://group-unsubscribe-url.com") // OPTIONAL
        ;
}

The $notifiable is automatically added as recipient.

In your controller, you can now send your template:

User::first()->notify(new MyAwesomeNotification);