Package Data | |
---|---|
Maintainer Username: | babenkoivan |
Maintainer Contact: | babenko.i.a@gmail.com (Ivan Babenko) |
Package Create Date: | 2020-01-25 |
Package Last Update: | 2024-06-18 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-11-24 15:06:57 |
Package Statistics | |
---|---|
Total Downloads: | 2,317,470 |
Monthly Downloads: | 72,129 |
Daily Downloads: | 704 |
Total Stars: | 256 |
Total Watchers: | 6 |
Total Forks: | 33 |
Total Open Issues: | 2 |
Elasticsearch driver for Laravel Scout.
The current version of Elastic Scout Driver has been tested with the following configuration:
The library can be installed via Composer:
composer require babenkoivan/elastic-scout-driver
Note, that this library is just a driver for Laravel Scout, don't forget to install it beforehand:
composer require laravel/scout
When Scout is installed publish its configuration and change the driver
option in the config/scout.php
file to elastic
:
php artisan vendor:publish --provider="Laravel\Scout\ScoutServiceProvider"
If you want to use Elastic Scout Driver with Lumen framework check this guide.
Elastic Scout Driver uses babenkoivan/elastic-client as a dependency. If you want to change the default client settings (and I'm pretty sure you do), then you need to create the configuration file first:
php artisan vendor:publish --provider="ElasticClient\ServiceProvider"
You can change Elasticsearch host and the other client settings in the config/elastic.client.php
file.
Please refer to babenkoivan/elastic-client for more details.
Elastic Scout Driver itself has only one configuration option at the moment - refresh_documents
.
If it's set to true
(false
by default) documents are indexed immediately, which might be handy for testing.
You can configure refresh_documents
in the config/elastic.scout_driver.php
file after publishing it with the following command:
php artisan vendor:publish --provider="ElasticScoutDriver\ServiceProvider"
At last, do not forget, that with Scout you can configure the searchable data, the model id and the index name. Check the official Scout documentation for more details.
Note, that the
_id
field can't be part of the searchable data, so make sure the field is excluded or renamed in thetoSearchableArray
method in case you are using MongoDB as the database.
Elastic driver uses Elasticsearch query string wrapped in a bool query under the hood. It means that you can use mini-language syntax when searching a model:
$orders = App\Order::search('title:(Star OR Trek)')->get();
When the query string is omitted, the match all query is used:
$orders = App\Order::search()->where('user_id', 1)->get();
Please refer to the official Laravel Scout documentation for more details and usage examples.
In case the basic search doesn't cover your project needs check Elastic Scout Driver Plus, which extends standard Scout search capabilities by introducing advanced query builders. These builders give you possibility to use compound queries, custom filters and sorting, highlights and more.
If you are looking for a way to control Elasticsearch index schema programmatically check Elastic Migrations. Elastic Migrations allow you to modify application's index schema and share it across multiple environments with the same ease, that gives you Laravel database migrations.
There are few things, which are slightly different from other Scout drivers:
toSearchableArray
method.
Elastic driver indexes a model even when toSearchableArray
returns an empty array. You can change this behaviour by
overwriting the shouldBeSearchable
method of your model:public function shouldBeSearchable()
{
return count($this->toSearchableArray()) > 0;
}
SearchResponse
class (see Elastic Adapter):$searchResponse = App\Order::search('Star Trek')->raw();
search
method:App\Order::search('Star Trek', function () {
// this will not be triggered
})->get()