babenkoivan / elastic-scout-driver
Elasticsearch driver for Laravel Scout
Installs: 3 314 856
Dependents: 5
Suggesters: 0
Security: 0
Stars: 273
Watchers: 4
Forks: 32
Open Issues: 0
pkg:composer/babenkoivan/elastic-scout-driver
Requires
- php: ^8.2
- babenkoivan/elastic-adapter: ^4.0
Requires (Dev)
- babenkoivan/elastic-migrations: ^4.0
- friendsofphp/php-cs-fixer: ^3.14
- laravel/legacy-factories: ^1.3
- laravel/scout: ^10.0
- orchestra/testbench: ^9.0
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^11.0
README
Elasticsearch driver for Laravel Scout.
Contents
Compatibility
The current version of Elastic Scout Driver has been tested with the following configuration:
- PHP 8.2
- Elasticsearch 8.x
- Laravel 11.x
- Laravel Scout 10.x
If your project uses older Laravel (or PHP) version check the previous major version of the package.
Installation
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
After Scout has been installed, publish its configuration file using:
php artisan vendor:publish --provider="Laravel\Scout\ScoutServiceProvider"
Then, change the driver option in the config/scout.php file to elastic:
// config/scout.php 'driver' => env('SCOUT_DRIVER', 'elastic'),
If you want to use Elastic Scout Driver with Lumen framework check this guide.
Configuration
Elastic Scout Driver uses babenkoivan/elastic-client as a dependency. To change the client settings you need to publish the configuration file first:
php artisan vendor:publish --provider="Elastic\Client\ServiceProvider"
In the newly created config/elastic.client.php file you can define the default connection name using configuration hashes.
Please, refer to the elastic-client documentation 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="Elastic\ScoutDriver\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
_idfield can't be part of the searchable data, so make sure the field is excluded or renamed in thetoSearchableArraymethod in case you are using MongoDB as the database.
Basic usage
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.
Advanced Search
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.
Migrations
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.
Pitfalls
There are few things, which are slightly different from other Scout drivers:
- As you probably know, Scout only indexes fields, which are returned by the toSearchableArraymethod. Elastic driver indexes a model even whentoSearchableArrayreturns an empty array. You can change this behaviour by overwriting theshouldBeSearchablemethod of your model:
public function shouldBeSearchable() { return count($this->toSearchableArray()) > 0; }
- Raw search returns an instance of SearchResultclass (see Elastic Adapter):
$searchResult = App\Order::search('Star Trek')->raw();
- To be compatible with other drivers and to not expose internal implementation of the engine, Elastic driver ignores callback
parameter of the searchmethod:
App\Order::search('Star Trek', function () { // this will not be triggered })->get()
