LaravelPackages.net
Acme Inc.
Toggle sidebar
sarfraznawaz2005/laravel-sse

Laravel package to provide Server Sent Events functionality for your app.

4.721
48
3.0.0
About sarfraznawaz2005/laravel-sse

sarfraznawaz2005/laravel-sse is a Laravel package for laravel package to provide server sent events functionality for your app.. It currently has 48 GitHub stars and 4.721 downloads on Packagist (latest version 3.0.0). Install it with composer require sarfraznawaz2005/laravel-sse. Discover more Laravel packages by sarfraznawaz2005 or browse all Laravel packages to compare alternatives.

Last updated

Latest Version on Packagist Total Downloads

Laravel SSE

Laravel package to provide Server Sent Events functionality for your app. You can use this package to show instant notifications to your users without them having to refresh their pages.

Requirements

  • PHP >= 7
  • Laravel 5

Installation

Via Composer

$ composer require sarfraznawaz2005/laravel-sse

For Laravel < 5.5:

Add Service Provider to config/app.php in providers section

Sarfraznawaz2005\SSE\ServiceProvider::class,

Add Facade to config/app.php in aliases section

'SSE' => Sarfraznawaz2005\SSE\Facades\SSEFacade::class,

Publish package's config, migration and view files by running below command:

$ php artisan vendor:publish --provider="Sarfraznawaz2005\SSE\ServiceProvider"

Run php artisan migrate to create sselogs table.

Setup SSE

Setup config options in config/sse.php file and then add this in your view/layout file:

@include('sse::view')

Usage

Syntax:

/**
 * @param string $message : notification message
 * @param string $type : alert, success, error, warning, info
 * @param string $event : Type of event such as "EmailSent", "UserLoggedIn", etc
 */
SSEFacade::notify($message, $type = 'info', $event = 'message')

To show popup notifications on the screen, in your controllers/event classes, you can do:

use Sarfraznawaz2005\SSE\Facades\SSEFacade;

public function myMethod()
{
    SSEFacade::notify('hello world....');
    
    // or via helper
    sse_notify('hi there');
}

Customizing Notification Library

By default, package uses noty for showing notifications. You can customize this by modifying code in resources/views/vendor/sse/view.blade.php file.

Customizing SSE Events

By default, pacakge uses message event type for streaming response:

SSEFacade::notify($message, $type = 'info', $event = 'message')

Notice $event = 'message'. You can customize this, let's say you want to use UserLoggedIn as SSE event type:

use Sarfraznawaz2005\SSE\Facades\SSEFacade;

public function myMethod()
{
    SSEFacade::notify('hello world....', 'info', 'UserLoggedIn');
    
    // or via helper
    sse_notify('hi there', 'info', 'UserLoggedIn');
}

Then you need to handle this in your view yourself like this:

<script>
var es = new EventSource("{{route('__sse_stream__')}}");

es.addEventListener("UserLoggedIn", function (e) {
    var data = JSON.parse(e.data);
    alert(data.message);
}, false);

</script>

Credits

License

Please see the license file for more information.

Star History Chart