PHP code example of ratheeps / laravel-pub-sub-messaging
1. Go to this page and download the library: Download ratheeps/laravel-pub-sub-messaging library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
ratheeps / laravel-pub-sub-messaging example snippets
return [
'default_topic' => env('PUB_SUB_MESSAGING_DEFAULT_TOPIC'),
'default_auth_driver' => null,
// map the jobs to subscribe SNS topics to handle the consuming events
'map' => [
// \App\Jobs\TestSQSJob::class => 'arn:aws:sns:ap-southeast-1:931616835216:modelEvent',
],
'published_attributes' => [
'id',
'created_at',
'updated_at'
],
'sns' => [
'key' => env('PUB_SUB_MESSAGING_AWS_ACCESS_KEY'),
'secret' => env('PUB_SUB_MESSAGING_AWS_SECRET_ACCESS_KEY'),
'region' => env('PUB_SUB_MESSAGING_AWS_DEFAULT_REGION', 'us-east-1'),
'disk_options' => [
// Indicates when to send messages to S3., Allowed values are: ALWAYS, NEVER, IF_NEEDED.
'store_payload' => 'IF_NEEDED',
'disk' => env('PUB_SUB_MESSAGING_DISK', 'pub_sub_messaging_s3'),
'prefix' => ''
]
]
];
use Illuminate\Bus\Queueable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Support\Facades\Log;
class TestSQSJob implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
protected $passedInData;
/**
* Create a new job instance.
*
* @param array $data
*/
public function __construct(array $data)
{
// $data is array containing the msg content from SQS
$this->passedInData = $data;
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
Log::info(json_encode($this->passedInData));
// Check laravel.log, it should now contain msg string.
}
}
namespace App;
use Illuminate\Database\Eloquent\Model;
use Ratheeps\PubSubMessaging\Traits\SNSPublisher;
class Post extends Model
{
use SNSPublisher;
/**
* @var array
* Optional (default value is [] )
* Witch are the attributes should only from SNS message
*/
static $publishedAttributes = [
'id',
'created_at',
'updated_at'
];
/**
* @var array
* Optional (default value is [created','updated','deleted','restored'] )
* Witch events should send to SNS
*/
static $publishEvents = ['created', 'updated'];
/**
* @var string
* Optional (default value is load from config )
* Publish SNS topic
*/
static $publishTopic = 'SampleTopic';
/**
* Or
* static $publishTopic = [
* 'created' => 'SampleTopic'
* ];
*/
}
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.