This a simple and easy to use wrapper for the official low-level Elasticsearch PHP Client.
It simplifies the work with Elasticsearch API by offering a lot of helper methods for managing indices, adding and updating documents and searching the index.
Via Composer
$composer require iivannov/elastic-commander
Minimum required (will work with default host - localhost:9200)
$commander = new Commander('YourIndexName');
With a list of hosts
$hosts = [
'192.168.1.1:9200', // IP + Port
'192.168.1.2', // Just IP
'mydomain.server.com:9201', // Domain + Port
'mydomain2.server.com', // Just Domain
'https://localhost', // SSL to localhost
'https://192.168.1.3:9200' // SSL to IP + Port
];
$commander = new Commander('YourIndexName', $hosts);
With a custom handler
$handler = new MyCustomHandler();
$commander = new Commander('YourIndexName', $hosts, $handler);
N.B. Each instance of the Commander works with the index name specified when initializing it. All actions and queries will be executed on this index. If you want to set a new index name to work with use:
$commander->reset('NewIndexName');
$commander->index()->create();
$commander->index()->delete();
A helper method that will reset the index by deleting it and creating it again.
$commander->index()->reset();
// Not finished
$commander->index()->optimize();
// Not finished
$commander->index()->stats();
$commander->mapping($mapping);
$commander->document('SomeDocumentType')->exists($id);
$commander->document('SomeDocumentType')->get($id);
In current version the add method expects an ID for the document.
$commander->document('SomeDocumentType')->add($id, $parameters);
$commander->document('SomeDocumentType')->add($id, $parameters);
Searching is done by passing a raw query array or by using a custom criteria class. After the query you have the option to get: the full response, only the ids, a map of the results or the total count.
$result = $commander->search('SomeDocumentType')->query($query, $sort, $size, $from);
$result = $commander->search('SomeDocumentType')->criteria($criteria);
After running either a raw query or one with a criteria class you can use one of the helper methods for manipulating the result response.
$result->response();
$result->total();
$result->ids();
The key will be the _id of the hit and the value will be an stdClass of the _source
$result->hits();
// Not finished