ICanBoogie/MessageBus master
  • Namespace
  • Class

Namespaces

  • ICanBoogie
    • MessageBus

Classes

  • SimpleMessageBus
  • SimpleMessageHandlerProvider

Interfaces

  • Exception
  • Message
  • MessageBus
  • MessageHandler
  • MessageHandlerProvider
  • MessagePusher
  • MessageToPush

Exceptions

  • NoHandlerForMessage
  • NoPusherForMessage
 1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 
<?php

/*
 * This file is part of the ICanBoogie package.
 *
 * (c) Olivier Laviale <olivier.laviale@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace ICanBoogie\MessageBus;

/**
 * A message bus that can handle messages right away or push them to a queue.
 */
class SimpleMessageBus implements MessageBus
{
    /**
     * @var MessageHandlerProvider|callable
     */
    private $message_handler_provider;

    /**
     * @var MessagePusher|callable
     */
    private $message_pusher;

    /**
     * @param MessageHandlerProvider|callable $message_handler_provider
     * @param MessagePusher|callable $message_pusher
     */
    public function __construct(callable $message_handler_provider, callable $message_pusher = null)
    {
        $this->message_handler_provider = $message_handler_provider;
        $this->message_pusher = $message_pusher;
    }

    /**
     * @param Message $message
     *
     * @return mixed
     */
    public function dispatch(Message $message)
    {
        if ($message instanceof MessageToPush)
        {
            return $this->push($message);
        }

        return $this->handle($message);
    }

    /**
     * @param Message $message
     *
     * @return mixed
     */
    protected function push(Message $message)
    {
        $pusher = $this->message_pusher;

        if (!$pusher)
        {
            throw new NoPusherForMessage($message);
        }

        return $pusher($message);
    }

    /**
     * @param Message $message
     *
     * @return mixed
     */
    protected function handle(Message $message)
    {
        $handler = $this->resolve_handler($message);

        return $handler($message);
    }

    /**
     * @param Message $message
     *
     * @return MessageHandler|callable
     *
     * @throws NoHandlerForMessage
     */
    protected function resolve_handler(Message $message)
    {
        $provider = $this->message_handler_provider;

        return $provider($message);
    }
}
ICanBoogie/MessageBus master API documentation generated by ApiGen