Download the PHP package sokanacademy/laravel-fluent-rabbitmq without Composer
On this page you can find all versions of the php package sokanacademy/laravel-fluent-rabbitmq. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download sokanacademy/laravel-fluent-rabbitmq
More information about sokanacademy/laravel-fluent-rabbitmq
Files in sokanacademy/laravel-fluent-rabbitmq
Package laravel-fluent-rabbitmq
Short Description integrate rabbitmq in a laravel application
License MIT
Homepage https://github.com/sokanacademy/Laravel-Fluent-RabbitMQ
Informations about the package laravel-fluent-rabbitmq
A package to work with RabbitMQ in an elegant way.
This package allows your laravel applications to easily communicate with each other in an event driven way.
One service can publish an event and another one can consume the event and take actions accordingly.
Installation
You can install the package via composer:
Then you should publish the package config with running this command:
This is the contents of the published config file:
Usage
Mark an event to be published on RabbitMQ
The only thing you must do is to make sure your event implements Sokanacademy\RabbitMQ\Support\ShouldPublish
interface
and that's it.
All of the event's public properties will be published, and you can have access to them in your consumer. Make sure these properties are primitive or Arrayable.
If you want your event to be published using a routing key, then consider adding routingKey method to your event:
declare exchanges in rabbitmq server
When a laravel application wants to publish events, you must run this command to create appropriate exchanges on RabbitMQ. For each event it will create an exchange with the name of event class. You can read more on exchanges types here.
The default type for exchanges will be 'fanout'. If you want to alter the type of exchange for an event you can add this property to your event:
Consume events from RabbitMQ
In the rabbitmq.php
config file you should list all the events you want to consume.
If you have same event in both services (publisher and consumer) then you can omit the map_into option for the event.
Then you can start consuming events with the following command:
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
- Sokanacademy
- All Contributors
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-fluent-rabbitmq with dependencies
illuminate/contracts Version ^10
php-amqplib/php-amqplib Version >=3.0
ext-json Version *