Download the PHP package clue/redis-protocol without Composer

On this page you can find all versions of the php package clue/redis-protocol. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package redis-protocol

clue/redis-protocol

CI status installs on Packagist

A streaming Redis protocol (RESP) parser and serializer written in pure PHP.

This parser and serializer implementation allows you to parse Redis protocol messages into native PHP values and vice-versa. This is usually needed by a Redis client implementation which also handles the connection socket.

To re-iterate: This is not a Redis client implementation. This is a protocol implementation that is usually used by a Redis client implementation. If you're looking for an easy way to build your own client implementation, then this is for you. If you merely want to connect to a Redis server and issue some commands, you're probably better off using one of the existing client implementations.

Table of contents

Support us

We invest a lot of time developing, maintaining and updating our awesome open-source projects. You can help us sustain this high-quality of our work by becoming a sponsor on GitHub. Sponsors get numerous benefits in return, see our sponsoring page for details.

Let's take these projects to the next level together! 🚀

Quickstart example

See also the examples.

Usage

Factory

The factory helps with instantiating the right parser and serializer. Eventually the best available implementation will be chosen depending on your installed extensions. You're also free to instantiate them directly, but this will lock you down on a given implementation (which could be okay depending on your use-case).

Parser

The library includes a streaming Redis protocol parser. As such, it can safely parse Redis protocol messages and work with an incomplete data stream. For this, each included parser implements a single method ParserInterface::pushIncoming($chunk).

Model

Each message (response as well as request) is represented by a model implementing the ModelInterface that has two methods:

These models are very lightweight and add little overhead. They help keeping the code organized and also provide a means to distinguish a single line StatusReply from a binary-safe BulkReply.

The parser always returns models. Models can also be instantiated directly:

Serializer

The serializer is responsible for creating serialized messages and the corresponing message models to be sent across the wire.

Install

It's very unlikely you'll want to use this protocol parser standalone. It should be added as a dependency to your Redis client implementation instead. The recommended way to install this library is through Composer. New to Composer?

This will install the latest supported version:

See also the CHANGELOG for details about version upgrades.

This project aims to run on any platform and thus does not require any PHP extensions and supports running on legacy PHP 5.3 through current PHP 8+. It's highly recommended to use the latest supported PHP version for this project.

Tests

To run the test suite, you first need to clone this repo and then install all dependencies through Composer:

To run the test suite, go to the project root and run:

The test suite is set up to always ensure 100% code coverage across all supported environments. If you have the Xdebug extension installed, you can also generate a code coverage report locally like this:

License

Its parser and serializer originally used to be based on jpd/redisent, which is released under the ISC license, copyright (c) 2009-2012 Justin Poliey [email protected].

Other than that, this project is released under the permissive MIT license.

Did you know that I offer custom development services and issuing invoices for sponsorships of releases and for contributions? Contact me (@clue) for details.


All versions of redis-protocol with dependencies

PHP Build Version
Package Version
Requires php Version >=5.3
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package clue/redis-protocol contains the following files

Loading the files please wait ....