2017 © Pedro Peláez
 

library protobuf-php

PHP implementation of Google's Protocol Buffers

image

centraldesktop/protobuf-php

PHP implementation of Google's Protocol Buffers

  • Tuesday, January 23, 2018
  • by treyhyde
  • Repository
  • 17 Watchers
  • 24 Stars
  • 94,642 Installations
  • PHP
  • 9 Dependents
  • 1 Suggesters
  • 156 Forks
  • 1 Open issues
  • 36 Versions
  • 8 % Grown

The README.md

Protobuf for PHP

Protobuf for PHP is an implementation of Google's Protocol Buffers for the PHP language, supporting its binary data serialization and including a protoc plugin to generate PHP classes from .proto files., (*1)

Great effort has been put into generating PHP files that include all sort of type hints to aide IDE's with autocompletion. Therefore, it can not only be used to communicate with Protocol Buffers services but also as a generation tool for data objects no matter what the final serialization is., (*2)

For more information see the included man pages., (*3)

Requirements

  • PHP 5.3
  • Pear's Console_CommandLine (for the protoc wrapper tool)
  • Google's protoc compiler version 2.3 or above
  • GMP or BC Math extensions ¹, (*4)

    ¹ Only needed for negative values in int32, int64 or fixed64 types. See the known issues section., (*5)

Features

Working

  • Standard types (numbers, string, enums, messages, etc)
  • Extensions, Unknown and Packed fields
  • Generate service interfaces
  • Protoc compiler plugin to generate the PHP classes
  • Template based code generation. Go crazy and customize the generated code :)
  • Include comments from .proto files in the generated files
  • Pluggable serialization backends (codecs)
    • Standard Binary
    • Standard TextFormat ¹
    • PhpArray
    • JSON
    • ProtoJson (_TagMap_ and Indexed variants)
    • XML
  • Reflection capabilities
  • Dynamic messages with annotations support (no code generation step required)
  • Lazy decoding of messages to improve the performance in real world scenarios

¹ Only serialization is supported in this codec, (*6)

Future

  • Speed optimized code generation mode

Example usage

$person = new Tutorial\Person();
$person->name = 'DrSlump';
$person->setId(12);

$book = new Tutorial\AddressBook();
$book->addPerson($person);

// Use default codec
$data = $book->serialize();

// Use custom codec
$codec = new \DrSlump\Protobuf\Codec\Json();
$data = $codec->encode($book);
// ... or ...
$data = $book->serialize($codec);

Installation

composer install

Known issues

Types

PHP is very weak when dealing with numbers processing. Several work arounds have been applied to the standard binary codec to reduce incompatibilities between Protobuf types and PHP ones., (*7)

  • Protobuf stores floating point values using the IEEE 754 standard with 64bit words for the double and 32bit for the float types. PHP supports IEEE 754 natively although the precission is platform dependant, however it typically supports 64bit doubles. It means that if your PHP was compiled with 64bit sized doubles (or greater) you shouldn't have any problem encoding and decoded float and double typed values with Protobuf., (*8)

  • Integer values are also platform dependant in PHP. The library has been developed and tested against PHP binaries compiled with 64bit integers. The encoding and decoding algorithm should in theory work no matter if PHP uses 32bit or 64bit integers internally, just take into account that with 32bit integers the numbers cannot exceed in any case the PHP_INT_MAX value (2147483647)., (*9)

    While Protobuf supports unsigned integers PHP does not. In fact, numbers above the compiled PHP maximum integer (PHP_INT_MAX, 0x7FFFFFFFFFFFFFFF for 64bits) will be automatically casted to doubles, which typically will offer 53bits of decimal precission, allowing to safely work with numbers upto 0x20000000000000 (2^53), even if they are represented in PHP as floats instead of integers. Higher numbers will loose precission or might even return an infinity value, note that the library does not include any checking for these numbers and using them might provoke unexpected behaviour., (*10)

    Negative values when encoded as int32, int64 or fixed64 types require the big integer extensions GMP or BC Math (the later only for 64bit architectures) to be available in your PHP environment. The reason is that when encoding these negative numbers without using zigzag the binary representation uses the most significant bit for the sign, thus the numbers become above the maximum supported values in PHP. The library will check for these conditions and will automatically try to use GMP or BC to process the value., (*11)

Strings

