2017 © Pedro Peláez
 

library client

PHP client for Bee.

image

bee/client

PHP client for Bee.

  • Thursday, September 14, 2017
  • by wprayudo
  • Repository
  • 1 Watchers
  • 0 Stars
  • 0 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 1 Versions
  • 0 % Grown

The README.md

PHP client for Bee

Installation

The recommended way to install the library is through Composer:, (*1)

$ composer require bee/client:@dev

Usage

use Bee\Client\Client;
use Bee\Client\Connection\StreamConnection;
use Bee\Client\Packer\PurePacker;

$conn = new StreamConnection();
// or
// $conn = new StreamConnection('tcp://127.0.0.1:3301', [
//     'socket_timeout' => 5.0, 
//     'connect_timeout' => 5.0,
//     'tcp_nodelay' => true,
// ]);
// or
// $conn = new StreamConnection('unix:///tmp/bee_instance.sock');

$client = new Client($conn, new PurePacker());
// or
// $client = new Client($conn, new PeclPacker());

// if authentication credentials are required
// $client->authenticate('username', 'userpass');

$space = $client->getSpace('my_space');

// Selecting all data
$result = $space->select();
var_dump($result->getData());

// Result: inserted tuple { 1, 'foo', 'bar' }
$space->insert([1, 'foo', 'bar']);

// Result: inserted tuple { 2, 'baz', 'qux'}
$space->upsert([2, 'baz', 'qux'], [['=', 1, 'BAZ'], ['=', 2, 'QUX']]);

// Result: updated tuple { 2, 'baz', 'qux'} with { 2, 'BAZ', 'QUX' }
$space->upsert([2, 'baz', 'qux'], [['=', 1, 'BAZ'], ['=', 2, 'QUX']]);

$result = $client->evaluate('return ...', [42]);
var_dump($result->getData());

$result = $client->call('box.stat');
var_dump($result->getData());

Note, (*2)

Using packer classes provided by the library require to install additional dependencies, which are not bundled with the library directly. Therefore, you have to install them manually. For example, if you plan to use PurePacker, install the rybakit/msgpack package. See the "suggest" section of composer.json for other alternatives., (*3)

Tests

To run unit tests:, (*4)

$ phpunit --testsuite Unit

To run integration tests:, (*5)

$ phpunit --testsuite Integration

Make sure to start client.lua first., (*6)

To run all tests:, (*7)

$ phpunit

If you already have Docker installed, you can run the tests in a docker container. First, create a container:, (*8)

$ ./dockerfile.py | docker build -t client -

The command above will create a container named client with PHP 7.1 runtime. You may change the default runtime by defining the IMAGE environment variable:, (*9)

$ IMAGE='php:7.0-cli' ./dockerfile.py | docker build -t client -

See a list of various images here., (*10)

Then run Bee instance (needed for integration tests):, (*11)

$ docker network create bee-php
$ docker run -d --net=bee-php --name=bee -v `pwd`:/client \
    bee/bee:1.7 bee /client/tests/Integration/client.lua

And then run both unit and integration tests:, (*12)

$ docker run --rm --net=bee-php --name client -v $(pwd):/client -w /client client

License

WTF license, (*13)

The Versions

14/09 2017

dev-master

9999999-dev

PHP client for Bee.

  Sources   Download

MIT

The Requires

  • php ^5.6|^7.0

 

The Development Requires

by Wahyu

nosql client pure bee