Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/handcraftedinthealps/redistransportbundle

[DEPRECATED] Now part of symfony/messenger since 4.3. Use that implementation instead!
https://github.com/handcraftedinthealps/redistransportbundle

message-bus php redis symfony symfony-bundle symfony-messenger

Last synced: 3 months ago
JSON representation

[DEPRECATED] Now part of symfony/messenger since 4.3. Use that implementation instead!

Awesome Lists containing this project

README

        

# RedisTransportBundle ⛰

[![GitHub license](https://img.shields.io/github/license/handcraftedinthealps/RedisTransportBundle.svg)](https://github.com/handcraftedinthealps/RedisTransportBundle/blob/master/LICENSE)
[![GitHub tag (latest SemVer)](https://img.shields.io/github/tag/handcraftedinthealps/RedisTransportBundle.svg)](https://github.com/handcraftedinthealps/RedisTransportBundle/releases)
[![CircleCI](https://circleci.com/gh/sulu/sulu/tree/develop.svg?style=shield)](https://circleci.com/gh/handcraftedinthealps/RedisTransportBundle/tree/master)

A symfony messenger transport implementation for redis streams.

> **NOTE: Most of the logic has moved to the Core Symfony Messenger component in 4.3. So this bundle is not longer a requirement to use messenger with redis streams. You can now use the `redis://` instead of `redis-stream://` and remove this bundle from your requirements.**

## Requirements

- PHP: **`^7.1`**
- Redis Extension: **`^4.2`**
- Redis Server: **`^5.0`**

## Symfony compatibility

| Symfony Messenger Version | Bundle Version
|---------------------------|------------------
| 4.2 | 1.0
| 4.3 | 1.1

When upgrading to symfony 4.3 you should replace this bundle
with the symfony `redis://` transport and remove the bundle
from your requirements.

## Installation

You need [composer](https://getcomposer.org) to install this bundle to your symfony application.

```bash
composer require handcraftedinthealps/redis-transport-bundle
```

## Configuration

### Symfony

When using the **symfony/framework-bundle** you can configure the following:

```yaml
# config/packages/framework.yaml
framework:
messenger:
routing:
'HandcraftedInTheAlps\Bundle\RedisTransportBundle\Message\DomainEventMessage':
senders: ['redis_stream']
transports:
redis_stream: 'redis-stream://127.0.0.1:6379/my_stream/my_group/my_consumer'
```

You can then send a DomainEventMessage or your custom Message over the redis stream:

```php
use HandcraftedInTheAlps\Bundle\RedisTransportBundle\Message\DomainEventMessage;

$this->messageBus->dispatch(
new DomainEventMessage(
'mountain.modified', // the custom event action
'mountain', // the model which has been changed
'1', // the model id or uuid
[ // the model payload
'id' => '1',
'name' => 'Piz Buin',
'height' => 3312,
]
)
);
```

And you can consume the messages with:

```bash
bin/console messenger:consume-messages redis_stream
```

Have also a look at the [messenger component documentation](https://symfony.com/doc/current/components/messenger.html) and [messenger usage documentation](https://symfony.com/doc/current/messenger.html).

## Commands

Messages in streams won't be removed by default. Therefor this bundle provides a command:

```
bin/console redis-transport:trim --maxlen 1000
```