Events and listeners are two awesome functionality to handle decouple modules in a web application. The laravel Events follow the observer pattern, That allows you to subscribe and listen for various events that occur in your application.
Laravel use Artisan to create event and listeners. Event classes are typically stored in the app/Events directory, while their listeners are stored in app/Listeners. initially, these folders do not exist but generate events and listeners folders using Artisan console commands.
What are Laravel Events and Listeners?
An event is an action or occurrence that will happen in your application. The Application will raise events when something happens, The listeners will listen to that event and react accordingly. The listener is a program or method that will execute some logic or operation.
Let’s Create Events in Laravel 9
We will create a simple event that fired an event on call of rest API endpoints. The listener will listen to that event and print a log message.
You can also check other recommended tutorials of Lumen/Laravel,
- How to Monitor Beanstalkd Queue In Laravel Using Admin Console
- How to Configure supervisord on Linux for Laravel Jobs Queue
- How to Configure Memcached in Lumen Api Framework
- Simple Example of Laravel 5 Login System Using Sentry
- Simple Laravel Layouts using Blade Template and Bootstrap Theme
Step 1: We will generate TestEvent and TestEventListener file using the CLI command.
php artisan event:generate
The above command will create a file into the respective folder like, TestEvent into app/Events
and TestEventListener into app/Listeners
.
Aleternate way, you can also create above file using below command:
php artisan make:event TestEvent php artisan make:listener TestEventListener --event="TestEvent"
Step 2: We will make one entry into app/Providers/EventServiceProvide.php
file, this file is used to register all of your application’s event listeners.
protected $listen = [ ..., .., 'App\Events\TestEvent' => [ 'App\Listeners\TestEventListener', ], ];
Now modified handle()
method into TestEventListener.php
file, that will have some program, that will execute when the event will occur.
How to Dispach Event in Laravel
The dispatching event is very easy in laravel, You need to just pass the event class object into Event::fire()
method and event will fire when the testEvent()
method will call.
use App\Events\Event; use App\Events\TestEvent; public function testEvent(){ try { Log::info('=== Hello ========'); Event::fire(new TestEvent()); return 'hello'; } catch(Exception $ex) { Log::info('Error'. $e->getMessage()); return $ex; } }
Above will sync manner to execute logic, if the someting is complex and time consuming process to execute on occurance of event, then mostly developer recommended use Laravel Queue for background lengthy process.
How to Use Larevel Event in Queue
This step will help to add event into queue so that listeners method will process into the background of laravel application. I will use same EVENT and add into Laravel queue.
You can use any available queue driver like db,redist or beanstakd. You can get more information of laravel queue from create Queue and Run Jobs using worker in Lumen/Laravel
We will create Job file using below command:
php artisan make:job MyJob
Above command will create jobs/MyJob.php
file and file would be like below:
<?php namespace App\Jobs; use Log; use Illuminate\Bus\Queueable; use Illuminate\Queue\SerializesModels; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Foundation\Bus\Dispatchable; class MyJob implements ShouldQueue { use Dispatchable, InteractsWithQueue, Queueable, SerializesModels; /** * Create a new job instance. * * @return void */ public function __construct() { // } /** * Execute the job. * * @return void */ public function handle() { // Log::info("hello! I am queue handler!!!"); } }
We will change Listener TestEventListener.php
file and added job instance into handler method.
<?php namespace App\Listeners; use App\Events\Event; use App\Events\TestEvent; use Illuminate\Queue\InteractsWithQueue; use Illuminate\Contracts\Broadcasting\ShouldBroadcast; use Log; use App\Jobs\MyJob; class TestEventListener extends Event implements ShouldBroadcast { /** * Create the event listener. * * @return void */ public function __construct() { // } /** * Handle the event. * * @param TestEvent $event * @return void */ public function handle(TestEvent $event) { // dispatch(new MyJob()); Log::info('=== TestEventListener ========'); } }
We will dispaced the event in the controller file as below:
public function testEventQueue(){ try { Event::fire(new TestEvent()); return 'hello Queue'; } catch(Exception $ex) { Log::info('Error'. $e->getMessage()); return $ex; } }
Now run queue manually using below command, You can add auto pickuo of jobs using supervisord, You can get more information Configure supervisord on Linux for Laravel Jobs Queue
php artisan queue:work