2017 © Pedro Peláez
 

library php-pubsub

An adapter based PubSub package for PHP

image

superbalist/php-pubsub

An adapter based PubSub package for PHP

  • Wednesday, May 24, 2017
  • by matthewgoslett
  • Repository
  • 23 Watchers
  • 12 Stars
  • 56,391 Installations
  • PHP
  • 13 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 3 Versions
  • 12 % Grown

The README.md

php-pubsub

A PHP abstraction for the pub-sub pattern, (*1)

Author Build Status StyleCI Software License Packagist Version Total Downloads, (*2)

Installation

composer require superbalist/php-pubsub

Adapters

  • Local (bundled)
  • /dev/null (bundled)
  • Redis - https://github.com/Superbalist/php-pubsub-redis
  • Kafka - https://github.com/Superbalist/php-pubsub-kafka
  • Google Cloud - https://github.com/Superbalist/php-pubsub-google-cloud
  • HTTP - https://github.com/Superbalist/php-pubsub-http

Integrations

Want to get started quickly? Check out some of these integrations:, (*3)

  • Laravel - https://github.com/Superbalist/laravel-pubsub

Usage

$adapter = new \Superbalist\PubSub\Adapters\LocalPubSubAdapter();

// consume messages
$adapter->subscribe('my_channel', function ($message) {
    var_dump($message);
});

// publish messages
$adapter->publish('my_channel', 'Hello World!');

// publish multiple messages
$messages = [
    'message 1',
    'message 2',
];
$adapter->publishBatch('my_channel', $messages);

Writing an Adapter

You can easily write your own custom adapter by implementing the PubSubAdapterInterface interface., (*4)

Your adapter must implement the following methods:, (*5)

/**
 * Subscribe a handler to a channel.
 *
 * @param string $channel
 * @param callable $handler
 */
public function subscribe($channel, callable $handler);

/**
 * Publish a message to a channel.
 *
 * @param string $channel
 * @param mixed $message
 */
public function publish($channel, $message);

/**
 * Publish multiple messages to a channel.
 *
 * @param string $channel
 * @param array $messages
 */
public function publishBatch($channel, array $messages);

Examples

The library comes with examples for all adapters and a Dockerfile for running the example scripts., (*6)

Run make up., (*7)

You will start at a bash prompt in the /opt/php-pubsub directory., (*8)

If you need another shell to publish a message to a blocking consumer, you can run docker-compose run php-pubsub /bin/bash, (*9)

To run the examples:, (*10)

$ php examples/LocalExample.php

The Versions

24/05 2017

dev-master

9999999-dev

An adapter based PubSub package for PHP

  Sources   Download

MIT

The Requires

  • php >=5.6.0

 

The Development Requires

by Superbalist.com a division of Takealot Online (Pty) Ltd

16/05 2017

2.0.0

2.0.0.0

An adapter based PubSub package for PHP

  Sources   Download

MIT

The Requires

  • php >=5.6.0

 

The Development Requires

by Superbalist.com a division of Takealot Online (Pty) Ltd

02/09 2016

1.0.0

1.0.0.0

An adapter based PubSub package for PHP

  Sources   Download

MIT

The Requires

  • php >=5.6.0

 

The Development Requires

by Superbalist.com a division of Takealot Online (Pty) Ltd