123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- <?php
- /*
- * This file is part of the Predis package.
- *
- * (c) Daniele Alessandri <suppakilla@gmail.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Predis\Protocol\Text;
- use Predis\CommunicationException;
- use Predis\Command\CommandInterface;
- use Predis\Connection\ComposableConnectionInterface;
- use Predis\Protocol\ProtocolException;
- use Predis\Protocol\ProtocolProcessorInterface;
- use Predis\Response;
- use Predis\Response\Iterator;
- /**
- * Protocol processor for the standard Redis wire protocol.
- *
- * @link http://redis.io/topics/protocol
- * @author Daniele Alessandri <suppakilla@gmail.com>
- */
- class ProtocolProcessor implements ProtocolProcessorInterface
- {
- protected $mbiterable;
- protected $serializer;
- /**
- *
- */
- public function __construct()
- {
- $this->mbiterable = false;
- $this->serializer = new RequestSerializer();
- }
- /**
- * {@inheritdoc}
- */
- public function write(ComposableConnectionInterface $connection, CommandInterface $command)
- {
- $request = $this->serializer->serialize($command);
- $connection->writeBytes($request);
- }
- /**
- * {@inheritdoc}
- */
- public function read(ComposableConnectionInterface $connection)
- {
- $chunk = $connection->readLine();
- $prefix = $chunk[0];
- $payload = substr($chunk, 1);
- switch ($prefix) {
- case '+': // inline
- return new Response\Status($payload);
- case '$': // bulk
- $size = (int) $payload;
- if ($size === -1) {
- return null;
- }
- return substr($connection->readBytes($size + 2), 0, -2);
- case '*': // multi bulk
- $count = (int) $payload;
- if ($count === -1) {
- return null;
- }
- if ($this->mbiterable) {
- return new Iterator\MultiBulk($connection, $count);
- }
- $multibulk = array();
- for ($i = 0; $i < $count; $i++) {
- $multibulk[$i] = $this->read($connection);
- }
- return $multibulk;
- case ':': // integer
- return (int) $payload;
- case '-': // error
- return new Response\Error($payload);
- default:
- CommunicationException::handle(new ProtocolException(
- $connection, "Unknown prefix: '$prefix'"
- ));
- }
- }
- /**
- * Enables or disables returning multibulk responses as specialized PHP
- * iterators used to stream bulk elements of a multibulk response instead
- * returning a plain array.
- *
- * Please note that streamable multibulk replies are not globally supported
- * by the abstractions built-in into Predis such as for transactions or
- * pipelines. Use them with care!
- *
- * @param bool $value Enable or disable streamable multibulk responses.
- */
- public function useIterableMultibulk($value)
- {
- $this->mbiterable = (bool) $value;
- }
- }
|