The binary codec expects strings to be encoded using UTF-8. PHP does not natively support string encodings, PHP's string data type is basically a length delimited stream of bytes, so it's not trivial to include automatic encoding conversion into the library encoding and decoding routines. Instead of trying to guess or offer a configuration interface for the encoding, the binary codec will process the string type just as it would process byte one, delegating on your application the task of encoding or decoding in the desired character set., (*12)

Memory usage

Large messages might be troublesome since the way the library is modelled does not allow to parse or serialize messages as streams, instead the whole operation is performed in memory, which allows for faster processing but could consume too much RAM if messages are too large., (*13)

Unknown fields

Since wire types are different across different codec's formats, it's not possible to transcode unkwnon fields consumed in one codec to another. This means, for example, that when consuming a message using the binary codec, if it contains unknown fields they won't be included when serializing the message using the Json codec., (*14)

Generating PHP classes

The generation tool is designed to be run as a protoc plugin, thus it should work with any proto file supported by the official compiler., (*15)

protoc --plugin=protoc-gen-php --php_out=./build tutorial.proto

To make use of non-standard options in your proto files (like php.namespace) you'll have to import the php.proto file included with the library. It's location will depend on where you've installed this library., (*16)

protoc -I=./Protobuf-PHP/library/DrSlump/Protobuf/Compiler/protos \
       --plugin=protoc-gen-php --php_out=./build tutorial.proto

In order to make your life easier, the supplied protoc plugin offers an additional execution mode, where it acts as a wrapper for the protoc invocation. It will automatically include the php.proto path so you don't need to worry about it., (*17)

protoc-gen-php -o ./build tutorial.proto

Testing

mkdir -p test/generated ./protoc-gen-php.php -o test/generated -Dmultifile=true -i ./test/library/DrSlump/Protobuf/Test/protos/ ./test/library/DrSlump/Protobuf/Test/protos/*.proto ./vendor/bin/phpunit, (*18)

The Versions

23/01 2018

dev-master

9999999-dev https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

23/01 2018

0.8.4

0.8.4.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

15/09 2017

dev-chore/at-0.8.1a

dev-chore/at-0.8.1a https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

15/09 2017

0.8.3

0.8.3.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

13/09 2017

0.8.2

0.8.2.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

01/06 2016

0.8.1

0.8.1.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

12/05 2016

0.8.0

0.8.0.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

11/05 2016

dev-feature/upgrade_php_option

dev-feature/upgrade_php_option https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

15/04 2016

dev-feature/php7

dev-feature/php7 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

15/04 2016

0.7.4

0.7.4.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

15/04 2016

1.0.1

1.0.1.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

15/04 2016

1.0.0

1.0.0.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

03/03 2016

0.7.3

0.7.3.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

03/03 2016

0.7.2

0.7.2.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

20/01 2016

0.7.1

0.7.1.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

24/11 2015

0.7.0

0.7.0.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

24/11 2015

dev-bugfix/remove-lightweight-extension

dev-bugfix/remove-lightweight-extension https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

22/05 2015

dev-bugfix/mb_substr

dev-bugfix/mb_substr https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

22/05 2015

0.6.9

0.6.9.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

08/05 2015

dev-feature/unit_cleanups

dev-feature/unit_cleanups https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

29/04 2015

0.6.8

0.6.8.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

09/03 2015

0.6.7

0.6.7.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

04/03 2015

dev-bugfix/APP-8618

dev-bugfix/APP-8618 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

04/03 2015

0.6.6

0.6.6.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

26/02 2015

dev-feature/safer_optional

dev-feature/safer_optional https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

26/02 2015

0.6.5

0.6.5.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

26/02 2015

0.6.4

0.6.4.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

04/11 2014

0.6.3

0.6.3.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

04/11 2014

0.6.2

0.6.2.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

11/10 2014

0.6.1

0.6.1.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

11/10 2014

0.6.0

0.6.0.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

10/10 2014

dev-feature/options

dev-feature/options https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

22/07 2014

dev-feature/update-compliancy

dev-feature/update-compliancy https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

07/03 2014

0.5.2

0.5.2.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

18/01 2014

0.5.1

0.5.1.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing

16/01 2014

0.5.0

0.5.0.0 https://github.com/drslump/Protobuf-PHP

PHP implementation of Google's Protocol Buffers

  Sources   Download

MIT

The Requires

 

The Development Requires

protobuf protocol buffer serializing