Centrifuge broadcaster for laravel >= 8.x
luisozparr/centrifuge-broadcaster is a Laravel package for centrifuge broadcaster for laravel >= 8.x.
It currently has 0 GitHub stars and 232 downloads on Packagist (latest version v2.4.0-rc).
Install it with composer require luisozparr/centrifuge-broadcaster.
Discover more Laravel packages by luisozparr
or browse all Laravel packages to compare alternatives.
Last updated
Centrifuge broadcaster for laravel >= 5.7 And Lumen >= 7.0 (Tested with Laravel 5.6, 7.0 and Lumen 7.0)
Require this package with composer:
composer require LuisOzParr/centrifuge-broadcaster
Open your config/app.php and add the following to the providers array:
'providers' => [
// ...
LaraComponents\Centrifuge\CentrifugeServiceProvider::class,
// And uncomment BroadcastServiceProvider
App\Providers\BroadcastServiceProvider::class,
],
Open your config/broadcasting.php and add the following to it:
'connections' => [
'centrifuge' => [
'driver' => 'centrifuge',
'url' => env('CENTRIFUGE_URL', 'http://127.0.0.1:8000'),
'token_ttl' => env('CENTRIFUGE_TOKEN_TTL', 3600),
'token_issuer' => env('APP_URL', 'default'),
'secret' => env('CENTRIFUGE_SECRET', null),
'api_key' => env('CENTRIFUGE_API_KEY', null),
'ssl_key' => env('CENTRIFUGE_SSL_KEY', null),
'verify' => env('CENTRIFUGE_VERIFY', false),
],
// ...
],
You can also add a configuration to your .env file:
CENTRIFUGE_API_KEY=very-long-secret-api-key
CENTRIFUGE_SECRET=very-long-secret-key
CENTRIFUGE_URL=http://localhost:8000
CENTRIFUGE_SSL_KEY=/etc/ssl/some.pem
CENTRIFUGE_TOKEN_TTL=3600 # seconds
CENTRIFUGE_VERIFY=false
Do not forget to install the broadcast driver
BROADCAST_DRIVER=centrifuge
To configure the Centrifugo server, read the official documentation
For broadcasting events, see the official documentation of laravel
A simple example of using the client:
<?php
namespace App\Http\Controllers;
use LaraComponents\Centrifuge\Centrifuge;
class ExampleController extends Controller
{
public function home(Centrifuge $centrifuge)
{
// Send message into channel
$centrifuge->publish('channel-name', [
'key' => 'value'
]);
// Generate api sign
$apiSign = $centrifuge->generateApiSign('data');
// ...
}
}
| Name | Description | |------|-------------| | publish(string $channel, array $data, string $client = null) | Send message into channel. | | broadcast(array $channels, array $data, string $client = null) | Send message into multiple channel. | | presence(string $channel) | Get channel presence information (all clients currently subscribed on this channel). | | history(string $channel) | Get channel history information (list of last messages sent into channel). | | unsubscribe(string $user_id, string $channel = null) | Unsubscribe user from channel. | | disconnect(string $user_id) | Disconnect user by its ID. | | channels() | Get channels information (list of currently active channels). | | stats() | Get stats information about running server nodes. | | generateToken(string $userId) | Generate JWT token for client. | | generateApiSign(string $data) | Generate api sign. |
The MIT License (MIT). Please see License File for more information.