socalnick / orchestrate-php-client
A PHP client for Orchestrate.io
Installs: 1 167
Dependents: 0
Suggesters: 0
Security: 0
Stars: 32
Watchers: 5
Forks: 5
Open Issues: 4
Requires
- php: >=5.5.0
- ext-curl: *
- guzzlehttp/guzzle: ~6.1
Requires (Dev)
- phpunit/phpunit: 3.7.*
README
Orchestrate PHP Client
A PHP client for Orchestrate.io.
Table of Contents
Installation
$ composer require socalnick/orchestrate-php-client
Creating a Client
Default to Amazon US East
use SocalNick\Orchestrate\Client; $client = new Client('your-api-key');
Use Amazon EU West
use SocalNick\Orchestrate\Client; $client = new Client('your-api-key', 'https://api.aws-eu-west-1.orchestrate.io/v0/');
Key / Value Operations
Put (also used to create a collection)
use SocalNick\Orchestrate\KvPutOperation; $kvPutOp = new KvPutOperation("first_collection", "first_key", json_encode(array("name" => "Nick"))); $kvObject = $client->execute($kvPutOp); $ref = $kvObject->getRef(); // 741357981fd7b5cb
Put if-match
use SocalNick\Orchestrate\KvPutOperation; $kvPutOp = new KvPutOperation("first_collection", "second_key", json_encode(array("name" => "Terry")), array('if-match' => '741357981fd7b5cb')); $kvObject = $client->execute($kvPutOp); $ref = $kvObject->getRef(); // 0d1f15ab524a5c5a
Put if-none-match
use SocalNick\Orchestrate\KvPutOperation; $kvPutOp = new KvPutOperation("first_collection", "second_key", json_encode(array("name" => "Bill")), array('if-none-match' => '*')); $kvObject = $client->execute($kvPutOp); // null
Post (auto-generated key)
use SocalNick\Orchestrate\KvPostOperation; $kvPostOp = new KvPostOperation("first_collection", json_encode(array("name" => "Nick"))); $kvObject = $client->execute($kvPostOp); $ref = $kvObject->getRef(); // 741357981fd7b5cb $key = $kvObject->getKey(); // 05fb279bc820dd05
Patch (partial update - operations)
use SocalNick\Orchestrate\KvPatchOperationsOperation; $kvPatchOperationsOp = new KvPatchOperationsOperation('first_collection', 'third_key'); $kvPatchOperationsOp ->add('birth_place.city', 'New York') ->remove('birth_place.country') ->replace('birth_place.state', 'New York') ->copy('full_name', 'name') ->test('age', 28) ->inc('age', 1) ->inc('years_until_death', -1); $result = $client->execute($kvPatchOperationsOp);
Patch (partial update - merge)
use SocalNick\Orchestrate\KvPatchMergeOperation; $partial = [ 'birth_place' => [ 'city' => 'New York', 'country' => null, 'state' => 'New York', ], 'first_name' => null, 'deprecated_first_name' => 'John', 'name' => 'John Foster', 'age' => 29, 'years_until_death' => 39, ]; $kvPatchMergeOp = new KvPatchMergeOperation('first_collection', 'third_key', json_encode($partial)); $result = self::$client->execute($kvPatchMergeOp);
Get
use SocalNick\Orchestrate\KvFetchOperation; $kvFetchOp = new KvFetchOperation("films", "the_godfather"); $kvObject = $client->execute($kvFetchOp); $ref = $kvObject->getRef(); // 9c1bc18e60d93848
Get a previous version by ref
use SocalNick\Orchestrate\KvFetchOperation; $kvFetchOp = new KvFetchOperation("first_collection", "second_key", "741357981fd7b5cb"); $kvObject = $client->execute($kvFetchOp); $ref = $kvObject->getRef(); // 741357981fd7b5cb
Delete
use SocalNick\Orchestrate\KvDeleteOperation; $kvDeleteOp = new KvDeleteOperation("first_collection", "first_key"); $result = $client->execute($kvDeleteOp); // true
Delete with purge
use SocalNick\Orchestrate\KvDeleteOperation; $kvDeleteOp = new KvDeleteOperation("first_collection", "first_key", true); $result = $client->execute($kvDeleteOp); // true
List
use SocalNick\Orchestrate\KvListOperation; $kvListOp = new KvListOperation("films"); $kvListObject = $client->execute($kvListOp); $count = $kvListObject->count(); // 10 $link = $kvListObject->getLink(); // /v0/films?limit=10&afterKey=the_godfather_part_2
List with inclusive start key
use SocalNick\Orchestrate\KvListOperation; $kvListOp = new KvListOperation("films", 5, 'anchorman'); $kvListObject = $client->execute($kvListOp); $count = $kvListObject->count(); // 5 $link = $kvListObject->getLink(); // /v0/films?limit=5&afterKey=pulp_fiction
List with exclusive after key
use SocalNick\Orchestrate\KvListOperation; $kvListOp = new KvListOperation("films", 5, null, 'anchorman'); $kvListObject = $client->execute($kvListOp); $count = $kvListObject->count(); // 5 $link = $kvListObject->getLink(); // /v0/films?limit=5&afterKey=shawshank_redemption
Delete collection
use SocalNick\Orchestrate\CollectionDeleteOperation; $cDeleteOp = new CollectionDeleteOperation("first_collection"); $result = $client->execute($cDeleteOp); // true
Search
Default Search
use SocalNick\Orchestrate\SearchOperation; $searchOp = new SearchOperation("films"); $searchResult = $client->execute($searchOp); $count = $searchResult->count(); // 10 $total = $searchResult->totalCount(); // 12
Search with query, limit, offset, and sort
use SocalNick\Orchestrate\SearchOperation; $searchOp = new SearchOperation("films", "Genre:*Crime*", 2, 2, 'value.Title:asc'); $searchResult = $client->execute($searchOp); $count = $searchResult->count(); // 2 $total = $searchResult->totalCount(); // 8 $firstKey = $searchResult->getValue()['results'][0]['path']['key']; // lock_stock_and_two_smoking_barrels
Search aggregate
use SocalNick\Orchestrate\SearchAggregateOperation; $searchOp = new SearchAggregateOperation("films", 'value.imdbRating:stats'); $searchResult = $client->execute($searchOp); $min = $searchResult->getValue()['aggregates'][0]['statistics']['min']; // 5.9 $max = $searchResult->getValue()['aggregates'][0]['statistics']['max']; // 9.3
Events
Post defaults to now
use SocalNick\Orchestrate\EventPostOperation; $evPostOp = new EventPostOperation("films", "pulp_fiction", "comment", json_encode(array("message" => "This is my favorite movie!"))); $evPostResult = $client->execute($evPostOp); // instance_of SocalNick\Orchestrate\EventUpsertResult
Post with timestamp
use SocalNick\Orchestrate\EventPostOperation; $evPostOp = new EventPostOperation("films", "pulp_fiction", "comment", json_encode(array("message" => "This is my favorite movie!")), 1395029140000); $evPostResult = $client->execute($evPostOp); // instance_of SocalNick\Orchestrate\EventUpsertResult
Get (an individual event)
use SocalNick\Orchestrate\EventFetchOperation; $evFetchOp = new EventFetchOperation("films", "pulp_fiction", "comment", $evPostResult->getTimestamp(), $evPostResult->getOrdinal()); $evObject = $client->execute($evFetchOp); $message = $evObject->getValue()['value']['message']; // This is my favorite movie!
Put (update an existing event)
use SocalNick\Orchestrate\EventPutOperation; $evPutOp = new EventPutOperation("films", "pulp_fiction", "comment", json_encode(array("message" => "This is still my favorite movie!")), $evPostResult->getTimestamp(), $evPostResult->getOrdinal()); $evPutResult = $client->execute($evPutOp); // instance_of SocalNick\Orchestrate\EventUpsertResult
Put with ref (update an existing event if ref matches)
use SocalNick\Orchestrate\EventPutOperation; $evPutOp = new EventPutOperation("films", "pulp_fiction", "comment", json_encode(array("message" => "Seriously, this is still my favorite movie!")), $evPostResult->getTimestamp(), $evPostResult->getOrdinal(), $evPutResult->getRef()); $evPutResult = $client->execute($evPutOp); // instance_of SocalNick\Orchestrate\EventUpsertResult
Delete
use SocalNick\Orchestrate\EventDeleteOperation; $evDeleteOp = new EventDeleteOperation("films", "pulp_fiction", "comment", $evPutResult->getTimestamp(), $evPutResult->getOrdinal(), true); $result = $client->execute($evDeleteOp); // true
Delete with ref (only delete if ref matches)
use SocalNick\Orchestrate\EventDeleteOperation; $evDeleteOp = new EventDeleteOperation("films", "pulp_fiction", "comment", $evPutResult->getTimestamp(), $evPutResult->getOrdinal(), true, $evPutResult->getRef()); $result = $client->execute($evDeleteOp); // true
List
use SocalNick\Orchestrate\EventListOperation; $evListOp = new EventListOperation("films", "pulp_fiction", "comment"); $evListObject = $client->execute($evListOp); $evListObject->count(); // 10
List with limit
use SocalNick\Orchestrate\EventListOperation; $evListOp = new EventListOperation("films", "pulp_fiction", "comment", 20); $evListObject = $client->execute($evListOp); $evListObject->count(); // 20
List with range queries
The range parameters are formatted as "$timestamp/$ordinal" where $ordinal is optional. The timestamp value should be formatted as described in timestamps.
use SocalNick\Orchestrate\EventListOperation; $evListOp = new EventListOperation("films", "pulp_fiction", "comment", 20, $startEvent, $afterEvent, $beforeEvent, $endEvent); $evListObject = $client->execute($evListOp);
Graph
Put
use SocalNick\Orchestrate\GraphPutOperation; $graphPutOp = new GraphPutOperation("films", "the_godfather", "sequel", "films", "the_godfather_part_2"); $result = $client->execute($graphPutOp); // true $graphPutOp = new GraphPutOperation("films", "the_godfather_part_2", "sequel", "films", "the_godfather_part_3"); $result = $client->execute($graphPutOp); // true
Get
use SocalNick\Orchestrate\GraphFetchOperation; $graphFetchOp = new GraphFetchOperation("films", "the_godfather", "sequel/sequel"); $graphObject = $client->execute($graphFetchOp); $count = $graphObject->count(); // 1
Get with limit and offset
use SocalNick\Orchestrate\GraphFetchOperation; $graphFetchOp = new GraphFetchOperation("directors", "francis_ford_coppola", "films_directed", 1, 1); $graphObject = $client->execute($graphFetchOp); $count = $graphObject->count(); // 1 $next = $graphObject->getNext(); // /v0/directors/francis_ford_coppola/relations/films_directed?limit=1&offset=2 $prev = $graphObject->getPrev(); // /v0/directors/francis_ford_coppola/relations/films_directed?limit=1&offset=0
Delete
use SocalNick\Orchestrate\GraphDeleteOperation; $graphDeleteOp = new GraphDeleteOperation("films", "the_godfather", "sequel", "films", "the_godfather_part_2"); $result = $client->execute($graphDeleteOp); // true $graphDeleteOp = new GraphDeleteOperation("films", "the_godfather_part_2", "sequel", "films", "the_godfather_part_3"); $result = $client->execute($graphDeleteOp); // true use SocalNick\Orchestrate\GraphFetchOperation; $graphFetchOp = new GraphFetchOperation("films", "the_godfather", "sequel"); $graphObject = $client->execute($graphFetchOp); $count = $graphObject->count(); // 0 $graphFetchOp = new GraphFetchOperation("films", "the_godfather_part_2", "sequel"); $graphObject = $client->execute($graphFetchOp); $count = $graphObject->count(); // 0