Allows receiving custom messages from Amazon SQS.
Note that message does not need to be in JSON either. Handler (by default JoblessHandler) will be called with raw message string. You can then do whatever you want with the string.
Because Laravel by default only allows receiving job messages from SQS. Those job messages have very strict form. Any incoming SQS message not following the form will be released back to the queue.
This component allows arbitrary SQS messages to be received and handled by the Laravel.
** Works on Laravel 5.3. **
Does not work on Laravel 5.2 or earlier.
Update 18.1.18: Kindly developed further by geraldosm, should work on Laravel 5.5.
composer require nollaversio/laravel-sqs-jobless
Note! If you get installation error because of minimum-stability issue, you need to add key-pair "minimum-stability": "dev" to your composer.json file.
Add Service Provider
'providers' => [
// ...
'Nollaversio\SQSJobless\JoblessSQSServiceProvider',
];
php artisan vendor:publish
Usage needs four steps:
- Make sure service provider is added.
- Create new record to config/queue.php
- Create App/Jobs/JoblessHandler class
- Change queue driver to sqs-jobless
- Start the queue.
'providers' => [
// ...
'Nollaversio\SQSJobless\JoblessSQSServiceProvider',
];
// app.config.queue.php
'sqs-jobless' => [
'driver' => 'sqs-jobless',
'key' => '1122334455667788XX',
'secret' => 'xxxxxxxxxxxxxxxxxxxxxxxxxx',
'prefix' => 'https://sqs.eu-central-1.amazonaws.com/11223344556677',
'queue' => 'msgs',
'region' => 'eu-central-1',
],
// App\Jobs\JoblessHandler.php
<?php
namespace App\Jobs;
use Illuminate\Bus\Queueable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
class JoblessHandler implements ShouldQueue
{
use InteractsWithQueue, Queueable, SerializesModels;
protected $passedInData;
/**
* Create a new job instance.
*
* @return void
*/
public function __construct($data)
{
// $data is STRING containing the msg content from SQS
$this->passedInData = $data;
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
\Log::info($this->passedInData);
// Check laravel.log, it should now contain msg string.
}
}
// .env
QUEUE_DRIVER=sqs-jobless
On command line:
php artisan queue:work
You can easily define your own handler class for messages. You can do this on config.sqs-jobless.php.
Note that only one handler can be defined at a time.