Package Data | |
---|---|
Maintainer Username: | Renato Maldonado |
Maintainer Contact: | mallldonado@hotmail.com (renato maldonado) |
Package Create Date: | 2023-04-22 |
Package Last Update: | 2023-05-29 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-11-17 03:09:22 |
Package Statistics | |
---|---|
Total Downloads: | 3,421 |
Monthly Downloads: | 270 |
Daily Downloads: | 0 |
Total Stars: | 1 |
Total Watchers: | 1 |
Total Forks: | 0 |
Total Open Issues: | 0 |
A custom SQS connector for Laravel (or Lumen) that supports many jobs e any message types based in library https://github.com/dusterio/laravel-plain-sqs.
But each job will be responsible for one queue sqs. All will be execute, if message in some queue exists it will be processed.
To install simply run:
composer require renatomaldonado/laravel-sqs-consume
// Add in your config/app.php
'providers' => [
'...',
'Renatomaldonado\LaravelSqsConsume\Provider\LaravelSQSQueueServiceProvider',
];
// Add in your bootstrap/app.php
$app->register(Renatomaldonado\LaravelSqsConsume\Provider\LumenSQSQueueServiceProvider::class);
// Generate standard config file (Laravel only)
php artisan vendor:publish --provider="Renatomaldonado\LaravelSqsConsume\Provider\LaravelSQSQueueServiceProvider"
// In Lumen, create it manually (see example below) and register it in bootstrap/app.php
$app->configure('sqs-consumer');
Edit config/sqs-consumer.php to suit your needs. This config matches SQS queues with handler classes.
return [
/**
* Queues array for execute in each job
*/
'queues' => ['queue-sqs-name-example', 'queue-sqs-name-example-two'],
'handlers' => [
'queue-sqs-name-example' => 'your-job',
'queue-sqs-name-example-two' => 'your-job-two',
],
'default-handler' => 'job-default'
];
If queue is not found in 'handlers' array, SQS payload is passed to default handler.
Add sqs-consumer connection to your config/queue.php, eg:
...
'sqs-consumer' => [
'driver' => 'sqs-consumer',
'key' => env('AWS_KEY', ''),
'secret' => env('AWS_SECRET', ''),
'prefix' => 'https://sqs.ea-northheast-1.amazonaws.com/123456/',
'queue' => 'queue-sqs-name-example',
'region' => 'ea-northheast-1',
],
...
In your .env file, choose sqs-consumer as your new default queue connection:
QUEUE_CONNECTION=sqs-consumer
If a third-party application is creating custom-format JSON messages or any message, just add a handler in the config file and implement a handler class as follows:
use Illuminate\Contracts\Queue\Job as LaravelJob;
class ExempleJob extends Job
{
protected $data;
/**
* @param LaravelJob $job
* @param $data
*/
public function handle(LaravelJob $job, $data)
{
// This is incoming JSON payload, already decoded to an array
var_dump($data);
// Raw JSON payload from SQS, if necessary
var_dump($job->getRawBody());
}
}