Laravel Event Listener.
Estimated reading time: 4 minutesEvent
is a specifictask
.Listener
listen
aevent
thentrigger
one or manyactions
.Actions<- Listener <- listen (event)
# generate from kernel
php artisan event:generate
# manually create
php artisan make:listener ListenerName
php artisan make:event EventName
event
EventName
class.
namespace App\Events;
use Illuminate\Broadcasting\Channel;
use Illuminate\Queue\SerializesModels;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
use App\User;
class EventName
{
use Dispatchable, InteractsWithSockets, SerializesModels;
public $user;
/**
* Create a new event instance.
*
* @return void
*/
public function __construct(User $user)
{
$this->user = $user;
}
/**
* Get the channels the event should broadcast on.
*
* @return \Illuminate\Broadcasting\Channel|array
*/
public function broadcastOn()
{
return new PrivateChannel('channel-name');
}
}
listener
namespace App\Listeners;
use App\Events\EventName;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
class ListenName
{
/**
* Create the event listener.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Handle the event.
*
* @param EventName $event
* @return void
*/
public function handle(EventName $event)
{
return $event;
}
}
register
app\Providers\EventServiceProvider.php
protected $listen = [
'App\Events\EventName' => [
'App\Listeners\ListenerName1',
'App\Listeners\ListenerName2',
'App\Listeners\ListenerNameALotOF',
],
];
fire / dispatching
use App\Events\OrderShipped;
event(new EventName($order));
event with queue
-
table create
php artisan queue:table php artisan migrate
- update inside .env for (database)
QUEUE_CONNECTION=database
-
implements ShouldQueue
inListenName
classnamespace App\Listeners; use App\Events\EventName; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Queue\ShouldQueue; class ListenName implements ShouldQueue { /** * Create the event listener. * * @return void */ public function __construct() { // } /** * Handle the event. * * @param EventName $event * @return void */ public function handle(EventName $event) { return $event; } }
php artisan queue::work
event with queue 2nd method
-
table create
php artisan queue:table php artisan migrate
-
implements ShouldQueue
inListenName
classnamespace App\Listeners; use App\Events\EventName; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Queue\ShouldQueue; class ListenName implements ShouldQueue { /** * The name of the connection the job should be sent to. * * @var string|null */ public $connection = 'database'; /** * The name of the queue the job should be sent to. * * @var string|null */ public $queue = 'listeners'; /** * The time (seconds) before the job should be processed. * * @var int */ public $delay = 60; /** * Create the event listener. * * @return void */ public function __construct() { // } /** * Handle the event. * * @param EventName $event * @return void */ public function handle(EventName $event) { return $event; } }
-
php artisan queue::work database --queue=listeners